From 5dce8c1e788881d59d9d5ff646bda29ed1bf0841 Mon Sep 17 00:00:00 2001 From: Obidur Rahman Date: Thu, 11 Jul 2024 00:12:49 +0600 Subject: [PATCH] Changes to be committed: --- .gitignore | 9 + .../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 | 1024 --- .../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 - myenv/Lib/site-packages/pip/__init__.py | 2 +- myenv/Lib/site-packages/pip/__pip-runner__.py | 4 +- .../pip/__pycache__/__init__.cpython-311.pyc | Bin 783 -> 785 bytes .../pip/__pycache__/__main__.cpython-311.pyc | Bin 902 -> 902 bytes .../__pip-runner__.cpython-311.pyc | Bin 2521 -> 2521 bytes .../site-packages/pip/_internal/__init__.py | 2 +- .../__pycache__/__init__.cpython-311.pyc | Bin 899 -> 899 bytes .../__pycache__/build_env.cpython-311.pyc | Bin 16088 -> 16329 bytes .../__pycache__/cache.cpython-311.pyc | Bin 14403 -> 14403 bytes .../__pycache__/configuration.cpython-311.pyc | Bin 19794 -> 19794 bytes .../__pycache__/exceptions.cpython-311.pyc | Bin 37458 -> 40109 bytes .../__pycache__/main.cpython-311.pyc | Bin 768 -> 768 bytes .../__pycache__/pyproject.cpython-311.pyc | Bin 5626 -> 5626 bytes .../self_outdated_check.cpython-311.pyc | Bin 11783 -> 11742 bytes .../__pycache__/wheel_builder.cpython-311.pyc | Bin 15184 -> 15149 bytes .../site-packages/pip/_internal/build_env.py | 3 + .../Lib/site-packages/pip/_internal/cache.py | 2 +- .../cli/__pycache__/__init__.cpython-311.pyc | Bin 303 -> 303 bytes .../autocompletion.cpython-311.pyc | Bin 10258 -> 10441 bytes .../__pycache__/base_command.cpython-311.pyc | Bin 11877 -> 11817 bytes .../__pycache__/cmdoptions.cpython-311.pyc | Bin 33783 -> 33792 bytes .../command_context.cpython-311.pyc | Bin 2125 -> 2125 bytes .../cli/__pycache__/main.cpython-311.pyc | Bin 2595 -> 2597 bytes .../__pycache__/main_parser.cpython-311.pyc | Bin 5539 -> 5539 bytes .../cli/__pycache__/parser.cpython-311.pyc | Bin 16964 -> 17026 bytes .../__pycache__/progress_bars.cpython-311.pyc | Bin 3187 -> 4603 bytes .../__pycache__/req_command.cpython-311.pyc | Bin 20342 -> 13096 bytes .../cli/__pycache__/spinners.cpython-311.pyc | Bin 8852 -> 8852 bytes .../__pycache__/status_codes.cpython-311.pyc | Bin 391 -> 391 bytes .../pip/_internal/cli/autocompletion.py | 4 + .../pip/_internal/cli/base_command.py | 2 - .../pip/_internal/cli/cmdoptions.py | 6 +- .../site-packages/pip/_internal/cli/main.py | 1 + .../site-packages/pip/_internal/cli/parser.py | 6 +- .../pip/_internal/cli/progress_bars.py | 26 + .../pip/_internal/cli/req_command.py | 198 +- .../__pycache__/__init__.cpython-311.pyc | Bin 4471 -> 4471 bytes .../__pycache__/cache.cpython-311.pyc | Bin 10891 -> 10891 bytes .../__pycache__/check.cpython-311.pyc | Bin 2426 -> 2321 bytes .../__pycache__/completion.cpython-311.pyc | Bin 5641 -> 5641 bytes .../__pycache__/configuration.cpython-311.pyc | Bin 14869 -> 14869 bytes .../__pycache__/debug.cpython-311.pyc | Bin 12214 -> 12182 bytes .../__pycache__/download.cpython-311.pyc | Bin 7960 -> 7865 bytes .../__pycache__/freeze.cpython-311.pyc | Bin 4676 -> 4676 bytes .../commands/__pycache__/hash.cpython-311.pyc | Bin 3373 -> 3373 bytes .../commands/__pycache__/help.cpython-311.pyc | Bin 1985 -> 1985 bytes .../__pycache__/index.cpython-311.pyc | Bin 7739 -> 7674 bytes .../__pycache__/inspect.cpython-311.pyc | Bin 4461 -> 4462 bytes .../__pycache__/install.cpython-311.pyc | Bin 31161 -> 31139 bytes .../commands/__pycache__/list.cpython-311.pyc | Bin 17265 -> 17723 bytes .../__pycache__/search.cpython-311.pyc | Bin 8967 -> 8870 bytes .../commands/__pycache__/show.cpython-311.pyc | Bin 11310 -> 12284 bytes .../__pycache__/uninstall.cpython-311.pyc | Bin 5161 -> 5167 bytes .../__pycache__/wheel.cpython-311.pyc | Bin 9417 -> 9322 bytes .../pip/_internal/commands/check.py | 2 - .../pip/_internal/commands/debug.py | 4 +- .../pip/_internal/commands/download.py | 1 - .../pip/_internal/commands/index.py | 6 +- .../pip/_internal/commands/inspect.py | 2 +- .../pip/_internal/commands/install.py | 15 +- .../pip/_internal/commands/list.py | 25 +- .../pip/_internal/commands/search.py | 8 +- .../pip/_internal/commands/show.py | 38 +- .../pip/_internal/commands/uninstall.py | 3 +- .../pip/_internal/commands/wheel.py | 1 - .../__pycache__/__init__.cpython-311.pyc | Bin 1053 -> 1053 bytes .../__pycache__/base.cpython-311.pyc | Bin 3145 -> 3188 bytes .../__pycache__/installed.cpython-311.pyc | Bin 1862 -> 1862 bytes .../__pycache__/sdist.cpython-311.pyc | Bin 9385 -> 9367 bytes .../__pycache__/wheel.cpython-311.pyc | Bin 2453 -> 2498 bytes .../pip/_internal/distributions/base.py | 8 +- .../pip/_internal/distributions/sdist.py | 14 +- .../pip/_internal/distributions/wheel.py | 8 +- .../site-packages/pip/_internal/exceptions.py | 67 +- .../__pycache__/__init__.cpython-311.pyc | Bin 257 -> 257 bytes .../__pycache__/collector.cpython-311.pyc | Bin 24602 -> 24349 bytes .../package_finder.cpython-311.pyc | Bin 44166 -> 44110 bytes .../index/__pycache__/sources.cpython-311.pyc | Bin 13973 -> 13973 bytes .../pip/_internal/index/collector.py | 47 +- .../pip/_internal/index/package_finder.py | 32 +- .../pip/_internal/locations/__init__.py | 11 - .../__pycache__/__init__.cpython-311.pyc | Bin 18195 -> 17884 bytes .../__pycache__/_distutils.cpython-311.pyc | Bin 7569 -> 7569 bytes .../__pycache__/_sysconfig.cpython-311.pyc | Bin 8899 -> 8917 bytes .../__pycache__/base.cpython-311.pyc | Bin 4020 -> 4020 bytes .../pip/_internal/locations/_sysconfig.py | 5 +- .../__pycache__/__init__.cpython-311.pyc | Bin 6519 -> 6519 bytes .../__pycache__/_json.cpython-311.pyc | Bin 3582 -> 3656 bytes .../metadata/__pycache__/base.cpython-311.pyc | Bin 38696 -> 38179 bytes .../__pycache__/pkg_resources.cpython-311.pyc | Bin 17553 -> 18225 bytes .../pip/_internal/metadata/_json.py | 4 +- .../pip/_internal/metadata/base.py | 56 +- .../__pycache__/__init__.cpython-311.pyc | Bin 408 -> 408 bytes .../__pycache__/_compat.cpython-311.pyc | Bin 3581 -> 3581 bytes .../__pycache__/_dists.cpython-311.pyc | Bin 14891 -> 14591 bytes .../__pycache__/_envs.cpython-311.pyc | Bin 12524 -> 12523 bytes .../_internal/metadata/importlib/_dists.py | 27 +- .../pip/_internal/metadata/importlib/_envs.py | 2 +- .../pip/_internal/metadata/pkg_resources.py | 45 +- .../__pycache__/__init__.cpython-311.pyc | Bin 291 -> 291 bytes .../__pycache__/candidate.cpython-311.pyc | Bin 2099 -> 1861 bytes .../__pycache__/direct_url.cpython-311.pyc | Bin 12784 -> 12423 bytes .../format_control.cpython-311.pyc | Bin 4645 -> 4645 bytes .../models/__pycache__/index.cpython-311.pyc | Bin 1916 -> 1916 bytes .../installation_report.cpython-311.pyc | Bin 2622 -> 2622 bytes .../models/__pycache__/link.cpython-311.pyc | Bin 28635 -> 29181 bytes .../models/__pycache__/scheme.cpython-311.pyc | Bin 1282 -> 1164 bytes .../__pycache__/search_scope.cpython-311.pyc | Bin 5845 -> 5781 bytes .../selection_prefs.cpython-311.pyc | Bin 2013 -> 2013 bytes .../__pycache__/target_python.cpython-311.pyc | Bin 5312 -> 5312 bytes .../models/__pycache__/wheel.cpython-311.pyc | Bin 6438 -> 6438 bytes .../pip/_internal/models/candidate.py | 29 +- .../pip/_internal/models/direct_url.py | 41 +- .../pip/_internal/models/link.py | 19 +- .../pip/_internal/models/scheme.py | 20 +- .../pip/_internal/models/search_scope.py | 17 +- .../pip/_internal/models/selection_prefs.py | 2 + .../pip/_internal/models/target_python.py | 1 - .../pip/_internal/models/wheel.py | 1 + .../__pycache__/__init__.cpython-311.pyc | Bin 279 -> 279 bytes .../network/__pycache__/auth.cpython-311.pyc | Bin 24006 -> 24002 bytes .../network/__pycache__/cache.cpython-311.pyc | Bin 7947 -> 7947 bytes .../__pycache__/download.cpython-311.pyc | Bin 9557 -> 9559 bytes .../__pycache__/lazy_wheel.cpython-311.pyc | Bin 13040 -> 13040 bytes .../__pycache__/session.cpython-311.pyc | Bin 21456 -> 21575 bytes .../network/__pycache__/utils.cpython-311.pyc | Bin 2428 -> 2428 bytes .../__pycache__/xmlrpc.cpython-311.pyc | Bin 3265 -> 3265 bytes .../pip/_internal/network/auth.py | 11 +- .../pip/_internal/network/download.py | 1 + .../pip/_internal/network/session.py | 4 +- .../__pycache__/__init__.cpython-311.pyc | Bin 217 -> 217 bytes .../__pycache__/check.cpython-311.pyc | Bin 8480 -> 6638 bytes .../__pycache__/freeze.cpython-311.pyc | Bin 11613 -> 11662 bytes .../__pycache__/prepare.cpython-311.pyc | Bin 27838 -> 27978 bytes .../__pycache__/__init__.cpython-311.pyc | Bin 223 -> 223 bytes .../__pycache__/build_tracker.cpython-311.pyc | Bin 8944 -> 8810 bytes .../__pycache__/metadata.cpython-311.pyc | Bin 2294 -> 2294 bytes .../metadata_editable.cpython-311.pyc | Bin 2330 -> 2330 bytes .../metadata_legacy.cpython-311.pyc | Bin 3730 -> 3682 bytes .../build/__pycache__/wheel.cpython-311.pyc | Bin 1960 -> 1960 bytes .../wheel_editable.cpython-311.pyc | Bin 2404 -> 2404 bytes .../__pycache__/wheel_legacy.cpython-311.pyc | Bin 4511 -> 4429 bytes .../operations/build/build_tracker.py | 5 +- .../operations/build/metadata_legacy.py | 2 +- .../operations/build/wheel_legacy.py | 8 +- .../pip/_internal/operations/check.py | 46 +- .../pip/_internal/operations/freeze.py | 11 +- .../__pycache__/__init__.cpython-311.pyc | Bin 291 -> 291 bytes .../editable_legacy.cpython-311.pyc | Bin 2204 -> 2206 bytes .../install/__pycache__/wheel.cpython-311.pyc | Bin 40185 -> 40294 bytes .../operations/install/editable_legacy.py | 1 + .../pip/_internal/operations/install/wheel.py | 33 +- .../pip/_internal/operations/prepare.py | 14 +- .../pip/_internal/req/__init__.py | 8 +- .../req/__pycache__/__init__.cpython-311.pyc | Bin 4404 -> 4144 bytes .../__pycache__/constructors.cpython-311.pyc | Bin 23413 -> 23070 bytes .../req/__pycache__/req_file.cpython-311.pyc | Bin 23125 -> 23102 bytes .../__pycache__/req_install.cpython-311.pyc | Bin 40261 -> 39825 bytes .../req/__pycache__/req_set.cpython-311.pyc | Bin 7973 -> 6019 bytes .../__pycache__/req_uninstall.cpython-311.pyc | Bin 37338 -> 36651 bytes .../pip/_internal/req/constructors.py | 46 +- .../pip/_internal/req/req_file.py | 25 +- .../pip/_internal/req/req_install.py | 19 +- .../pip/_internal/req/req_set.py | 37 - .../pip/_internal/req/req_uninstall.py | 28 +- .../__pycache__/__init__.cpython-311.pyc | Bin 217 -> 217 bytes .../__pycache__/base.cpython-311.pyc | Bin 1388 -> 1388 bytes .../__pycache__/__init__.cpython-311.pyc | Bin 224 -> 224 bytes .../__pycache__/resolver.cpython-311.pyc | Bin 23681 -> 23849 bytes .../_internal/resolution/legacy/resolver.py | 25 +- .../__pycache__/__init__.cpython-311.pyc | Bin 228 -> 228 bytes .../__pycache__/base.cpython-311.pyc | Bin 9316 -> 9138 bytes .../__pycache__/candidates.cpython-311.pyc | Bin 31410 -> 30065 bytes .../__pycache__/factory.cpython-311.pyc | Bin 35798 -> 35985 bytes .../found_candidates.cpython-311.pyc | Bin 6776 -> 7416 bytes .../__pycache__/provider.cpython-311.pyc | Bin 11467 -> 11632 bytes .../__pycache__/reporter.cpython-311.pyc | Bin 5458 -> 5458 bytes .../__pycache__/requirements.cpython-311.pyc | Bin 12230 -> 16137 bytes .../__pycache__/resolver.cpython-311.pyc | Bin 13468 -> 13468 bytes .../_internal/resolution/resolvelib/base.py | 18 +- .../resolution/resolvelib/candidates.py | 122 +- .../resolution/resolvelib/factory.py | 22 +- .../resolution/resolvelib/found_candidates.py | 29 +- .../resolution/resolvelib/provider.py | 3 + .../resolution/resolvelib/requirements.py | 79 + .../pip/_internal/self_outdated_check.py | 4 +- .../__pycache__/__init__.cpython-311.pyc | Bin 212 -> 212 bytes .../__pycache__/_jaraco_text.cpython-311.pyc | Bin 4776 -> 4775 bytes .../utils/__pycache__/_log.cpython-311.pyc | Bin 2033 -> 2033 bytes .../utils/__pycache__/appdirs.cpython-311.pyc | Bin 2571 -> 2571 bytes .../utils/__pycache__/compat.cpython-311.pyc | Bin 2279 -> 3015 bytes .../compatibility_tags.cpython-311.pyc | Bin 6771 -> 6771 bytes .../__pycache__/datetime.cpython-311.pyc | Bin 729 -> 729 bytes .../__pycache__/deprecation.cpython-311.pyc | Bin 4698 -> 4703 bytes .../direct_url_helpers.cpython-311.pyc | Bin 3733 -> 3695 bytes .../__pycache__/egg_link.cpython-311.pyc | Bin 3567 -> 3567 bytes .../__pycache__/encoding.cpython-311.pyc | Bin 2335 -> 2335 bytes .../__pycache__/entrypoints.cpython-311.pyc | Bin 4257 -> 4257 bytes .../__pycache__/filesystem.cpython-311.pyc | Bin 8242 -> 8242 bytes .../__pycache__/filetypes.cpython-311.pyc | Bin 1328 -> 1328 bytes .../utils/__pycache__/glibc.cpython-311.pyc | Bin 2624 -> 2624 bytes .../utils/__pycache__/hashes.cpython-311.pyc | Bin 8783 -> 8759 bytes .../utils/__pycache__/logging.cpython-311.pyc | Bin 15383 -> 15383 bytes .../utils/__pycache__/misc.cpython-311.pyc | Bin 38629 -> 38117 bytes .../utils/__pycache__/models.cpython-311.pyc | Bin 2952 -> 0 bytes .../__pycache__/packaging.cpython-311.pyc | Bin 2819 -> 2819 bytes .../setuptools_build.cpython-311.pyc | Bin 4884 -> 4884 bytes .../__pycache__/subprocess.cpython-311.pyc | Bin 9911 -> 9803 bytes .../__pycache__/temp_dir.cpython-311.pyc | Bin 13396 -> 13396 bytes .../__pycache__/unpacking.cpython-311.pyc | Bin 12908 -> 15523 bytes .../utils/__pycache__/urls.cpython-311.pyc | Bin 2704 -> 2306 bytes .../__pycache__/virtualenv.cpython-311.pyc | Bin 4952 -> 4952 bytes .../utils/__pycache__/wheel.cpython-311.pyc | Bin 7040 -> 7003 bytes .../pip/_internal/utils/_jaraco_text.py | 2 +- .../pip/_internal/utils/compat.py | 16 + .../pip/_internal/utils/deprecation.py | 16 +- .../pip/_internal/utils/direct_url_helpers.py | 4 +- .../pip/_internal/utils/hashes.py | 6 +- .../pip/_internal/utils/logging.py | 1 - .../site-packages/pip/_internal/utils/misc.py | 77 +- .../pip/_internal/utils/models.py | 39 - .../pip/_internal/utils/subprocess.py | 17 +- .../pip/_internal/utils/unpacking.py | 178 +- .../site-packages/pip/_internal/utils/urls.py | 7 - .../pip/_internal/utils/wheel.py | 2 +- .../vcs/__pycache__/__init__.cpython-311.pyc | Bin 647 -> 647 bytes .../vcs/__pycache__/bazaar.cpython-311.pyc | Bin 5872 -> 5909 bytes .../vcs/__pycache__/git.cpython-311.pyc | Bin 21387 -> 21480 bytes .../vcs/__pycache__/mercurial.cpython-311.pyc | Bin 8740 -> 8740 bytes .../__pycache__/subversion.cpython-311.pyc | Bin 14615 -> 14655 bytes .../versioncontrol.cpython-311.pyc | Bin 31779 -> 31781 bytes .../site-packages/pip/_internal/vcs/bazaar.py | 8 +- .../site-packages/pip/_internal/vcs/git.py | 3 +- .../pip/_internal/vcs/subversion.py | 6 +- .../pip/_internal/vcs/versioncontrol.py | 49 +- .../pip/_internal/wheel_builder.py | 2 +- .../Lib/site-packages/pip/_vendor/__init__.py | 5 - .../__pycache__/__init__.cpython-311.pyc | Bin 5675 -> 5415 bytes .../_vendor/__pycache__/six.cpython-311.pyc | Bin 46427 -> 0 bytes .../typing_extensions.cpython-311.pyc | Bin 131597 -> 138645 bytes .../pip/_vendor/cachecontrol/__init__.py | 2 +- .../__pycache__/__init__.cpython-311.pyc | Bin 991 -> 991 bytes .../__pycache__/_cmd.cpython-311.pyc | Bin 3042 -> 3042 bytes .../__pycache__/adapter.cpython-311.pyc | Bin 6918 -> 6918 bytes .../__pycache__/cache.cpython-311.pyc | Bin 4515 -> 4515 bytes .../__pycache__/controller.cpython-311.pyc | Bin 18268 -> 18320 bytes .../__pycache__/filewrapper.cpython-311.pyc | Bin 4771 -> 4771 bytes .../__pycache__/heuristics.cpython-311.pyc | Bin 7574 -> 7574 bytes .../__pycache__/serialize.cpython-311.pyc | Bin 7050 -> 5952 bytes .../__pycache__/wrapper.cpython-311.pyc | Bin 1883 -> 1883 bytes .../pip/_vendor/cachecontrol/adapter.py | 10 +- .../__pycache__/__init__.cpython-311.pyc | Bin 492 -> 492 bytes .../__pycache__/file_cache.cpython-311.pyc | Bin 8998 -> 9099 bytes .../__pycache__/redis_cache.cpython-311.pyc | Bin 3099 -> 3099 bytes .../_vendor/cachecontrol/caches/file_cache.py | 7 +- .../pip/_vendor/cachecontrol/controller.py | 7 +- .../pip/_vendor/cachecontrol/heuristics.py | 2 +- .../pip/_vendor/cachecontrol/serialize.py | 76 +- .../pip/_vendor/certifi/__init__.py | 2 +- .../__pycache__/__init__.cpython-311.pyc | Bin 354 -> 354 bytes .../__pycache__/__main__.cpython-311.pyc | Bin 755 -> 755 bytes .../certifi/__pycache__/core.cpython-311.pyc | Bin 3377 -> 3801 bytes .../pip/_vendor/certifi/cacert.pem | 321 +- .../site-packages/pip/_vendor/certifi/core.py | 6 + .../pip/_vendor/chardet/__init__.py | 115 - .../__pycache__/__init__.cpython-311.pyc | Bin 5086 -> 0 bytes .../__pycache__/big5freq.cpython-311.pyc | Bin 27216 -> 0 bytes .../__pycache__/big5prober.cpython-311.pyc | Bin 1691 -> 0 bytes .../chardistribution.cpython-311.pyc | Bin 11283 -> 0 bytes .../charsetgroupprober.cpython-311.pyc | Bin 4313 -> 0 bytes .../__pycache__/charsetprober.cpython-311.pyc | Bin 5559 -> 0 bytes .../codingstatemachine.cpython-311.pyc | Bin 4010 -> 0 bytes .../codingstatemachinedict.cpython-311.pyc | Bin 966 -> 0 bytes .../__pycache__/cp949prober.cpython-311.pyc | Bin 1700 -> 0 bytes .../chardet/__pycache__/enums.cpython-311.pyc | Bin 3401 -> 0 bytes .../__pycache__/escprober.cpython-311.pyc | Bin 4917 -> 0 bytes .../chardet/__pycache__/escsm.cpython-311.pyc | Bin 12656 -> 0 bytes .../__pycache__/eucjpprober.cpython-311.pyc | Bin 4743 -> 0 bytes .../__pycache__/euckrfreq.cpython-311.pyc | Bin 12099 -> 0 bytes .../__pycache__/euckrprober.cpython-311.pyc | Bin 1692 -> 0 bytes .../__pycache__/euctwfreq.cpython-311.pyc | Bin 27221 -> 0 bytes .../__pycache__/euctwprober.cpython-311.pyc | Bin 1692 -> 0 bytes .../__pycache__/gb2312freq.cpython-311.pyc | Bin 19143 -> 0 bytes .../__pycache__/gb2312prober.cpython-311.pyc | Bin 1707 -> 0 bytes .../__pycache__/hebrewprober.cpython-311.pyc | Bin 5696 -> 0 bytes .../__pycache__/jisfreq.cpython-311.pyc | Bin 22172 -> 0 bytes .../__pycache__/johabfreq.cpython-311.pyc | Bin 84676 -> 0 bytes .../__pycache__/johabprober.cpython-311.pyc | Bin 1698 -> 0 bytes .../__pycache__/jpcntx.cpython-311.pyc | Bin 40180 -> 0 bytes .../langbulgarianmodel.cpython-311.pyc | Bin 85850 -> 0 bytes .../langgreekmodel.cpython-311.pyc | Bin 79272 -> 0 bytes .../langhebrewmodel.cpython-311.pyc | Bin 80034 -> 0 bytes .../langhungarianmodel.cpython-311.pyc | Bin 85804 -> 0 bytes .../langrussianmodel.cpython-311.pyc | Bin 108751 -> 0 bytes .../__pycache__/langthaimodel.cpython-311.pyc | Bin 80212 -> 0 bytes .../langturkishmodel.cpython-311.pyc | Bin 80051 -> 0 bytes .../__pycache__/latin1prober.cpython-311.pyc | Bin 7347 -> 0 bytes .../macromanprober.cpython-311.pyc | Bin 7514 -> 0 bytes .../mbcharsetprober.cpython-311.pyc | Bin 4135 -> 0 bytes .../mbcsgroupprober.cpython-311.pyc | Bin 2005 -> 0 bytes .../__pycache__/mbcssm.cpython-311.pyc | Bin 31745 -> 0 bytes .../__pycache__/resultdict.cpython-311.pyc | Bin 784 -> 0 bytes .../sbcharsetprober.cpython-311.pyc | Bin 6410 -> 0 bytes .../sbcsgroupprober.cpython-311.pyc | Bin 2955 -> 0 bytes .../__pycache__/sjisprober.cpython-311.pyc | Bin 4848 -> 0 bytes .../universaldetector.cpython-311.pyc | Bin 12476 -> 0 bytes .../__pycache__/utf1632prober.cpython-311.pyc | Bin 10596 -> 0 bytes .../__pycache__/utf8prober.cpython-311.pyc | Bin 3483 -> 0 bytes .../__pycache__/version.cpython-311.pyc | Bin 519 -> 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-311.pyc | Bin 216 -> 0 bytes .../__pycache__/chardetect.cpython-311.pyc | Bin 4355 -> 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-311.pyc | Bin 221 -> 0 bytes .../__pycache__/languages.cpython-311.pyc | Bin 10821 -> 0 bytes .../pip/_vendor/chardet/metadata/languages.py | 352 - .../pip/_vendor/chardet/py.typed | 0 .../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-311.pyc | Bin 588 -> 0 bytes .../colorama/__pycache__/ansi.cpython-311.pyc | Bin 4586 -> 0 bytes .../__pycache__/ansitowin32.cpython-311.pyc | Bin 16232 -> 0 bytes .../__pycache__/initialise.cpython-311.pyc | Bin 3949 -> 0 bytes .../__pycache__/win32.cpython-311.pyc | Bin 7937 -> 0 bytes .../__pycache__/winterm.cpython-311.pyc | Bin 9163 -> 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-311.pyc | Bin 219 -> 0 bytes .../__pycache__/ansi_test.cpython-311.pyc | Bin 5864 -> 0 bytes .../ansitowin32_test.cpython-311.pyc | Bin 21531 -> 0 bytes .../initialise_test.cpython-311.pyc | Bin 14158 -> 0 bytes .../__pycache__/isatty_test.cpython-311.pyc | Bin 6723 -> 0 bytes .../tests/__pycache__/utils.cpython-311.pyc | Bin 2898 -> 0 bytes .../__pycache__/winterm_test.cpython-311.pyc | Bin 7251 -> 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 - .../__pycache__/__init__.cpython-311.pyc | Bin 1481 -> 1481 bytes .../__pycache__/compat.cpython-311.pyc | Bin 52418 -> 52418 bytes .../__pycache__/database.cpython-311.pyc | Bin 72199 -> 72199 bytes .../distlib/__pycache__/index.cpython-311.pyc | Bin 26680 -> 26680 bytes .../__pycache__/locators.cpython-311.pyc | Bin 65805 -> 65805 bytes .../__pycache__/manifest.cpython-311.pyc | Bin 17030 -> 17030 bytes .../__pycache__/markers.cpython-311.pyc | Bin 8564 -> 8564 bytes .../__pycache__/metadata.cpython-311.pyc | Bin 47445 -> 47445 bytes .../__pycache__/resources.cpython-311.pyc | Bin 19006 -> 19006 bytes .../__pycache__/scripts.cpython-311.pyc | Bin 21258 -> 21578 bytes .../distlib/__pycache__/util.cpython-311.pyc | Bin 98209 -> 98209 bytes .../__pycache__/version.cpython-311.pyc | Bin 34828 -> 34828 bytes .../distlib/__pycache__/wheel.cpython-311.pyc | Bin 59491 -> 59491 bytes .../pip/_vendor/distlib/scripts.py | 26 +- .../__pycache__/__init__.cpython-311.pyc | Bin 1210 -> 1210 bytes .../__pycache__/__main__.cpython-311.pyc | Bin 344 -> 344 bytes .../distro/__pycache__/distro.cpython-311.pyc | Bin 57743 -> 57834 bytes .../pip/_vendor/distro/distro.py | 12 +- .../idna/__pycache__/__init__.cpython-311.pyc | Bin 1111 -> 1111 bytes .../idna/__pycache__/codec.cpython-311.pyc | Bin 5402 -> 5798 bytes .../idna/__pycache__/compat.cpython-311.pyc | Bin 1028 -> 1028 bytes .../idna/__pycache__/core.cpython-311.pyc | Bin 19463 -> 18913 bytes .../idna/__pycache__/idnadata.cpython-311.pyc | Bin 38987 -> 101557 bytes .../__pycache__/intranges.cpython-311.pyc | Bin 2996 -> 2996 bytes .../__pycache__/package_data.cpython-311.pyc | Bin 231 -> 231 bytes .../__pycache__/uts46data.cpython-311.pyc | Bin 163211 -> 163189 bytes .../site-packages/pip/_vendor/idna/codec.py | 34 +- .../site-packages/pip/_vendor/idna/core.py | 33 +- .../pip/_vendor/idna/idnadata.py | 2206 +++++- .../pip/_vendor/idna/package_data.py | 2 +- .../pip/_vendor/idna/uts46data.py | 454 +- .../pip/_vendor/msgpack/__init__.py | 8 +- .../__pycache__/__init__.cpython-311.pyc | Bin 2090 -> 1996 bytes .../__pycache__/exceptions.cpython-311.pyc | Bin 2391 -> 2391 bytes .../msgpack/__pycache__/ext.cpython-311.pyc | Bin 9176 -> 8643 bytes .../__pycache__/fallback.cpython-311.pyc | Bin 47163 -> 45342 bytes .../site-packages/pip/_vendor/msgpack/ext.py | 55 +- .../pip/_vendor/msgpack/fallback.py | 147 +- .../pip/_vendor/packaging/__about__.py | 26 - .../pip/_vendor/packaging/__init__.py | 30 +- .../__pycache__/__about__.cpython-311.pyc | Bin 655 -> 0 bytes .../__pycache__/__init__.cpython-311.pyc | Bin 576 -> 573 bytes .../__pycache__/_manylinux.cpython-311.pyc | Bin 13242 -> 10934 bytes .../__pycache__/_musllinux.cpython-311.pyc | Bin 8010 -> 5325 bytes .../__pycache__/_structures.cpython-311.pyc | Bin 3698 -> 3698 bytes .../__pycache__/markers.cpython-311.pyc | Bin 16538 -> 12786 bytes .../__pycache__/requirements.cpython-311.pyc | Bin 7653 -> 4739 bytes .../__pycache__/specifiers.cpython-311.pyc | Bin 34376 -> 41274 bytes .../__pycache__/tags.cpython-311.pyc | Bin 21361 -> 24093 bytes .../__pycache__/utils.cpython-311.pyc | Bin 6696 -> 8326 bytes .../__pycache__/version.cpython-311.pyc | Bin 21888 -> 20844 bytes .../pip/_vendor/packaging/_manylinux.py | 237 +- .../pip/_vendor/packaging/_musllinux.py | 97 +- .../pip/_vendor/packaging/markers.py | 271 +- .../pip/_vendor/packaging/requirements.py | 153 +- .../pip/_vendor/packaging/specifiers.py | 995 +-- .../pip/_vendor/packaging/tags.py | 175 +- .../pip/_vendor/packaging/utils.py | 58 +- .../pip/_vendor/packaging/version.py | 427 +- .../pip/_vendor/pkg_resources/__init__.py | 190 +- .../__pycache__/__init__.cpython-311.pyc | Bin 160156 -> 159780 bytes .../pip/_vendor/platformdirs/__init__.py | 137 +- .../pip/_vendor/platformdirs/__main__.py | 4 +- .../__pycache__/__init__.cpython-311.pyc | Bin 17509 -> 19205 bytes .../__pycache__/__main__.cpython-311.pyc | Bin 2289 -> 2311 bytes .../__pycache__/android.cpython-311.pyc | Bin 10475 -> 11034 bytes .../__pycache__/api.cpython-311.pyc | Bin 10568 -> 14123 bytes .../__pycache__/macos.cpython-311.pyc | Bin 6080 -> 8532 bytes .../__pycache__/unix.cpython-311.pyc | Bin 13786 -> 16576 bytes .../__pycache__/version.cpython-311.pyc | Bin 326 -> 674 bytes .../__pycache__/windows.cpython-311.pyc | Bin 13954 -> 14717 bytes .../pip/_vendor/platformdirs/android.py | 38 +- .../pip/_vendor/platformdirs/api.py | 105 +- .../pip/_vendor/platformdirs/macos.py | 51 +- .../pip/_vendor/platformdirs/unix.py | 122 +- .../pip/_vendor/platformdirs/version.py | 16 +- .../pip/_vendor/platformdirs/windows.py | 49 +- .../pip/_vendor/pygments/__init__.py | 2 +- .../__pycache__/__init__.cpython-311.pyc | Bin 3845 -> 3845 bytes .../__pycache__/__main__.cpython-311.pyc | Bin 794 -> 794 bytes .../__pycache__/cmdline.cpython-311.pyc | Bin 30305 -> 30236 bytes .../__pycache__/console.cpython-311.pyc | Bin 3057 -> 3057 bytes .../__pycache__/filter.cpython-311.pyc | Bin 3518 -> 3518 bytes .../__pycache__/formatter.cpython-311.pyc | Bin 4833 -> 4833 bytes .../__pycache__/lexer.cpython-311.pyc | Bin 42321 -> 42306 bytes .../__pycache__/modeline.cpython-311.pyc | Bin 1737 -> 1737 bytes .../__pycache__/plugin.cpython-311.pyc | Bin 3750 -> 3750 bytes .../__pycache__/regexopt.cpython-311.pyc | Bin 5044 -> 5044 bytes .../__pycache__/scanner.cpython-311.pyc | Bin 4899 -> 4899 bytes .../__pycache__/sphinxext.cpython-311.pyc | Bin 12844 -> 13878 bytes .../__pycache__/style.cpython-311.pyc | Bin 7437 -> 7480 bytes .../__pycache__/token.cpython-311.pyc | Bin 7478 -> 7517 bytes .../__pycache__/unistring.cpython-311.pyc | Bin 33851 -> 33851 bytes .../pygments/__pycache__/util.cpython-311.pyc | Bin 15703 -> 15703 bytes .../pip/_vendor/pygments/cmdline.py | 4 +- .../__pycache__/__init__.cpython-311.pyc | Bin 40118 -> 40118 bytes .../_vendor/pygments/formatters/__init__.py | 2 +- .../__pycache__/__init__.cpython-311.pyc | Bin 7776 -> 7794 bytes .../__pycache__/_mapping.cpython-311.pyc | Bin 4236 -> 4236 bytes .../__pycache__/bbcode.cpython-311.pyc | Bin 4492 -> 4492 bytes .../__pycache__/groff.cpython-311.pyc | Bin 7865 -> 7865 bytes .../__pycache__/html.cpython-311.pyc | Bin 42654 -> 42764 bytes .../__pycache__/img.cpython-311.pyc | Bin 28582 -> 30093 bytes .../__pycache__/irc.cpython-311.pyc | Bin 6418 -> 6418 bytes .../__pycache__/latex.cpython-311.pyc | Bin 21818 -> 21818 bytes .../__pycache__/other.cpython-311.pyc | Bin 7646 -> 7646 bytes .../__pycache__/pangomarkup.cpython-311.pyc | Bin 3190 -> 3190 bytes .../__pycache__/rtf.cpython-311.pyc | Bin 6857 -> 6857 bytes .../__pycache__/svg.cpython-311.pyc | Bin 9677 -> 9677 bytes .../__pycache__/terminal.cpython-311.pyc | Bin 6056 -> 6056 bytes .../__pycache__/terminal256.cpython-311.pyc | Bin 16422 -> 16422 bytes .../pip/_vendor/pygments/formatters/html.py | 3 +- .../pip/_vendor/pygments/formatters/img.py | 41 +- .../pip/_vendor/pygments/lexer.py | 46 +- .../pip/_vendor/pygments/lexers/__init__.py | 1 + .../__pycache__/__init__.cpython-311.pyc | Bin 16362 -> 16390 bytes .../__pycache__/_mapping.cpython-311.pyc | Bin 64804 -> 67444 bytes .../lexers/__pycache__/python.cpython-311.pyc | Bin 43318 -> 43337 bytes .../pip/_vendor/pygments/lexers/_mapping.py | 33 +- .../pip/_vendor/pygments/lexers/python.py | 8 +- .../pip/_vendor/pygments/sphinxext.py | 22 + .../pip/_vendor/pygments/style.py | 6 + .../pip/_vendor/pygments/styles/__init__.py | 70 +- .../__pycache__/__init__.cpython-311.pyc | Bin 4693 -> 3113 bytes .../pip/_vendor/pygments/token.py | 1 + .../pip/_vendor/pyparsing/__init__.py | 322 - .../__pycache__/__init__.cpython-311.pyc | Bin 8242 -> 0 bytes .../__pycache__/actions.cpython-311.pyc | Bin 9133 -> 0 bytes .../__pycache__/common.cpython-311.pyc | Bin 14880 -> 0 bytes .../__pycache__/core.cpython-311.pyc | Bin 295453 -> 0 bytes .../__pycache__/exceptions.cpython-311.pyc | Bin 13720 -> 0 bytes .../__pycache__/helpers.cpython-311.pyc | Bin 54139 -> 0 bytes .../__pycache__/results.cpython-311.pyc | Bin 37860 -> 0 bytes .../__pycache__/testing.cpython-311.pyc | Bin 19523 -> 0 bytes .../__pycache__/unicode.cpython-311.pyc | Bin 15211 -> 0 bytes .../__pycache__/util.cpython-311.pyc | Bin 16794 -> 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-311.pyc | Bin 28802 -> 0 bytes .../pip/_vendor/pyparsing/exceptions.py | 299 - .../pip/_vendor/pyparsing/helpers.py | 1100 --- .../pip/_vendor/pyparsing/py.typed | 0 .../pip/_vendor/pyparsing/results.py | 796 --- .../pip/_vendor/pyparsing/testing.py | 331 - .../pip/_vendor/pyparsing/unicode.py | 361 - .../pip/_vendor/pyparsing/util.py | 284 - .../__pycache__/__init__.cpython-311.pyc | Bin 719 -> 719 bytes .../__pycache__/_compat.cpython-311.pyc | Bin 417 -> 417 bytes .../__pycache__/_impl.cpython-311.pyc | Bin 16683 -> 16683 bytes .../__pycache__/__init__.cpython-311.pyc | Bin 1179 -> 1179 bytes .../__pycache__/_in_process.cpython-311.pyc | Bin 16501 -> 16501 bytes .../pip/_vendor/requests/__init__.py | 9 +- .../__pycache__/__init__.cpython-311.pyc | Bin 6450 -> 6225 bytes .../__pycache__/__version__.cpython-311.pyc | Bin 600 -> 600 bytes .../_internal_utils.cpython-311.pyc | Bin 2164 -> 2164 bytes .../__pycache__/adapters.cpython-311.pyc | Bin 23217 -> 30767 bytes .../requests/__pycache__/api.cpython-311.pyc | Bin 7517 -> 7517 bytes .../requests/__pycache__/auth.cpython-311.pyc | Bin 14644 -> 14644 bytes .../__pycache__/certs.cpython-311.pyc | Bin 996 -> 996 bytes .../__pycache__/compat.cpython-311.pyc | Bin 1822 -> 1999 bytes .../__pycache__/cookies.cpython-311.pyc | Bin 27124 -> 27154 bytes .../__pycache__/exceptions.cpython-311.pyc | Bin 8539 -> 9098 bytes .../requests/__pycache__/help.cpython-311.pyc | Bin 4534 -> 4418 bytes .../__pycache__/hooks.cpython-311.pyc | Bin 1264 -> 1264 bytes .../__pycache__/models.cpython-311.pyc | Bin 38795 -> 38832 bytes .../__pycache__/packages.cpython-311.pyc | Bin 844 -> 1360 bytes .../__pycache__/sessions.cpython-311.pyc | Bin 29707 -> 29832 bytes .../__pycache__/status_codes.cpython-311.pyc | Bin 6251 -> 6323 bytes .../__pycache__/structures.cpython-311.pyc | Bin 6236 -> 6236 bytes .../__pycache__/utils.cpython-311.pyc | Bin 40270 -> 40615 bytes .../pip/_vendor/requests/__version__.py | 6 +- .../pip/_vendor/requests/adapters.py | 219 +- .../site-packages/pip/_vendor/requests/api.py | 2 +- .../pip/_vendor/requests/auth.py | 1 - .../pip/_vendor/requests/compat.py | 15 +- .../pip/_vendor/requests/cookies.py | 16 +- .../pip/_vendor/requests/exceptions.py | 10 + .../pip/_vendor/requests/help.py | 6 +- .../pip/_vendor/requests/models.py | 13 +- .../pip/_vendor/requests/packages.py | 13 +- .../pip/_vendor/requests/sessions.py | 12 +- .../pip/_vendor/requests/status_codes.py | 10 +- .../pip/_vendor/requests/utils.py | 16 +- .../__pycache__/__init__.cpython-311.pyc | Bin 767 -> 767 bytes .../__pycache__/providers.cpython-311.pyc | Bin 7085 -> 7085 bytes .../__pycache__/reporters.cpython-311.pyc | Bin 2849 -> 2849 bytes .../__pycache__/resolvers.cpython-311.pyc | Bin 29249 -> 29249 bytes .../__pycache__/structs.cpython-311.pyc | Bin 11486 -> 11486 bytes .../__pycache__/__init__.cpython-311.pyc | Bin 222 -> 222 bytes .../collections_abc.cpython-311.pyc | Bin 497 -> 497 bytes .../pip/_vendor/rich/__main__.py | 1 - .../rich/__pycache__/__init__.cpython-311.pyc | Bin 7510 -> 7510 bytes .../rich/__pycache__/__main__.cpython-311.pyc | Bin 11588 -> 11588 bytes .../__pycache__/_cell_widths.cpython-311.pyc | Bin 7849 -> 7900 bytes .../__pycache__/_emoji_codes.cpython-311.pyc | Bin 208536 -> 208536 bytes .../_emoji_replace.cpython-311.pyc | Bin 1948 -> 1948 bytes .../_export_format.cpython-311.pyc | Bin 2339 -> 2367 bytes .../__pycache__/_extension.cpython-311.pyc | Bin 649 -> 649 bytes .../rich/__pycache__/_fileno.cpython-311.pyc | Bin 991 -> 991 bytes .../rich/__pycache__/_inspect.cpython-311.pyc | Bin 14201 -> 14201 bytes .../__pycache__/_log_render.cpython-311.pyc | Bin 4783 -> 4783 bytes .../rich/__pycache__/_loop.cpython-311.pyc | Bin 2129 -> 2129 bytes .../__pycache__/_null_file.cpython-311.pyc | Bin 4188 -> 4188 bytes .../__pycache__/_palettes.cpython-311.pyc | Bin 5265 -> 5265 bytes .../rich/__pycache__/_pick.cpython-311.pyc | Bin 809 -> 809 bytes .../rich/__pycache__/_ratio.cpython-311.pyc | Bin 7948 -> 7946 bytes .../__pycache__/_spinners.cpython-311.pyc | Bin 13698 -> 13698 bytes .../rich/__pycache__/_stack.cpython-311.pyc | Bin 1144 -> 1144 bytes .../rich/__pycache__/_timer.cpython-311.pyc | Bin 997 -> 997 bytes .../_win32_console.cpython-311.pyc | Bin 30185 -> 30185 bytes .../rich/__pycache__/_windows.cpython-311.pyc | Bin 2844 -> 2844 bytes .../_windows_renderer.cpython-311.pyc | Bin 4035 -> 4035 bytes .../rich/__pycache__/_wrap.cpython-311.pyc | Bin 2800 -> 3871 bytes .../rich/__pycache__/abc.cpython-311.pyc | Bin 1941 -> 1941 bytes .../rich/__pycache__/align.cpython-311.pyc | Bin 13483 -> 13483 bytes .../rich/__pycache__/ansi.cpython-311.pyc | Bin 10514 -> 10514 bytes .../rich/__pycache__/bar.cpython-311.pyc | Bin 4563 -> 4563 bytes .../rich/__pycache__/box.cpython-311.pyc | Bin 13005 -> 13005 bytes .../rich/__pycache__/cells.cpython-311.pyc | Bin 6635 -> 6656 bytes .../rich/__pycache__/color.cpython-311.pyc | Bin 27819 -> 27819 bytes .../__pycache__/color_triplet.cpython-311.pyc | Bin 1889 -> 1889 bytes .../rich/__pycache__/columns.cpython-311.pyc | Bin 10660 -> 10660 bytes .../rich/__pycache__/console.cpython-311.pyc | Bin 123755 -> 123656 bytes .../__pycache__/constrain.cpython-311.pyc | Bin 2481 -> 2481 bytes .../__pycache__/containers.cpython-311.pyc | Bin 10822 -> 10827 bytes .../rich/__pycache__/control.cpython-311.pyc | Bin 11913 -> 11913 bytes .../default_styles.cpython-311.pyc | Bin 12616 -> 12616 bytes .../rich/__pycache__/diagnose.cpython-311.pyc | Bin 1836 -> 1836 bytes .../rich/__pycache__/emoji.cpython-311.pyc | Bin 4814 -> 4814 bytes .../rich/__pycache__/errors.cpython-311.pyc | Bin 2345 -> 2345 bytes .../__pycache__/file_proxy.cpython-311.pyc | Bin 4049 -> 4049 bytes .../rich/__pycache__/filesize.cpython-311.pyc | Bin 3317 -> 3317 bytes .../__pycache__/highlighter.cpython-311.pyc | Bin 11003 -> 11004 bytes .../rich/__pycache__/json.cpython-311.pyc | Bin 6560 -> 6560 bytes .../rich/__pycache__/jupyter.cpython-311.pyc | Bin 6420 -> 6420 bytes .../rich/__pycache__/layout.cpython-311.pyc | Bin 23327 -> 23327 bytes .../rich/__pycache__/live.cpython-311.pyc | Bin 21313 -> 21313 bytes .../__pycache__/live_render.cpython-311.pyc | Bin 5161 -> 5161 bytes .../rich/__pycache__/logging.cpython-311.pyc | Bin 14532 -> 14532 bytes .../rich/__pycache__/markup.cpython-311.pyc | Bin 10454 -> 10778 bytes .../rich/__pycache__/measure.cpython-311.pyc | Bin 7287 -> 7287 bytes .../rich/__pycache__/padding.cpython-311.pyc | Bin 7503 -> 7503 bytes .../rich/__pycache__/pager.cpython-311.pyc | Bin 2261 -> 2261 bytes .../rich/__pycache__/palette.cpython-311.pyc | Bin 5994 -> 5994 bytes .../rich/__pycache__/panel.cpython-311.pyc | Bin 12750 -> 12847 bytes .../rich/__pycache__/pretty.cpython-311.pyc | Bin 44363 -> 44507 bytes .../rich/__pycache__/progress.cpython-311.pyc | Bin 82630 -> 82682 bytes .../__pycache__/progress_bar.cpython-311.pyc | Bin 11028 -> 11028 bytes .../rich/__pycache__/prompt.cpython-311.pyc | Bin 16394 -> 16400 bytes .../rich/__pycache__/protocol.cpython-311.pyc | Bin 2112 -> 2112 bytes .../rich/__pycache__/region.cpython-311.pyc | Bin 675 -> 675 bytes .../rich/__pycache__/repr.cpython-311.pyc | Bin 7642 -> 7638 bytes .../rich/__pycache__/rule.cpython-311.pyc | Bin 7181 -> 7181 bytes .../rich/__pycache__/scope.cpython-311.pyc | Bin 4367 -> 4367 bytes .../rich/__pycache__/screen.cpython-311.pyc | Bin 2790 -> 2790 bytes .../rich/__pycache__/segment.cpython-311.pyc | Bin 31620 -> 31620 bytes .../rich/__pycache__/spinner.cpython-311.pyc | Bin 6896 -> 6896 bytes .../rich/__pycache__/status.cpython-311.pyc | Bin 6774 -> 6774 bytes .../rich/__pycache__/style.cpython-311.pyc | Bin 35214 -> 35214 bytes .../rich/__pycache__/styled.cpython-311.pyc | Bin 2455 -> 2455 bytes .../rich/__pycache__/syntax.cpython-311.pyc | Bin 42665 -> 43035 bytes .../rich/__pycache__/table.cpython-311.pyc | Bin 48816 -> 48816 bytes .../terminal_theme.cpython-311.pyc | Bin 3721 -> 3721 bytes .../rich/__pycache__/text.cpython-311.pyc | Bin 64973 -> 67148 bytes .../rich/__pycache__/theme.cpython-311.pyc | Bin 7320 -> 7320 bytes .../rich/__pycache__/themes.cpython-311.pyc | Bin 371 -> 371 bytes .../__pycache__/traceback.cpython-311.pyc | Bin 34583 -> 34583 bytes .../rich/__pycache__/tree.cpython-311.pyc | Bin 12542 -> 12542 bytes .../pip/_vendor/rich/_cell_widths.py | 367 +- .../pip/_vendor/rich/_export_format.py | 4 +- .../site-packages/pip/_vendor/rich/_ratio.py | 1 - .../pip/_vendor/rich/_windows.py | 1 - .../site-packages/pip/_vendor/rich/_wrap.py | 73 +- .../site-packages/pip/_vendor/rich/align.py | 2 +- .../Lib/site-packages/pip/_vendor/rich/bar.py | 1 - .../Lib/site-packages/pip/_vendor/rich/box.py | 345 +- .../site-packages/pip/_vendor/rich/cells.py | 55 +- .../site-packages/pip/_vendor/rich/color.py | 1 - .../site-packages/pip/_vendor/rich/console.py | 2 +- .../pip/_vendor/rich/containers.py | 8 +- .../pip/_vendor/rich/highlighter.py | 2 +- .../site-packages/pip/_vendor/rich/json.py | 1 - .../site-packages/pip/_vendor/rich/layout.py | 3 +- .../site-packages/pip/_vendor/rich/live.py | 2 +- .../pip/_vendor/rich/live_render.py | 1 - .../site-packages/pip/_vendor/rich/markup.py | 7 +- .../site-packages/pip/_vendor/rich/panel.py | 4 + .../site-packages/pip/_vendor/rich/pretty.py | 15 +- .../pip/_vendor/rich/progress.py | 7 +- .../pip/_vendor/rich/progress_bar.py | 1 - .../site-packages/pip/_vendor/rich/prompt.py | 3 +- .../site-packages/pip/_vendor/rich/repr.py | 2 +- .../site-packages/pip/_vendor/rich/segment.py | 1 - .../site-packages/pip/_vendor/rich/status.py | 1 - .../site-packages/pip/_vendor/rich/syntax.py | 12 +- .../site-packages/pip/_vendor/rich/table.py | 4 +- .../site-packages/pip/_vendor/rich/text.py | 116 +- .../pip/_vendor/rich/traceback.py | 3 - .../site-packages/pip/_vendor/rich/tree.py | 2 - myenv/Lib/site-packages/pip/_vendor/six.py | 998 --- .../pip/_vendor/tenacity/__init__.py | 2 +- .../__pycache__/__init__.cpython-311.pyc | Bin 29062 -> 29131 bytes .../__pycache__/_asyncio.cpython-311.pyc | Bin 5238 -> 5238 bytes .../__pycache__/_utils.cpython-311.pyc | Bin 2578 -> 2578 bytes .../__pycache__/after.cpython-311.pyc | Bin 1773 -> 1773 bytes .../__pycache__/before.cpython-311.pyc | Bin 1607 -> 1607 bytes .../__pycache__/before_sleep.cpython-311.pyc | Bin 2390 -> 2390 bytes .../tenacity/__pycache__/nap.cpython-311.pyc | Bin 1581 -> 1581 bytes .../__pycache__/retry.cpython-311.pyc | Bin 15957 -> 15957 bytes .../tenacity/__pycache__/stop.cpython-311.pyc | Bin 6310 -> 6310 bytes .../__pycache__/tornadoweb.cpython-311.pyc | Bin 2927 -> 2927 bytes .../tenacity/__pycache__/wait.cpython-311.pyc | Bin 13316 -> 13316 bytes .../__pycache__/__init__.cpython-311.pyc | Bin 426 -> 426 bytes .../tomli/__pycache__/_parser.cpython-311.pyc | Bin 30865 -> 30865 bytes .../tomli/__pycache__/_re.cpython-311.pyc | Bin 4505 -> 4505 bytes .../tomli/__pycache__/_types.cpython-311.pyc | Bin 418 -> 418 bytes .../pip/_vendor/truststore/__init__.py | 2 +- .../__pycache__/__init__.cpython-311.pyc | Bin 679 -> 679 bytes .../__pycache__/_api.cpython-311.pyc | Bin 16741 -> 17700 bytes .../__pycache__/_macos.cpython-311.pyc | Bin 17421 -> 17335 bytes .../__pycache__/_openssl.cpython-311.pyc | Bin 2360 -> 2360 bytes .../_ssl_constants.cpython-311.pyc | Bin 1135 -> 1135 bytes .../__pycache__/_windows.cpython-311.pyc | Bin 17263 -> 17529 bytes .../pip/_vendor/truststore/_api.py | 41 +- .../pip/_vendor/truststore/_macos.py | 14 +- .../pip/_vendor/truststore/_windows.py | 30 +- .../pip/_vendor/typing_extensions.py | 1130 +-- .../__pycache__/__init__.cpython-311.pyc | Bin 3724 -> 3724 bytes .../__pycache__/_collections.cpython-311.pyc | Bin 18312 -> 18902 bytes .../__pycache__/_version.cpython-311.pyc | Bin 234 -> 234 bytes .../__pycache__/connection.cpython-311.pyc | Bin 22080 -> 22080 bytes .../connectionpool.cpython-311.pyc | Bin 38292 -> 38492 bytes .../__pycache__/exceptions.cpython-311.pyc | Bin 16138 -> 16138 bytes .../__pycache__/fields.cpython-311.pyc | Bin 11431 -> 11431 bytes .../__pycache__/filepost.cpython-311.pyc | Bin 4512 -> 4512 bytes .../__pycache__/poolmanager.cpython-311.pyc | Bin 21630 -> 21834 bytes .../__pycache__/request.cpython-311.pyc | Bin 7683 -> 7683 bytes .../__pycache__/response.cpython-311.pyc | Bin 36558 -> 36558 bytes .../pip/_vendor/urllib3/_collections.py | 18 + .../pip/_vendor/urllib3/_version.py | 2 +- .../pip/_vendor/urllib3/connectionpool.py | 5 + .../__pycache__/__init__.cpython-311.pyc | Bin 220 -> 220 bytes .../_appengine_environ.cpython-311.pyc | Bin 1959 -> 1959 bytes .../__pycache__/appengine.cpython-311.pyc | Bin 12166 -> 12166 bytes .../__pycache__/ntlmpool.cpython-311.pyc | Bin 6243 -> 6243 bytes .../__pycache__/pyopenssl.cpython-311.pyc | Bin 25752 -> 25752 bytes .../securetransport.cpython-311.pyc | Bin 36858 -> 36855 bytes .../contrib/__pycache__/socks.cpython-311.pyc | Bin 8104 -> 8104 bytes .../__pycache__/__init__.cpython-311.pyc | Bin 237 -> 237 bytes .../__pycache__/bindings.cpython-311.pyc | Bin 16984 -> 16984 bytes .../__pycache__/low_level.cpython-311.pyc | Bin 15621 -> 15621 bytes .../urllib3/contrib/securetransport.py | 3 +- .../__pycache__/__init__.cpython-311.pyc | Bin 221 -> 221 bytes .../packages/__pycache__/six.cpython-311.pyc | Bin 46463 -> 46463 bytes .../__pycache__/__init__.cpython-311.pyc | Bin 231 -> 231 bytes .../__pycache__/makefile.cpython-311.pyc | Bin 1978 -> 1978 bytes .../weakref_finalize.cpython-311.pyc | Bin 8006 -> 8006 bytes .../pip/_vendor/urllib3/poolmanager.py | 7 +- .../util/__pycache__/__init__.cpython-311.pyc | Bin 1423 -> 1423 bytes .../__pycache__/connection.cpython-311.pyc | Bin 5150 -> 5150 bytes .../util/__pycache__/proxy.cpython-311.pyc | Bin 1732 -> 1732 bytes .../util/__pycache__/queue.cpython-311.pyc | Bin 1515 -> 1515 bytes .../util/__pycache__/request.cpython-311.pyc | Bin 4635 -> 4635 bytes .../util/__pycache__/response.cpython-311.pyc | Bin 3504 -> 3504 bytes .../util/__pycache__/retry.cpython-311.pyc | Bin 22784 -> 22784 bytes .../util/__pycache__/ssl_.cpython-311.pyc | Bin 16835 -> 16835 bytes .../ssl_match_hostname.cpython-311.pyc | Bin 5814 -> 5814 bytes .../__pycache__/ssltransport.cpython-311.pyc | Bin 11643 -> 11643 bytes .../util/__pycache__/timeout.cpython-311.pyc | Bin 11357 -> 11357 bytes .../util/__pycache__/url.cpython-311.pyc | Bin 17598 -> 17598 bytes .../util/__pycache__/wait.cpython-311.pyc | Bin 5017 -> 5017 bytes .../Lib/site-packages/pip/_vendor/vendor.txt | 35 +- .../pip/_vendor/webencodings/__init__.py | 342 - .../__pycache__/__init__.cpython-311.pyc | Bin 12897 -> 0 bytes .../__pycache__/labels.cpython-311.pyc | Bin 7297 -> 0 bytes .../__pycache__/mklabels.cpython-311.pyc | Bin 3225 -> 0 bytes .../__pycache__/tests.cpython-311.pyc | Bin 11203 -> 0 bytes .../x_user_defined.cpython-311.pyc | Bin 3577 -> 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 - myenv/Scripts/pip.exe | Bin 108433 -> 108433 bytes myenv/Scripts/pip3.11.exe | Bin 108433 -> 108433 bytes myenv/Scripts/pip3.exe | Bin 108433 -> 108433 bytes 784 files changed, 7261 insertions(+), 62004 deletions(-) create mode 100644 .gitignore delete mode 100644 myenv/Lib/site-packages/pip-24.0.dist-info/AUTHORS.txt delete mode 100644 myenv/Lib/site-packages/pip-24.0.dist-info/INSTALLER delete mode 100644 myenv/Lib/site-packages/pip-24.0.dist-info/LICENSE.txt delete mode 100644 myenv/Lib/site-packages/pip-24.0.dist-info/METADATA delete mode 100644 myenv/Lib/site-packages/pip-24.0.dist-info/RECORD delete mode 100644 myenv/Lib/site-packages/pip-24.0.dist-info/REQUESTED delete mode 100644 myenv/Lib/site-packages/pip-24.0.dist-info/WHEEL delete mode 100644 myenv/Lib/site-packages/pip-24.0.dist-info/entry_points.txt delete mode 100644 myenv/Lib/site-packages/pip-24.0.dist-info/top_level.txt delete mode 100644 myenv/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_internal/utils/models.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__init__.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachinedict.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/johabfreq.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/johabprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/macromanprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/resultdict.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf1632prober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/big5freq.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/big5prober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/chardistribution.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/charsetprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/codingstatemachinedict.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/cp949prober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/enums.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/escprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/escsm.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/euckrprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/euctwprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/jisfreq.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/johabfreq.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/johabprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/jpcntx.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/latin1prober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/macromanprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/mbcssm.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/metadata/__init__.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/languages.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/py.typed delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/resultdict.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/sjisprober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/universaldetector.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/utf1632prober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/utf8prober.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/chardet/version.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/__init__.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/ansi.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/initialise.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/__init__.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/__init__.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/ansi_test.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/ansitowin32_test.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/initialise_test.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/isatty_test.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/utils.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/winterm_test.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/ansi_test.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/ansitowin32_test.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/initialise_test.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/isatty_test.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/utils.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/tests/winterm_test.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/win32.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/colorama/winterm.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/packaging/__about__.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__init__.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/__init__.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/actions.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/common.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/core.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/exceptions.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/helpers.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/results.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/testing.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/unicode.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/util.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/actions.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/common.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/core.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__init__.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__pycache__/__init__.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/exceptions.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/helpers.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/py.typed delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/results.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/testing.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/unicode.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/pyparsing/util.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/six.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/webencodings/__init__.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-311.pyc delete mode 100644 myenv/Lib/site-packages/pip/_vendor/webencodings/labels.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/webencodings/mklabels.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/webencodings/tests.py delete mode 100644 myenv/Lib/site-packages/pip/_vendor/webencodings/x_user_defined.py diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..286e480 --- /dev/null +++ b/.gitignore @@ -0,0 +1,9 @@ +# Virtual environment +myenv/ + +# Python specific +*.pyc +__pycache__/ + +# Other +.DS_Store diff --git a/myenv/Lib/site-packages/pip-24.0.dist-info/AUTHORS.txt b/myenv/Lib/site-packages/pip-24.0.dist-info/AUTHORS.txt deleted file mode 100644 index 0e63548..0000000 --- a/myenv/Lib/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/myenv/Lib/site-packages/pip-24.0.dist-info/INSTALLER b/myenv/Lib/site-packages/pip-24.0.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/myenv/Lib/site-packages/pip-24.0.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/myenv/Lib/site-packages/pip-24.0.dist-info/LICENSE.txt b/myenv/Lib/site-packages/pip-24.0.dist-info/LICENSE.txt deleted file mode 100644 index 8e7b65e..0000000 --- a/myenv/Lib/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/myenv/Lib/site-packages/pip-24.0.dist-info/METADATA b/myenv/Lib/site-packages/pip-24.0.dist-info/METADATA deleted file mode 100644 index e5b45bd..0000000 --- a/myenv/Lib/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/myenv/Lib/site-packages/pip-24.0.dist-info/RECORD b/myenv/Lib/site-packages/pip-24.0.dist-info/RECORD deleted file mode 100644 index 61dd37b..0000000 --- a/myenv/Lib/site-packages/pip-24.0.dist-info/RECORD +++ /dev/null @@ -1,1024 +0,0 @@ -../../Scripts/pip.exe,sha256=aof0o97Ur0LVrEYeL2A9HhSS5pnW1wLWZ51SdEBOrUA,108433 -../../Scripts/pip3.11.exe,sha256=aof0o97Ur0LVrEYeL2A9HhSS5pnW1wLWZ51SdEBOrUA,108433 -../../Scripts/pip3.exe,sha256=aof0o97Ur0LVrEYeL2A9HhSS5pnW1wLWZ51SdEBOrUA,108433 -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=ynZN1_707_L23Oa8_O5LOxEoccj1nDa4xHT5galfN7o,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-311.pyc,, -pip/__pycache__/__main__.cpython-311.pyc,, -pip/__pycache__/__pip-runner__.cpython-311.pyc,, -pip/_internal/__init__.py,sha256=iqZ5-YQsQV08tkUc7L806Reop6tguLFWf70ySF6be0Y,515 -pip/_internal/__pycache__/__init__.cpython-311.pyc,, -pip/_internal/__pycache__/build_env.cpython-311.pyc,, -pip/_internal/__pycache__/cache.cpython-311.pyc,, -pip/_internal/__pycache__/configuration.cpython-311.pyc,, -pip/_internal/__pycache__/exceptions.cpython-311.pyc,, -pip/_internal/__pycache__/main.cpython-311.pyc,, -pip/_internal/__pycache__/pyproject.cpython-311.pyc,, -pip/_internal/__pycache__/self_outdated_check.cpython-311.pyc,, -pip/_internal/__pycache__/wheel_builder.cpython-311.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-311.pyc,, -pip/_internal/cli/__pycache__/autocompletion.cpython-311.pyc,, -pip/_internal/cli/__pycache__/base_command.cpython-311.pyc,, -pip/_internal/cli/__pycache__/cmdoptions.cpython-311.pyc,, -pip/_internal/cli/__pycache__/command_context.cpython-311.pyc,, -pip/_internal/cli/__pycache__/main.cpython-311.pyc,, -pip/_internal/cli/__pycache__/main_parser.cpython-311.pyc,, -pip/_internal/cli/__pycache__/parser.cpython-311.pyc,, -pip/_internal/cli/__pycache__/progress_bars.cpython-311.pyc,, -pip/_internal/cli/__pycache__/req_command.cpython-311.pyc,, -pip/_internal/cli/__pycache__/spinners.cpython-311.pyc,, -pip/_internal/cli/__pycache__/status_codes.cpython-311.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=1EIm8yMixQMELO4QzogdIoWkvIlQqlAW0YnPeOmnvEA,30064 -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-311.pyc,, -pip/_internal/commands/__pycache__/cache.cpython-311.pyc,, -pip/_internal/commands/__pycache__/check.cpython-311.pyc,, -pip/_internal/commands/__pycache__/completion.cpython-311.pyc,, -pip/_internal/commands/__pycache__/configuration.cpython-311.pyc,, -pip/_internal/commands/__pycache__/debug.cpython-311.pyc,, -pip/_internal/commands/__pycache__/download.cpython-311.pyc,, -pip/_internal/commands/__pycache__/freeze.cpython-311.pyc,, -pip/_internal/commands/__pycache__/hash.cpython-311.pyc,, -pip/_internal/commands/__pycache__/help.cpython-311.pyc,, -pip/_internal/commands/__pycache__/index.cpython-311.pyc,, -pip/_internal/commands/__pycache__/inspect.cpython-311.pyc,, -pip/_internal/commands/__pycache__/install.cpython-311.pyc,, -pip/_internal/commands/__pycache__/list.cpython-311.pyc,, -pip/_internal/commands/__pycache__/search.cpython-311.pyc,, -pip/_internal/commands/__pycache__/show.cpython-311.pyc,, -pip/_internal/commands/__pycache__/uninstall.cpython-311.pyc,, -pip/_internal/commands/__pycache__/wheel.cpython-311.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=2qjQrH9KWi5Roav0CuR7vc7hWm4uOi_0l6tp3ESKDHM,3172 -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=7wRUUmdyyOknl-WZYbO_LtFQxHlWod3pjOY9yYH435o,12450 -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-311.pyc,, -pip/_internal/distributions/__pycache__/base.cpython-311.pyc,, -pip/_internal/distributions/__pycache__/installed.cpython-311.pyc,, -pip/_internal/distributions/__pycache__/sdist.cpython-311.pyc,, -pip/_internal/distributions/__pycache__/wheel.cpython-311.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-311.pyc,, -pip/_internal/index/__pycache__/collector.cpython-311.pyc,, -pip/_internal/index/__pycache__/package_finder.cpython-311.pyc,, -pip/_internal/index/__pycache__/sources.cpython-311.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-311.pyc,, -pip/_internal/locations/__pycache__/_distutils.cpython-311.pyc,, -pip/_internal/locations/__pycache__/_sysconfig.cpython-311.pyc,, -pip/_internal/locations/__pycache__/base.cpython-311.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-311.pyc,, -pip/_internal/metadata/__pycache__/_json.cpython-311.pyc,, -pip/_internal/metadata/__pycache__/base.cpython-311.pyc,, -pip/_internal/metadata/__pycache__/pkg_resources.cpython-311.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-311.pyc,, -pip/_internal/metadata/importlib/__pycache__/_compat.cpython-311.pyc,, -pip/_internal/metadata/importlib/__pycache__/_dists.cpython-311.pyc,, -pip/_internal/metadata/importlib/__pycache__/_envs.cpython-311.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-311.pyc,, -pip/_internal/models/__pycache__/candidate.cpython-311.pyc,, -pip/_internal/models/__pycache__/direct_url.cpython-311.pyc,, -pip/_internal/models/__pycache__/format_control.cpython-311.pyc,, -pip/_internal/models/__pycache__/index.cpython-311.pyc,, -pip/_internal/models/__pycache__/installation_report.cpython-311.pyc,, -pip/_internal/models/__pycache__/link.cpython-311.pyc,, -pip/_internal/models/__pycache__/scheme.cpython-311.pyc,, -pip/_internal/models/__pycache__/search_scope.cpython-311.pyc,, -pip/_internal/models/__pycache__/selection_prefs.cpython-311.pyc,, -pip/_internal/models/__pycache__/target_python.cpython-311.pyc,, -pip/_internal/models/__pycache__/wheel.cpython-311.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-311.pyc,, -pip/_internal/network/__pycache__/auth.cpython-311.pyc,, -pip/_internal/network/__pycache__/cache.cpython-311.pyc,, -pip/_internal/network/__pycache__/download.cpython-311.pyc,, -pip/_internal/network/__pycache__/lazy_wheel.cpython-311.pyc,, -pip/_internal/network/__pycache__/session.cpython-311.pyc,, -pip/_internal/network/__pycache__/utils.cpython-311.pyc,, -pip/_internal/network/__pycache__/xmlrpc.cpython-311.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-311.pyc,, -pip/_internal/operations/__pycache__/check.cpython-311.pyc,, -pip/_internal/operations/__pycache__/freeze.cpython-311.pyc,, -pip/_internal/operations/__pycache__/prepare.cpython-311.pyc,, -pip/_internal/operations/build/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/operations/build/__pycache__/__init__.cpython-311.pyc,, -pip/_internal/operations/build/__pycache__/build_tracker.cpython-311.pyc,, -pip/_internal/operations/build/__pycache__/metadata.cpython-311.pyc,, -pip/_internal/operations/build/__pycache__/metadata_editable.cpython-311.pyc,, -pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-311.pyc,, -pip/_internal/operations/build/__pycache__/wheel.cpython-311.pyc,, -pip/_internal/operations/build/__pycache__/wheel_editable.cpython-311.pyc,, -pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-311.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-311.pyc,, -pip/_internal/operations/install/__pycache__/editable_legacy.cpython-311.pyc,, -pip/_internal/operations/install/__pycache__/wheel.cpython-311.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-311.pyc,, -pip/_internal/req/__pycache__/constructors.cpython-311.pyc,, -pip/_internal/req/__pycache__/req_file.cpython-311.pyc,, -pip/_internal/req/__pycache__/req_install.cpython-311.pyc,, -pip/_internal/req/__pycache__/req_set.cpython-311.pyc,, -pip/_internal/req/__pycache__/req_uninstall.cpython-311.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-311.pyc,, -pip/_internal/resolution/__pycache__/base.cpython-311.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-311.pyc,, -pip/_internal/resolution/legacy/__pycache__/resolver.cpython-311.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-311.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/base.cpython-311.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-311.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-311.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-311.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-311.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-311.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-311.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-311.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-311.pyc,, -pip/_internal/utils/__pycache__/_jaraco_text.cpython-311.pyc,, -pip/_internal/utils/__pycache__/_log.cpython-311.pyc,, -pip/_internal/utils/__pycache__/appdirs.cpython-311.pyc,, -pip/_internal/utils/__pycache__/compat.cpython-311.pyc,, -pip/_internal/utils/__pycache__/compatibility_tags.cpython-311.pyc,, -pip/_internal/utils/__pycache__/datetime.cpython-311.pyc,, -pip/_internal/utils/__pycache__/deprecation.cpython-311.pyc,, -pip/_internal/utils/__pycache__/direct_url_helpers.cpython-311.pyc,, -pip/_internal/utils/__pycache__/egg_link.cpython-311.pyc,, -pip/_internal/utils/__pycache__/encoding.cpython-311.pyc,, -pip/_internal/utils/__pycache__/entrypoints.cpython-311.pyc,, -pip/_internal/utils/__pycache__/filesystem.cpython-311.pyc,, -pip/_internal/utils/__pycache__/filetypes.cpython-311.pyc,, -pip/_internal/utils/__pycache__/glibc.cpython-311.pyc,, -pip/_internal/utils/__pycache__/hashes.cpython-311.pyc,, -pip/_internal/utils/__pycache__/logging.cpython-311.pyc,, -pip/_internal/utils/__pycache__/misc.cpython-311.pyc,, -pip/_internal/utils/__pycache__/models.cpython-311.pyc,, -pip/_internal/utils/__pycache__/packaging.cpython-311.pyc,, -pip/_internal/utils/__pycache__/setuptools_build.cpython-311.pyc,, -pip/_internal/utils/__pycache__/subprocess.cpython-311.pyc,, -pip/_internal/utils/__pycache__/temp_dir.cpython-311.pyc,, -pip/_internal/utils/__pycache__/unpacking.cpython-311.pyc,, -pip/_internal/utils/__pycache__/urls.cpython-311.pyc,, -pip/_internal/utils/__pycache__/virtualenv.cpython-311.pyc,, -pip/_internal/utils/__pycache__/wheel.cpython-311.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-311.pyc,, -pip/_internal/vcs/__pycache__/bazaar.cpython-311.pyc,, -pip/_internal/vcs/__pycache__/git.cpython-311.pyc,, -pip/_internal/vcs/__pycache__/mercurial.cpython-311.pyc,, -pip/_internal/vcs/__pycache__/subversion.cpython-311.pyc,, -pip/_internal/vcs/__pycache__/versioncontrol.cpython-311.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-311.pyc,, -pip/_vendor/__pycache__/six.cpython-311.pyc,, -pip/_vendor/__pycache__/typing_extensions.cpython-311.pyc,, -pip/_vendor/cachecontrol/__init__.py,sha256=ctHagMhQXuvQDdm4TirZrwDOT5H8oBNAJqzdKI6sovk,676 -pip/_vendor/cachecontrol/__pycache__/__init__.cpython-311.pyc,, -pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-311.pyc,, -pip/_vendor/cachecontrol/__pycache__/adapter.cpython-311.pyc,, -pip/_vendor/cachecontrol/__pycache__/cache.cpython-311.pyc,, -pip/_vendor/cachecontrol/__pycache__/controller.cpython-311.pyc,, -pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-311.pyc,, -pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-311.pyc,, -pip/_vendor/cachecontrol/__pycache__/serialize.cpython-311.pyc,, -pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-311.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-311.pyc,, -pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-311.pyc,, -pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-311.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/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -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-311.pyc,, -pip/_vendor/certifi/__pycache__/__main__.cpython-311.pyc,, -pip/_vendor/certifi/__pycache__/core.cpython-311.pyc,, -pip/_vendor/certifi/cacert.pem,sha256=eU0Dn_3yd8BH4m8sfVj4Glhl2KDrcCSg-sEWT-pNJ88,281617 -pip/_vendor/certifi/core.py,sha256=ZwiOsv-sD_ouU1ft8wy_xZ3LQ7UbcVzyqj2XNyrsZis,4279 -pip/_vendor/certifi/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/chardet/__init__.py,sha256=57R-HSxj0PWmILMN0GFmUNqEMfrEVSamXyjD-W6_fbs,4797 -pip/_vendor/chardet/__pycache__/__init__.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/big5freq.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/big5prober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/chardistribution.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/charsetprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/codingstatemachinedict.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/cp949prober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/enums.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/escprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/escsm.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/eucjpprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/euckrfreq.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/euckrprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/euctwfreq.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/euctwprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/gb2312freq.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/gb2312prober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/hebrewprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/jisfreq.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/johabfreq.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/johabprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/jpcntx.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/langthaimodel.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/latin1prober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/macromanprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/mbcssm.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/resultdict.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/sjisprober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/universaldetector.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/utf1632prober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/utf8prober.cpython-311.pyc,, -pip/_vendor/chardet/__pycache__/version.cpython-311.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-311.pyc,, -pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-311.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-311.pyc,, -pip/_vendor/chardet/metadata/__pycache__/languages.cpython-311.pyc,, -pip/_vendor/chardet/metadata/languages.py,sha256=FhvBIdZFxRQ-dTwkb_0madRKgVBCaUMQz9I5xqjE5iQ,13560 -pip/_vendor/chardet/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -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-311.pyc,, -pip/_vendor/colorama/__pycache__/ansi.cpython-311.pyc,, -pip/_vendor/colorama/__pycache__/ansitowin32.cpython-311.pyc,, -pip/_vendor/colorama/__pycache__/initialise.cpython-311.pyc,, -pip/_vendor/colorama/__pycache__/win32.cpython-311.pyc,, -pip/_vendor/colorama/__pycache__/winterm.cpython-311.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-311.pyc,, -pip/_vendor/colorama/tests/__pycache__/ansi_test.cpython-311.pyc,, -pip/_vendor/colorama/tests/__pycache__/ansitowin32_test.cpython-311.pyc,, -pip/_vendor/colorama/tests/__pycache__/initialise_test.cpython-311.pyc,, -pip/_vendor/colorama/tests/__pycache__/isatty_test.cpython-311.pyc,, -pip/_vendor/colorama/tests/__pycache__/utils.cpython-311.pyc,, -pip/_vendor/colorama/tests/__pycache__/winterm_test.cpython-311.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-311.pyc,, -pip/_vendor/distlib/__pycache__/compat.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/database.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/index.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/locators.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/manifest.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/markers.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/metadata.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/resources.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/scripts.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/util.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/version.cpython-311.pyc,, -pip/_vendor/distlib/__pycache__/wheel.cpython-311.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/t32.exe,sha256=a0GV5kCoWsMutvliiCKmIgV98eRZ33wXoS-XrqvJQVs,97792 -pip/_vendor/distlib/t64-arm.exe,sha256=68TAa32V504xVBnufojh0PcenpR3U4wAqTqf-MZqbPw,182784 -pip/_vendor/distlib/t64.exe,sha256=gaYY8hy4fbkHYTTnA4i26ct8IQZzkBG2pRdy0iyuBrc,108032 -pip/_vendor/distlib/util.py,sha256=XSznxEi_i3T20UJuaVc0qXHz5ksGUCW1khYlBprN_QE,67530 -pip/_vendor/distlib/version.py,sha256=9pXkduchve_aN7JG6iL9VTYV_kqNSGoc2Dwl8JuySnQ,23747 -pip/_vendor/distlib/w32.exe,sha256=R4csx3-OGM9kL4aPIzQKRo5TfmRSHZo6QWyLhDhNBks,91648 -pip/_vendor/distlib/w64-arm.exe,sha256=xdyYhKj0WDcVUOCb05blQYvzdYIKMbmJn2SZvzkcey4,168448 -pip/_vendor/distlib/w64.exe,sha256=ejGf-rojoBfXseGLpya6bFTFPWRG21X5KvU8J5iU-K0,101888 -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-311.pyc,, -pip/_vendor/distro/__pycache__/__main__.cpython-311.pyc,, -pip/_vendor/distro/__pycache__/distro.cpython-311.pyc,, -pip/_vendor/distro/distro.py,sha256=UZO1LjIhtFCMdlbiz39gj3raV-Amf3SBwzGzfApiMHw,49330 -pip/_vendor/distro/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/idna/__init__.py,sha256=KJQN1eQBr8iIK5SKrJ47lXvxG0BJ7Lm38W4zT0v_8lk,849 -pip/_vendor/idna/__pycache__/__init__.cpython-311.pyc,, -pip/_vendor/idna/__pycache__/codec.cpython-311.pyc,, -pip/_vendor/idna/__pycache__/compat.cpython-311.pyc,, -pip/_vendor/idna/__pycache__/core.cpython-311.pyc,, -pip/_vendor/idna/__pycache__/idnadata.cpython-311.pyc,, -pip/_vendor/idna/__pycache__/intranges.cpython-311.pyc,, -pip/_vendor/idna/__pycache__/package_data.cpython-311.pyc,, -pip/_vendor/idna/__pycache__/uts46data.cpython-311.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=1JxchwKzkxBSn7R_oCE12oBu3eVux0VzdxolmIad24M,12950 -pip/_vendor/idna/idnadata.py,sha256=xUjqKqiJV8Ho_XzBpAtv5JFoVPSupK-SUXvtjygUHqw,44375 -pip/_vendor/idna/intranges.py,sha256=YBr4fRYuWH7kTKS2tXlFjM24ZF1Pdvcir-aywniInqg,1881 -pip/_vendor/idna/package_data.py,sha256=C_jHJzmX8PI4xq0jpzmcTMxpb5lDsq4o5VyxQzlVrZE,21 -pip/_vendor/idna/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -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-311.pyc,, -pip/_vendor/msgpack/__pycache__/exceptions.cpython-311.pyc,, -pip/_vendor/msgpack/__pycache__/ext.cpython-311.pyc,, -pip/_vendor/msgpack/__pycache__/fallback.cpython-311.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-311.pyc,, -pip/_vendor/packaging/__pycache__/__init__.cpython-311.pyc,, -pip/_vendor/packaging/__pycache__/_manylinux.cpython-311.pyc,, -pip/_vendor/packaging/__pycache__/_musllinux.cpython-311.pyc,, -pip/_vendor/packaging/__pycache__/_structures.cpython-311.pyc,, -pip/_vendor/packaging/__pycache__/markers.cpython-311.pyc,, -pip/_vendor/packaging/__pycache__/requirements.cpython-311.pyc,, -pip/_vendor/packaging/__pycache__/specifiers.cpython-311.pyc,, -pip/_vendor/packaging/__pycache__/tags.cpython-311.pyc,, -pip/_vendor/packaging/__pycache__/utils.cpython-311.pyc,, -pip/_vendor/packaging/__pycache__/version.cpython-311.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/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -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-311.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-311.pyc,, -pip/_vendor/platformdirs/__pycache__/__main__.cpython-311.pyc,, -pip/_vendor/platformdirs/__pycache__/android.cpython-311.pyc,, -pip/_vendor/platformdirs/__pycache__/api.cpython-311.pyc,, -pip/_vendor/platformdirs/__pycache__/macos.cpython-311.pyc,, -pip/_vendor/platformdirs/__pycache__/unix.cpython-311.pyc,, -pip/_vendor/platformdirs/__pycache__/version.cpython-311.pyc,, -pip/_vendor/platformdirs/__pycache__/windows.cpython-311.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/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -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-311.pyc,, -pip/_vendor/pygments/__pycache__/__main__.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/cmdline.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/console.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/filter.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/formatter.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/lexer.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/modeline.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/plugin.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/regexopt.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/scanner.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/sphinxext.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/style.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/token.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/unistring.cpython-311.pyc,, -pip/_vendor/pygments/__pycache__/util.cpython-311.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-311.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-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/_mapping.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/bbcode.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/groff.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/html.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/img.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/irc.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/latex.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/other.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/pangomarkup.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/rtf.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/svg.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/terminal.cpython-311.pyc,, -pip/_vendor/pygments/formatters/__pycache__/terminal256.cpython-311.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-311.pyc,, -pip/_vendor/pygments/lexers/__pycache__/_mapping.cpython-311.pyc,, -pip/_vendor/pygments/lexers/__pycache__/python.cpython-311.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-311.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-311.pyc,, -pip/_vendor/pyparsing/__pycache__/actions.cpython-311.pyc,, -pip/_vendor/pyparsing/__pycache__/common.cpython-311.pyc,, -pip/_vendor/pyparsing/__pycache__/core.cpython-311.pyc,, -pip/_vendor/pyparsing/__pycache__/exceptions.cpython-311.pyc,, -pip/_vendor/pyparsing/__pycache__/helpers.cpython-311.pyc,, -pip/_vendor/pyparsing/__pycache__/results.cpython-311.pyc,, -pip/_vendor/pyparsing/__pycache__/testing.cpython-311.pyc,, -pip/_vendor/pyparsing/__pycache__/unicode.cpython-311.pyc,, -pip/_vendor/pyparsing/__pycache__/util.cpython-311.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-311.pyc,, -pip/_vendor/pyparsing/exceptions.py,sha256=6Jc6W1eDZBzyFu1J0YrcdNFVBC-RINujZmveSnB8Rxw,9523 -pip/_vendor/pyparsing/helpers.py,sha256=BZJHCA8SS0pYio30KGQTc9w2qMOaK4YpZ7hcvHbnTgk,38646 -pip/_vendor/pyparsing/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -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-311.pyc,, -pip/_vendor/pyproject_hooks/__pycache__/_compat.cpython-311.pyc,, -pip/_vendor/pyproject_hooks/__pycache__/_impl.cpython-311.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-311.pyc,, -pip/_vendor/pyproject_hooks/_in_process/__pycache__/_in_process.cpython-311.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-311.pyc,, -pip/_vendor/requests/__pycache__/__version__.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/_internal_utils.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/adapters.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/api.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/auth.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/certs.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/compat.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/cookies.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/exceptions.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/help.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/hooks.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/models.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/packages.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/sessions.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/status_codes.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/structures.cpython-311.pyc,, -pip/_vendor/requests/__pycache__/utils.cpython-311.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=kOPn0qYD6xRTzaxbqTdYiSInBZHl6379AJsyIgzYGLY,33460 -pip/_vendor/resolvelib/__init__.py,sha256=h509TdEcpb5-44JonaU3ex2TM15GVBLjM9CNCPwnTTs,537 -pip/_vendor/resolvelib/__pycache__/__init__.cpython-311.pyc,, -pip/_vendor/resolvelib/__pycache__/providers.cpython-311.pyc,, -pip/_vendor/resolvelib/__pycache__/reporters.cpython-311.pyc,, -pip/_vendor/resolvelib/__pycache__/resolvers.cpython-311.pyc,, -pip/_vendor/resolvelib/__pycache__/structs.cpython-311.pyc,, -pip/_vendor/resolvelib/compat/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-311.pyc,, -pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-311.pyc,, -pip/_vendor/resolvelib/compat/collections_abc.py,sha256=uy8xUZ-NDEw916tugUXm8HgwCGiMO0f-RcdnpkfXfOs,156 -pip/_vendor/resolvelib/providers.py,sha256=fuuvVrCetu5gsxPB43ERyjfO8aReS3rFQHpDgiItbs4,5871 -pip/_vendor/resolvelib/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -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-311.pyc,, -pip/_vendor/rich/__pycache__/__main__.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_cell_widths.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_emoji_codes.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_emoji_replace.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_export_format.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_extension.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_fileno.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_inspect.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_log_render.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_loop.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_null_file.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_palettes.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_pick.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_ratio.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_spinners.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_stack.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_timer.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_win32_console.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_windows.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_windows_renderer.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/_wrap.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/abc.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/align.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/ansi.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/bar.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/box.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/cells.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/color.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/color_triplet.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/columns.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/console.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/constrain.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/containers.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/control.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/default_styles.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/diagnose.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/emoji.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/errors.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/file_proxy.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/filesize.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/highlighter.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/json.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/jupyter.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/layout.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/live.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/live_render.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/logging.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/markup.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/measure.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/padding.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/pager.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/palette.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/panel.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/pretty.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/progress.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/progress_bar.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/prompt.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/protocol.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/region.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/repr.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/rule.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/scope.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/screen.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/segment.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/spinner.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/status.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/style.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/styled.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/syntax.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/table.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/terminal_theme.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/text.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/theme.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/themes.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/traceback.cpython-311.pyc,, -pip/_vendor/rich/__pycache__/tree.cpython-311.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/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -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-311.pyc,, -pip/_vendor/tenacity/__pycache__/_asyncio.cpython-311.pyc,, -pip/_vendor/tenacity/__pycache__/_utils.cpython-311.pyc,, -pip/_vendor/tenacity/__pycache__/after.cpython-311.pyc,, -pip/_vendor/tenacity/__pycache__/before.cpython-311.pyc,, -pip/_vendor/tenacity/__pycache__/before_sleep.cpython-311.pyc,, -pip/_vendor/tenacity/__pycache__/nap.cpython-311.pyc,, -pip/_vendor/tenacity/__pycache__/retry.cpython-311.pyc,, -pip/_vendor/tenacity/__pycache__/stop.cpython-311.pyc,, -pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-311.pyc,, -pip/_vendor/tenacity/__pycache__/wait.cpython-311.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/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -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-311.pyc,, -pip/_vendor/tomli/__pycache__/_parser.cpython-311.pyc,, -pip/_vendor/tomli/__pycache__/_re.cpython-311.pyc,, -pip/_vendor/tomli/__pycache__/_types.cpython-311.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/tomli/py.typed,sha256=8PjyZ1aVoQpRVvt71muvuq5qE-jTFZkK-GLHkhdebmc,26 -pip/_vendor/truststore/__init__.py,sha256=qzTLSH8PvAkY1fr6QQ2vV-KwE_M83wdXugtpJaP_AbM,403 -pip/_vendor/truststore/__pycache__/__init__.cpython-311.pyc,, -pip/_vendor/truststore/__pycache__/_api.cpython-311.pyc,, -pip/_vendor/truststore/__pycache__/_macos.cpython-311.pyc,, -pip/_vendor/truststore/__pycache__/_openssl.cpython-311.pyc,, -pip/_vendor/truststore/__pycache__/_ssl_constants.cpython-311.pyc,, -pip/_vendor/truststore/__pycache__/_windows.cpython-311.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/truststore/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/typing_extensions.py,sha256=EWpcpyQnVmc48E9fSyPGs-vXgHcAk9tQABQIxmMsCGk,111130 -pip/_vendor/urllib3/__init__.py,sha256=iXLcYiJySn0GNbWOOZDDApgBL1JgP44EZ8i1760S8Mc,3333 -pip/_vendor/urllib3/__pycache__/__init__.cpython-311.pyc,, -pip/_vendor/urllib3/__pycache__/_collections.cpython-311.pyc,, -pip/_vendor/urllib3/__pycache__/_version.cpython-311.pyc,, -pip/_vendor/urllib3/__pycache__/connection.cpython-311.pyc,, -pip/_vendor/urllib3/__pycache__/connectionpool.cpython-311.pyc,, -pip/_vendor/urllib3/__pycache__/exceptions.cpython-311.pyc,, -pip/_vendor/urllib3/__pycache__/fields.cpython-311.pyc,, -pip/_vendor/urllib3/__pycache__/filepost.cpython-311.pyc,, -pip/_vendor/urllib3/__pycache__/poolmanager.cpython-311.pyc,, -pip/_vendor/urllib3/__pycache__/request.cpython-311.pyc,, -pip/_vendor/urllib3/__pycache__/response.cpython-311.pyc,, -pip/_vendor/urllib3/_collections.py,sha256=Rp1mVyBgc_UlAcp6M3at1skJBXR5J43NawRTvW2g_XY,10811 -pip/_vendor/urllib3/_version.py,sha256=azoM7M7BUADl2kBhMVR6PPf2GhBDI90me1fcnzTwdcw,64 -pip/_vendor/urllib3/connection.py,sha256=92k9td_y4PEiTIjNufCUa1NzMB3J3w0LEdyokYgXnW8,20300 -pip/_vendor/urllib3/connectionpool.py,sha256=ItVDasDnPRPP9R8bNxY7tPBlC724nJ9nlxVgXG_SLbI,39990 -pip/_vendor/urllib3/contrib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-311.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-311.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-311.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-311.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-311.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-311.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-311.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-311.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-311.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-311.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-311.pyc,, -pip/_vendor/urllib3/packages/__pycache__/six.cpython-311.pyc,, -pip/_vendor/urllib3/packages/backports/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-311.pyc,, -pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-311.pyc,, -pip/_vendor/urllib3/packages/backports/__pycache__/weakref_finalize.cpython-311.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=0i8cJgrqupza67IBPZ_u9jXvnSxr5UBlVEiUqdkPtYI,19752 -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-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/connection.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/proxy.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/queue.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/request.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/response.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/retry.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssl_match_hostname.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/timeout.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/url.cpython-311.pyc,, -pip/_vendor/urllib3/util/__pycache__/wait.cpython-311.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=Z6WEf518eTOXP5jr5QSQ9gqJI0DVYt3Xs3EKnYaTmus,22013 -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-311.pyc,, -pip/_vendor/webencodings/__pycache__/labels.cpython-311.pyc,, -pip/_vendor/webencodings/__pycache__/mklabels.cpython-311.pyc,, -pip/_vendor/webencodings/__pycache__/tests.cpython-311.pyc,, -pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-311.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/myenv/Lib/site-packages/pip-24.0.dist-info/REQUESTED b/myenv/Lib/site-packages/pip-24.0.dist-info/REQUESTED deleted file mode 100644 index e69de29..0000000 diff --git a/myenv/Lib/site-packages/pip-24.0.dist-info/WHEEL b/myenv/Lib/site-packages/pip-24.0.dist-info/WHEEL deleted file mode 100644 index 98c0d20..0000000 --- a/myenv/Lib/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/myenv/Lib/site-packages/pip-24.0.dist-info/entry_points.txt b/myenv/Lib/site-packages/pip-24.0.dist-info/entry_points.txt deleted file mode 100644 index 5367846..0000000 --- a/myenv/Lib/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.10 = pip._internal.cli.main:main diff --git a/myenv/Lib/site-packages/pip-24.0.dist-info/top_level.txt b/myenv/Lib/site-packages/pip-24.0.dist-info/top_level.txt deleted file mode 100644 index a1b589e..0000000 --- a/myenv/Lib/site-packages/pip-24.0.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/myenv/Lib/site-packages/pip/__init__.py b/myenv/Lib/site-packages/pip/__init__.py index be0e3ed..60c2d0e 100644 --- a/myenv/Lib/site-packages/pip/__init__.py +++ b/myenv/Lib/site-packages/pip/__init__.py @@ -1,6 +1,6 @@ from typing import List, Optional -__version__ = "24.0" +__version__ = "24.1.2" def main(args: Optional[List[str]] = None) -> int: diff --git a/myenv/Lib/site-packages/pip/__pip-runner__.py b/myenv/Lib/site-packages/pip/__pip-runner__.py index 49a148a..c633787 100644 --- a/myenv/Lib/site-packages/pip/__pip-runner__.py +++ b/myenv/Lib/site-packages/pip/__pip-runner__.py @@ -8,8 +8,8 @@ import sys -# Copied from setup.py -PYTHON_REQUIRES = (3, 7) +# Copied from pyproject.toml +PYTHON_REQUIRES = (3, 8) def version_str(version): # type: ignore diff --git a/myenv/Lib/site-packages/pip/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/__pycache__/__init__.cpython-311.pyc index 2a46dfc67a3881b803dfa735de68ac236ccc751f..054e09d607d8bd4721aa449cee906dfebcbf47fc 100644 GIT binary patch delta 39 tcmeBYo5;qyoR^o20SH`9_NApx%hb)Hu)TrBLKXQ3Gn~` delta 37 rcmbQp*3ZVfoR^o20SKHA^`#|G`PmPuU)k++eFk$rPNlNUPxe-a2R diff --git a/myenv/Lib/site-packages/pip/_internal/__init__.py b/myenv/Lib/site-packages/pip/_internal/__init__.py index 96c6b88..1a5b7f8 100644 --- a/myenv/Lib/site-packages/pip/_internal/__init__.py +++ b/myenv/Lib/site-packages/pip/_internal/__init__.py @@ -7,7 +7,7 @@ _log.init_logging() -def main(args: (Optional[List[str]]) = None) -> int: +def main(args: Optional[List[str]] = None) -> int: """This is preserved for old console scripts that may still be referencing it. diff --git a/myenv/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-311.pyc index fa20494b0ebe0883dfe557f2e3aed12f0fdc0230..799ed4099827f1196cdfb1c3d84b4b2f1672df2e 100644 GIT binary patch delta 45 zcmZo>Z)WFR&dbZi00b^4`_dRU@;WjLbyUn?nGrmP^9sMx2L=vCsTIkS6PT3&333c; delta 45 zcmZo>Z)WFR&dbZi00hp5`qG#;@;WjLP2iXzG9!787?z!il`!-kBR~>IT99057$JZ~!*#WB0Fy9-L=_#H5;ZBom#DW_o6O zm>}D^h`ic#Z>Ddyj|m1rW{dq~Nsl~mlL^8*_?Dj8L8(q2lIrnw$u1dbUqvL)NFIVT zYhHCIe^j^jp>@+f>zFQS zM#%v=cGHNS@hy8kBpIfKa7$4%9A#F^cTYSyac24iJZiim9zYG=0)I08(A2G zYw;sBl{CN=n;ZUWy3Imx#oW$1plI%H453UDmE?k)krkRD5D4&g*fzJaPN)+fXF-UI z{r+K;@HT=VK|4WL1%hx(JSOUbuHv@%4P!C*m$jX>L#?gRJb`Mx5Vgh8)wbv>zG)K; zedH=^KBplucx0&8o_od|XQLa$YWCUWQ!b?0b-N(PBP!dDyAqKV0{W_1{J-K0uC}I8_R7 zf)71UwfB-UQNEzcSxFaj3T|iBd>SUalih>Fj1Z6?%`lhePa&b05pX*KkCyU147a_0 zHdEa2HktYYC@UvWv&h-y6whTfaW$W=bj z&91|1fqC3X))p{2&!KcmGh;$|f`_3$7_2@?28{&g;9PKs&A`>*5mArmCAb@$K{s8U zj@O#O3sp_C@D3>VX)gB<5azs2wx}Z zHG($?$VT5bMMR1=ifR=}%}uu8?+&p)!eiYR`t)h-`BXm6m$KQ!`LwLtB~7SI5A_`z zzI6V+T!SyVFR?~=HXISNF%^Bo`>lR>F61<+wKzzG!;_Z1?F!qS^|{Y_4L#uo+x}eW7I$hIV4YJ6nDvZ^87s@P=Wp@rbbEQ0df`pMqKPmGlaZg8fz#eA;t@HA7qP8I!Shc^PuO z|8aXXqw<`hRmm6Rle?X6YhcAeJwTmp|Wr}pH3w4*uZCf$yG0k!%lvK zw00^>Zv#|Wnkm8O75-}?Epyl$6RN`Bqfxb9|8Xkf3z{jN%KktzE#wrHze}!eAt+7+ zy&fMzsfAoe{_|ZEOR2O3@AtQfe<$Tn;eP+)LGxX^{}a1^L;wHG;rg?q^PZ#gt|Rn` zBlK?Uo?~dkF;t8WaKqT|TRkU@#&x6Vq{Xsc#Sq^%aJ|Wf-TWYW;J9T^@Ypc>^={rqPHYY3WMQ4?w^nUU3noK$Mn6#D)fXo`3Q-ziQF zx3k4VX6I(3Z_9|kpVzi-nelf^6g;i3DnH3=S!iSx>bzSvqU=IV{g#6$r%>hGsv%0K zz_w8k>o1+%GE^A4sC4(ye95bI4e;RLKg(AugN@PFmHrzMH!{Cn{ z@TRgUH6Cw6{+AY%T@*I0_LogO2xmrv%>m?;7PyYoZsP)69_?rfq8a}KDN#G&yW8c5 zqrv_FF=_TnL*Au;T!nfKRYR!|Uc`9X-63?TQ0gxVm=Bwy5=&zMdH)*=T#iM8{d>dE zE4P`{uMw0QBm5;c&H~^&)DqS^@lJV{ z|9~bb)e=!wf@*@_63`mCUS1y&wNqnjG^FJ0`h58v4GH{|g)fk}So(vm!}p`XiZpz< zH0iI1p?@zNCh8Qy&k0fxJMsY=gKv)Hur*v6b34e z<x)rw6@nHD6oDGdXD~EkD9P vM-^O=puANa8y{!2{Tsrbe^@&D^}s13!*c)sxUKWQ+AW=h>yM0>C@22~D)5Z1 delta 2934 zcmZuzYit|G5xzZ=M^b!9q9nfbA}LxD^`tCIwrtvt?Z%es+D;=kNY%J3%{xg{DU#Wv z6h)yT|8V+3Tg06NNt!hFFX!bTDOjKZ@~bh>I&D)F{bgK%piT?71zK1^0<CuL+GD&&^U-Ow6RvWaW+K8`DYtryPR8vXR(vq_>eBcSJD{9k4 z>&%EOosiV#i;~)MRYo3sH+goWKiaB(v>HVjS+|+6KY;yvgm)0VLp!|3geHudR&DI6 z1)1^PWFA-LX-Q7BRekb71~ZoLDXpmCZSZ%?W40KIoshFW%G%-g)?cx1c*PcDG5Dpe z*WZmgL(#MI+M=ctUnCOYQE(`oEDpWODb@wc%5cYSVv7)T5kv`g)u0QmD~DY|L48>X zZdseFQTs=Xjf2%0Ya?@`VNNTj`BI^fIiJ_krCf<0!R`S#>P#!-yXp3>Q;~-v*iKmZ zA^hVaLPw#<7qb~%OUQ;iloXvhC00ax$8~_6f`0c%fQS+{!#){h6@C)!Qt+<(Vb)b`_B_W}d-a+(W9{rDf2%pQ?a{3Z#asd7ISvC&Z7d2? zO)2&ee4{BH6648+Lg8idhP}9~@qFfSK2`m1)9)<4&m$clCeAPqk{p7M0$+*^plB%C zN?9wYLM`Iio-Th7z8pL;m?Vz`0r42}Y>A&mLAN2`GDYq)*MZh%H3YZDLu|VG=U~`6 zBxYfz&#-HSShuIk)>2DB@~mOLiB3{PeL|ARNsvBvX|lQ$Q-U< zFdDIV&!P6TVZ*HQ4DW^G@wjV}9Q*|5U@5+vO~b44{fda_DfmnLEYcj@m13_~S9g7t zd1);TWj0q(HO|9uyF1R#fUD;n&lyzUOuj-yeem0!))Csdwa|V@-7gZnL_o%3(R2kR zS|+hY+j{R~zlL+YE2Cl zw>U9LwSP`JH@~Ko8_{F)sjvkn?C)!5br6lU*c=t*ii@OxQ?0wVtgNDk>Vi_AKU}7o zvH4W&C0TXPGjlLFV)w(J`T|Yfntshuaqy!R+ZA&FPsO2np|`&?RIf@;$=g*8Lkq1r zYj&&wmitF~8h1_s!>z9|3y->*$DprLHz)73|85vP8t(CM)jTXs6&Kv@kHF+WYh&|H zPe=_+z?%cX7ROGF@c&}01?~*^EdFv2JY663<=C3LOh<6@Q3EhE7;5dWwI!)yQ-c-j zi_(weil^ef7J~DG_p>m(I(P>DJ@}tyzhTiI*Nr-DMawRgsr2z~@C*+RW{|?LzmY1=AwfpE&F0aA^$*6LR zjNgLClBcR0$p!hqFM0x#F3Sy}c%lMbgqi;o}5!VRPF2`~`x`2!>n76y>suT6w;xnw6QN+IbtDqCSELs;)gT zwlHq<-t>nyEcpM2hRzKe{%5A7lB61Z zY>^b-#YZ;eT8B`X_aKdzz0}wO*T(*86VrzJz0nwzH4)!yOq4I3&NN=D)GexYJ47d1 z;KQK9*MX`}?5MaP-E_FWW#wJaxGx^rV&FGWceno&*k0`*|K2nfW-PSnbQDSW`@~Mg zg;xm7Vu@1L3XOX^MX41r)oSv+Ryvg*T6{A~T9;K3WgCvNk}IdvaU4XawYeZ+!knI3 ztp3lA6;AH!i{q!&-GPZ+8%Bz|>m|IfFLi=A63l2iT`W&6mh$*9f-_U^=e)=hHuDPD z-tsRI18w=On{YGg%g{D4#D?MIL}*=P;%7u#zhfiv_sHMegd{l#Tm;t%C=s0I&p#m8 z-kg`I86gndQIdXMgI3DU->`MT{J|e5Zubj2GD++;2mLXbi|>kkBux>#NiYwe?!V6V z!#f9xFqMk104$_p%H}7-4^q8fqpTTDEEiuW&duTdG)i7?5r~5mBT0Oa9U+N6Z^U6R z1B_5}E9ieYQj0}(DX$&kAEE*Sm-J_=;e#m#^N0SKoU}09{hy5=i~djV);`QCh$ZKW+093jL?EnA( delta 22 ccmX?HaJYbXIWI340}wbL>Pu_d$ZKW+091Yk<^TWy diff --git a/myenv/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-311.pyc index 655d153aaea4bfe6e7c7aa3ef9c29dd235e80763..575cc102f202a18fed1f6f5888a7387f39c902c3 100644 GIT binary patch delta 21 bcmcaKi}BJdMy}<&yj%=G;Bs;!mxnI^OD6^m delta 21 bcmcaKi}BJdMy}<&yj%=G;CyH!mxnI^O8y1~ diff --git a/myenv/Lib/site-packages/pip/_internal/__pycache__/exceptions.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/__pycache__/exceptions.cpython-311.pyc index 3eb3a644ad728bf7e4d976c6bbdf882c2c8788ab..8315b8f6c8c20aa644e575f071162e6f36096171 100644 GIT binary patch delta 6662 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 diff --git a/myenv/Lib/site-packages/pip/_internal/__pycache__/main.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/__pycache__/main.cpython-311.pyc index 5cd7d9a38883b6a83e171dd6b031bc9595c2a3a1..16ee27c3406ac9df1b57fff901b25ce3e5e3c91b 100644 GIT binary patch delta 19 ZcmZo*YhdGA&dbZi00b^4H*$Sr0sttV1fl={ delta 19 ZcmZo*YhdGA&dbZi00hp5HgbJq0sts>1eyQ< diff --git a/myenv/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-311.pyc index 13f046f6afaf516068775726b92cfa64edef06c9..3469ad815b8fdef5f3814a4ce5c734c45be77704 100644 GIT binary patch delta 19 ZcmeyR{Y#r`IWI340}!~J+{pDo6aYTB1?>O; delta 19 ZcmeyR{Y#r`IWI340}wbL+Q{`m6aYSt1?2z$ diff --git a/myenv/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-311.pyc index b2a2b39c93d0d965b30728a2bce6779ec6a1e1e1..51199e92f5988c2485aa9d838ae37d030e5cb9af 100644 GIT binary patch delta 675 zcmZvZJ#P~+7{~pDG;LlkFQnHbP0}>EUUNy>gOorErBp~vAj-zzB2}SwN`l=)N2u7k zAhGbGVpv#M5DZ8NaT2P!G9Z{37*Ga20RtZapCJeYk8JDb=l_5F*z%n#U)Qx4nifJb z&V9JwdbX$C-Aw=@h>Wl}Ka7)#18kh@SXVsCCU^>`6pyhq&)|&WAe-b_oK+lRIiAOP z#bGwZ3%H;-!lro<7Zq!)#0_jHj5Tig%1D&NFZ)2EHE-LBgDWbU|>bUXA}fdANhPgKmX_dJU-pGt-DvW7n&9TGR}T{ z*xP%g-M@VV0u1mJjj=e2EB4U@(~++DAf0AOlvI3(rq~RcQS7H_mO&ZC0h(nwlv5m} zc~(FL#UVP&im0eqqjRi;N{Yj@%qpm&II>Ku%s>XKp_)oW={&2WI$J;stbrOTcbGQW zB3gvN0|@9J73X34!jfcff7$&MH^{N)5P+BR`4i|kj*}KnkXFx&^*dg40#B0Rn;k}<)pTT^Q43eWU7C9Vv{{1q?MW+LC=S0W#u|9k`+8B z@Ap^1B~rj;qFn>7LtOHtmsbDr1#m_B+WSqwPw1zMRbik7Gr@9LR%m`x5N&A=_pqzrH)-rkn1#Tfq6LUxd)_oJsCM7Q zIS+~VhSApChWf}FHMgyS>^U&yUn91OP21#QS4{6OHaq5+yshm(_*z)=Pei1CE4ua> Q{I{HY^{)_C#ZKeKZ#}E5SO5S3 diff --git a/myenv/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-311.pyc index b72be2c9abd22ed961aeed353e8e1aca6aedeaa5..97173445e50483f2e4a2dd24fe21409d30de8cf2 100644 GIT binary patch delta 74 zcmcamwziCSIWI340}!~J>`N2h$ZN&UxMZ>i`xI988ip+P&A-_N7#SNT^Kh2%>p$QZ ey27t_fkW>BH-Cr8ljFIxH{atdG6VoRvKHh3 delta 78 zcmZ2mcA<=SIWI340}wbL>PwT{$ZN&UxNout`xI7@8iobzlPAiHOg=BqxA`SI2P0$W i 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 + # just reuse 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: diff --git a/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-311.pyc index bdac3a173e3a4076c11e662a4b56f797df6fa7d8..16353c2acc4b3e7cc01e6308dd6d08635768cd10 100644 GIT binary patch delta 19 ZcmZ3_w4RA;IWI340}!~J+{mTM2mmb*1SS9g delta 19 ZcmZ3_w4RA;IWI340}wbL+Q_BK2mmbS1RekY diff --git a/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-311.pyc index bc79cce94e2b2ea10ef4907dfe8deb96243610d6..ff2640ac8c45c0166c568eda151f6a7626aa5167 100644 GIT binary patch delta 1133 zcmah{TWAwO6rH<|JiFa&wvE}ESCh68tJPY3U~4LEeHN`+Q4oTPsWxj(>n1*k(I4@n z#Rqsr`ytYgqM-Ffe#8%zDne0^&=!frxNK^3ozAEPxkE%^4g0s%-Sf-A*fliT#9|8Unq;tPj7gC4!YjAdq0APUXtB~ih2MqS^Z!(FtG6-j?Id_JewKr97kRMb^0kfYqm z*{S)NCXCr?rC)E7xt%Kq&3r-<+DNc;Klg1*|GXIt*b_?8(cZOg!}j*AU7I>Sut$ez zzX=MqJ6^-0eArn5upSqey@zfLNl#%jew04L7JOTN7k1)B`62AZ9j*c##s$g}HB{vK z(?x4f>R{67PZjw+J(>Jrr5<2)e$?#-$1bYR45x4712r)Bi-nYxpImw-HWVA4Q*cJ7 zoY7ANMESZgmc4oG>ajb0g?XJ*^Eyjp{-v4{0^?z4TLT$yC~I5BkGB9t!$$>;ZU#H^ zJ>DlgoWe$5w`DD3I&sJssh+sJ#jq$(H|ErNlIty z@U5cau80bwcqq~fz4#{5C=bw3(b|_xXA()n*o2{)Du`oqO>=lZjil`qO8OL*Pw%mc zQU-%_`QaKJoF#uPjBG=x4x3nS44pwMgOa6EO)Xo77%;D2Z7uuy69@WwV#aZttQ+&{ P0IpBu58Q?qqDQ_1!g%ii delta 1079 zcmbVKO=uHA6rQ))Y<{;%nxsi=Hlb~5n?^&U7A&o`v9)5MCXEN7v{)srX054gf=G>8 z1P>{qvF{*w3Q~VSK{N-!gHS7i)q@`Nkb@{*s(7e+@gg{rvTa2K@v-yq=G$-HeDh|W z56;HLTcT(rG^n74t8R+PY8;TE|noaQYcR%Ua21SEXR`~RzUuht2E9MU$>8fUfs;6M7y z*5Na)f9tARu2#MGl99HVntY9HSD9?Hnh_#9(Je?~jml7+3wH@2k!Ky8qIbbsjbHt4 zoE18xh^ix%9_P&Rx*hSeAW`qjdM^faZNTG@ZYMp(HC+>UXa$efma`Q%&>lH8AlKrk z!6UY>)srRk=_OFREDip}ue#!xhGj~1j-#G`^RFtVXfj1_{0w)oCEc2h;A4HGxc&t& zubVBBswX7rDf%jR*llQct)7f_Y2C}ffG;5B400C3?|rya!fXFusE= zrRydKKtDb-FF_28;!B9*@v85Tz(bZtFoIs|0vy5j*4L252e$21{xUb2DeK14CsWE~ zy7bc)0@zau+N+`AFx|#NN9G()$PX6NWLY5k+8gzAEw6N&=vOK@(!6iJ-V_a!`LH>< zLo?qA6csOBrz9ARmb{)98pz|4cfYWgG5r{o8ibXfC`+}*0md>oRk|!u_rs+*--s5D zA{Pij5yOF_)biCpq-Bz7%DRbECYwwt${?Ewsmyq4Vyvu9WhfUkDBD=EVf+^8fD;&Q zbQ${?!JtrzHOgSBc<5wg6rXNHCp)H+V$j8)Vx|u#nj|=nGfj8h;{euW@&_hxU-Ri- DV`<## diff --git a/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-311.pyc index 2965952ee5f52ed5a66cb47fc570274eb8422f11..604339ad343652e32302fc32c128de4fcc93a848 100644 GIT binary patch delta 1970 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 diff --git a/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-311.pyc index 61b6ac84c8851c844a001b53003948a3c86ba9f0..b4b5f053c37b7f82f5af302419c10fd1fe2a64bc 100644 GIT binary patch delta 1605 zcmZ|Pe@v8R8~|{>cgHKj9kCHQDdLFZ$H6J`Lr~<$CB|$6#1z3q?cxsZxZ^!~j~{_F zkF|k9!`7EMrP;uOf}x3zQLQ#sY$S6|WfAPen*EVmG2B|qNku*1=SXX_+wHUO`#j(G zd7t-rzR!EVQ{_Fb(tV)Q1qblo&gq_NWlU$(1l0sscb@}mDa+GzN3S=keJZ!?Q@g9H zeQL$htk`*SYY~1EyEV|H=MAVeya`S`V>kh?Vr<+6aN$gxhqn~QFNMfFSt%o&EI&a5 z5l)I-#6e;|A!9{iwB)7Gi?1iHNFqtbcH@~45sFk9a} z4kfqpju=xobmA710Zy`)OaRcqDmTV}LCj$vWp)yKi3B2!cw2x2n?|4mi&9#`M7nsQ z{~nx8iGkC2KV_IF3~aVX_tG7Y8>){w`YU;r;=7-5JlWTb$>zbbUoqoo_BOPZ%o?NO?fK}^YPgFzh4OoH<` zm-&fwo)QMJH_OZio6X9G%NVxx$7p{u^+gaL5o5$f;u1z|ON4Qjw@nL@ctjH`&F)@} zop@(^G#>|Y)=47$B8$oif0&q=yAM)7<--^?{=qY8$UtJ8_>AKLj^4ik;<01+d0qow zhRykt(8GSspHV>z`+5gof@$`B!6GD2)2;EuAd$u~u2G(%cz`eyk;E1J?fG1|#xe@E zD*tARA``FSWTm?%)Nmccijv?a+g|hvz$|;WI20lux1n=1-W*PqczJo{SYlc2?gDuB zDsL?`O3DW6og&1%nkW*Jo5$;=JK+{Sx#wFLWjqFxzhxCb7 zTeYRp)sU^Hb|c?B@pw^cF7}+ISS3x+%znY%s@8CNPoHGBc)n?!yh_0HyARN2wZukk8?Pf`wJSQ_d(&1klw>pD2 zYU2U!vJvM5Koi#1)gP;)$GVAnqLFxwXd}GDapDBW7wmD=)w^s*8Woq)MXe`^w+QhC zI8Bi_z~Wf;)8!B`LWtvXnWAw*RQ)kgxaoA=LWl~zMiCXKvW3VXZW6PEsHb^~ZV?N_ zZQ?uP4)FuAL@W~bhzG?Lp@M$87 zc!v1zmvA{Kr_OC{blLKh4BpHC0iIrV$h|i(RI9%s{`1#9ykVgenM7d{iu^4g9hAXXWLBoI4b*+CmGj#rN7Um&7ybkYCR`_uO;O zJ%4U@ujaRt8vPe~y)KOZ?Y+|PY@5*=wUPEJdv%k>Ud8rkPbWnMG+s|2-0O69mg8E= zE=){418%&S+6Qe|kT!+2>CfW*GzZsN)9*&f+>`PS!Of~Ov=HYexrK0uP)m@}m6;@U zk=TX(nGYplB;%lQC`yRJRK~)rhah8hM#7+}1kYrrNvCK_56)+I#)*T3H(^{uD<`ll zCl&fxOAY|^F!_~aNELRWRWdn1$RMN<1_W?6_agM*VN*wpFn`ix(3A}4FmlHPH<;bg zoP@OF1mP)HL!=wR;=C!Thr~~CJSzRuNUMoEdMWQ4KwW-dJ&)WD872T z1$68)dp1A>e&;wIYC!&$I4!`Rn1QChAQlIjz3>Zy%kn7O~xE$oy#9U#bN zS{4BO_`clM)k?>D2wsAZ&`vl;5D(Hxl6pA;I@Kk&wK^L7N~_XG+J3@E1o3Q~BS}oX znB`&m93xB+#Ej7}D59A~|96QNHk0xwLGx4UmyMztG?}R@H4+wvTVZalcq~lYmL=*Ict%O*@^Mp8z@g~N^lenGm5+M;w wyoow97x{mfI>_wa0}*=tb06>Qtz3ra8`h8IWI340}!~J+{oq30RS^+1fu`| delta 19 ZcmX>ra8`h8IWI340}wbL+Q{Y10RS^T1e*W= diff --git a/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-311.pyc index 387ac5c6011113f7ed5097075187997fad53fbd6..579fa25dd9bb29b14f418795b9a6004e3f18f2f5 100644 GIT binary patch delta 58 zcmZ21vQ&h3IWI340}!~J>`PPutT$m`6;sJA(g?L3p%FQDKDW=2NF4@``VEFTzv!~+K2 I$rhY%0f)T}^#A|> diff --git a/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-311.pyc index 8fb39ca7dc420c9822c3057efc24b54ccef88681..3b0676ecf1374eb8100231aba8cdbbd774f440f3 100644 GIT binary patch delta 19 ZcmZ3iy;z%TIWI340}!~J+{iUk6aX>K1n2+& delta 19 ZcmZ3iy;z%TIWI340}wbL+Q>Ci6aX=$1mFMw diff --git a/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-311.pyc index 43ac2a9c8420a3faa56d37915dd4bcfe74f88cf2..dd9f5cda5849b5acb208ddf609cb966094fb8662 100644 GIT binary patch delta 2626 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 Nulmy7KH|Zk{{cAPEfoL& diff --git a/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-311.pyc index 3dd480eb5d3c0474b6bd2b43b13a543cbf4fc657..740ada2c455b04bd5731ea18b8a62c0acb8a4a97 100644 GIT binary patch delta 1963 zcmZ`3OKclObY_2EdpB`YyNTm8sneta7h-5b2`VL3+61U*18M|^m8xL8>ta~P*6dnU zqm68#93m7UM+KcWl^LaK;nRerQG1cn|16ssrq*3&Ad17 zKW}Cy_TNbN*Iiv91Tg)}7uh?ZweHyKZ(@XQBNeGwM@n|dnLMkoc~0T-yu#-N zMaTz~KweZtOyyX8?b?ZQKB7c?lGCI4Bgzqf&Fj7SKBW&Mjn#N9)=xe9a2;zxC!J;X z_LP2A*e|UHw74p218Pv?w3v!joMrdqv!WVWhUktyr6y_tZD3FE8R~*6Epy5sn3eD1 zT~`P7`m=)CwJaz@DxO2hZaabhkfp0>Q@fnY=S+<}!pu+XXcThugi=w34Ug5eg``N1 z0FU%i)JM^X{Wt#upMquV(LLcuT+Tq*eW0@dV+6*|5K!+ROb-N`{&o|o%sz@$5d_99 zb4!fMFR>ObVwgFT-BVG8`(W$amKU_dGst2r*5d9nz@Gus1dJ>+jjml?5-ir_TU>;! z0|pkm5CT{HMu!u-!NguMK+)np^$n85J};e4_ziB)I8`izXW;{M8)LLOry{6tVAcy{ zN`z<&CZXjZF+iEN5g=%M5g0q41GN#AIb^B<*2>YQH4q;+F5Ro*W<1^UJtfGTKPlvYDq zVr)~4IsK`J&pkfloSLfjPu0W=b@75DUg!|0iSfD^cUu1r7(j%Ebe*mca?U4tkIlgu z&`Oi%0eL*p((27Joej-Q2Ab{dclN7PsGXZ96SxHPdh>da7h%%~07^8WnRCxmIg)cA zLx)iZ^cQ>;)Ce*Bz&*BsVEXfb2 zTDkm$J6xHqPOQ(=xZ`#1xWgTHd-@xQ=c7Ja;axHO)p)hEcJ|A&HF0ny;7Wa4(%_~v zSd)&`rDNbLIJ`0OjkY=R;kYw0?#l6%+4YHynVNjEE}wMdldc@wl7}|sp_-hi%LzwL zxZRNzsrfaemM1a+sXf5{dys*p547&IscEO}+_Ed;CE0?fb@w(6*lS|nOZ0Wv1q*-I zyua-hpF^hD+C}sd@%C@xXR~qOJz(}8AdiK%BD7iHaD&;>LdGl*O&)o0Xilap=ZiyqGJd=ApqfvXItO89kRWin)aajTj_io1tMG zwQq%zXUJ<*ryUrf0X#syLBEgw70=}hYDw27$rae5*V*{p{wLHchARH&+J~eOdq|S) zamk8|JLq)h@1hC&p;RirjUzbfcK23GtAz#&>xO`&NOgR5tP!A;h=lM;sj99|JK;o~ wA8rIG7wtzWGub=RP4ZbDN6pgeMeA-X%f8Q3YtN;K2 delta 604 zcmY*Tzl#$=6rQ)UJJ}?c%}RFn67}%VSS()fuk1!q0LkDtrzcVp`~9o0oUZsD=H?6i&3~m}nLfTnu8ytGg^Z z&0&j#OG?6zLt%WS?FN1*W8-b!O+`i%F$itxVNd!R0uATYCi`f0unZ1a=`)xi$UyyC zYQYm#t=)H1hNF`}bE@9eUftHO9~gy8XlCVjJb0Q8hsh`_ZFgnb>n2jWW@axHQeMV# zWFV}r$~E=eX;(IoT-V)>dh1+re%2d%)g$C2JR{eYS%0CX^%ZESPxbI#Mtg%ax08D9 zfXJ(u*5j;sd?Jl)T@D%N~ zd(;awxTM6 zx6u)MR2>z(o$j>9)G@(3Xx<)I$L(F}E_*_qAW}dw$;I7U;WH=iLfpOwfAvS*V@_P$ zyEOv-h_t#ng2AI(6N^FhF=Lw9}Nc-IR=OGkrG*o5ElHQ42=k ztfcf@t4&uNPq!Rb_LfZfjCpz4Vy106-gL#bb;pnwbk~$iRCnEcJbrG;a$yjLk!-pA z$AQ6Z-jeRgMn!fio~+Xq{i+*xOw-{14%{LkekZtpxOvtw%qz!PWx2Y!sY3kLv!?4> z6=zd&%DQ5${VS*veyO35@S|59QA%=d}s2H?$~jM_Y% zJw+bn&twm@-AB*-kZaPiAE{J5*xcp!vOfvlBSlUJwvVP@UTI*X@M1d=#t;+)8NkK7 zm1X(H4K~bQ9~dS3`5y;vlRkbu*Ly6CTByJx0DjPNJS8ZWF+4c2i;K~{AWyMjR7tE@ z-jY_LrtU0P8J^#6{`=e)$;g_%*q5=KUji7l9aID;4W89=0`Qn zax72N{AkHGH1Npv4cs@J=Gi)b+bNHU0;lOYgaRf>Ug691EuBO^REG8FS8ZvEue_KrLt zWNK~K&T&F!`Gv8e&SSXA41k}gvdSU@MQuT6>^OgQtZnrKPQ9VOq4w$ZHI{E@N4L?jPi;EDR$coM!%UNXYpvO)j z6cJ7%Jb~~T043=MOVnjYC8>Y&)ITzk9Y-y+ip?U-@k9B}%vqp*ddnK^S)EzB?z^eDFjT)qSDBo#(~)U8DM_e)-RcGmaeB$3VvQ@ zC-~*voqIJ@yMUl0EFc&FN|IqFu}%O#X+crNkf(w_oD$MtJyaj<0csC5>WlgP zeMiVRf21%1M(BkZlIE`!@{o}46n?aNPg2_b#u8M!$DomUF6+WCW)Lg@Kde`)rem;e zC_$6_$fD`#p2z%{X;>cSmCHJCA_1qf)c{@5B>W)g`a#{fD)Nb4N40p_atw`H&Lx-a zO`;@Rt}t8o{E%Ul054W72NFTF8c~+QI}s}k6T8U|9T@DnhATr@*lr_GDATP63hxUC z3gKUX)cy0?PY^CxZ^Gc0P!gk+k}g`R=yG5unE1P?0?F~r;U{3Rb@=;)9O0SiljH(7riZkz z!7?Snns9Zv#Gs5#)(iu78zsRiGubzBm<9m7hh13&2v^r@;}vAz0&pV$n*oB4|7H3p zq{R49CS&VT0!2}NO0+n0Zf1r(1+rohq(!BV|GGW5T5sOi|NI0LqGy$C(_5+-3>%~$ zgxsk&oJP?&H|Kg`j>Ku@{iu zLTEvF6~Iq!HtLcIok3FwdmN;q_ttL_CawvDqO^AX*w4vl&yj|n_fjn{PJYR%HQ)d; zpe0j_2pW}|`)V;k<5Ejctx?c~6i=% z@`+%-g+9v{PVDF3Ini+x-SnHQRy7Yj4Gz`OX}&})aUc2HKOxUUshC%^QvKfvhKbG+ zyl=KIjD^Ee{K)J8Y2xMCVW{dCW=BXfe*<_6e}8r$jA8e8@m@BJy_4UXlSvnUeQtnsb04sW51!1*;t2atcRTJCgKC}^7YO?{3eWSqC&wmt zAl-`~;=PJY1Y;Q3gXjThz01@*$bJSxycpe;0B@Y{Cod%sd_n}B2Metz3Vtn1~+-j3xqV!0dPT2yLi*$8#N8*1JN p4G8S6MM7PHb*ZD4;w`7MM?N1U@tXAMxZXMPftdR6e<%p2{{wPt0muLV delta 10006 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 delta 19 ZcmbQ@I>nW1IWI340}wbL+Q`+V1OPJZ1oQv^ diff --git a/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-311.pyc index 3c38782f1b9cd0dd7da46d97d0e883f6c14e98a6..9b19b4058518e3d9b6e10647e82641ee3d5e323a 100644 GIT binary patch delta 19 ZcmZo?ZfE9N&dbZi00b^4H*(c70stsN1TX*q delta 19 ZcmZo?ZfE9N&dbZi00hp5HgeT60str(1SkLi diff --git a/myenv/Lib/site-packages/pip/_internal/cli/autocompletion.py b/myenv/Lib/site-packages/pip/_internal/cli/autocompletion.py index e5950b9..f3f70ac 100644 --- a/myenv/Lib/site-packages/pip/_internal/cli/autocompletion.py +++ b/myenv/Lib/site-packages/pip/_internal/cli/autocompletion.py @@ -17,6 +17,10 @@ def autocomplete() -> None: # Don't complete if user hasn't sourced bash_completion file. if "PIP_AUTO_COMPLETE" not in os.environ: return + # Don't complete if autocompletion environment variables + # are not present + if not os.environ.get("COMP_WORDS") or not os.environ.get("COMP_CWORD"): + return cwords = os.environ["COMP_WORDS"].split()[1:] cword = int(os.environ["COMP_CWORD"]) try: diff --git a/myenv/Lib/site-packages/pip/_internal/cli/base_command.py b/myenv/Lib/site-packages/pip/_internal/cli/base_command.py index db9d5cc..09f8c75 100644 --- a/myenv/Lib/site-packages/pip/_internal/cli/base_command.py +++ b/myenv/Lib/site-packages/pip/_internal/cli/base_command.py @@ -28,7 +28,6 @@ InstallationError, NetworkConnectionError, PreviousBuildDirError, - UninstallationError, ) from pip._internal.utils.filesystem import check_path_owner from pip._internal.utils.logging import BrokenStdoutLoggingError, setup_logging @@ -192,7 +191,6 @@ def exc_logging_wrapper(*args: Any) -> int: return PREVIOUS_BUILD_DIR_ERROR except ( InstallationError, - UninstallationError, BadCommand, NetworkConnectionError, ) as exc: diff --git a/myenv/Lib/site-packages/pip/_internal/cli/cmdoptions.py b/myenv/Lib/site-packages/pip/_internal/cli/cmdoptions.py index d05e502..a47f8a3 100644 --- a/myenv/Lib/site-packages/pip/_internal/cli/cmdoptions.py +++ b/myenv/Lib/site-packages/pip/_internal/cli/cmdoptions.py @@ -226,9 +226,9 @@ class PipOption(Option): "--progress-bar", dest="progress_bar", type="choice", - choices=["on", "off"], + choices=["on", "off", "raw"], default="on", - help="Specify whether the progress bar should be used [on, off] (default: on)", + help="Specify whether the progress bar should be used [on, off, raw] (default: on)", ) log: Callable[..., Option] = partial( @@ -903,7 +903,7 @@ def _handle_config_settings( 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.", + help="Action if pip is run as a root user [warn, ignore] (default: warn)", ) diff --git a/myenv/Lib/site-packages/pip/_internal/cli/main.py b/myenv/Lib/site-packages/pip/_internal/cli/main.py index 7e061f5..563ac79 100644 --- a/myenv/Lib/site-packages/pip/_internal/cli/main.py +++ b/myenv/Lib/site-packages/pip/_internal/cli/main.py @@ -1,5 +1,6 @@ """Primary application entrypoint. """ + import locale import logging import os diff --git a/myenv/Lib/site-packages/pip/_internal/cli/parser.py b/myenv/Lib/site-packages/pip/_internal/cli/parser.py index ae554b2..b7d7c1f 100644 --- a/myenv/Lib/site-packages/pip/_internal/cli/parser.py +++ b/myenv/Lib/site-packages/pip/_internal/cli/parser.py @@ -6,7 +6,7 @@ import sys import textwrap from contextlib import suppress -from typing import Any, Dict, Generator, List, Tuple +from typing import Any, Dict, Generator, List, Optional, Tuple from pip._internal.cli.status_codes import UNKNOWN_ERROR from pip._internal.configuration import Configuration, ConfigurationError @@ -67,7 +67,7 @@ def format_usage(self, usage: str) -> str: msg = "\nUsage: {}\n".format(self.indent_lines(textwrap.dedent(usage), " ")) return msg - def format_description(self, description: str) -> str: + def format_description(self, description: Optional[str]) -> str: # leave full control over description to us if description: if hasattr(self.parser, "main"): @@ -85,7 +85,7 @@ def format_description(self, description: str) -> str: else: return "" - def format_epilog(self, epilog: str) -> str: + def format_epilog(self, epilog: Optional[str]) -> str: # leave full control over epilog to us if epilog: return epilog diff --git a/myenv/Lib/site-packages/pip/_internal/cli/progress_bars.py b/myenv/Lib/site-packages/pip/_internal/cli/progress_bars.py index 0ad1403..b842b1b 100644 --- a/myenv/Lib/site-packages/pip/_internal/cli/progress_bars.py +++ b/myenv/Lib/site-packages/pip/_internal/cli/progress_bars.py @@ -1,4 +1,5 @@ import functools +import sys from typing import Callable, Generator, Iterable, Iterator, Optional, Tuple from pip._vendor.rich.progress import ( @@ -14,6 +15,7 @@ TransferSpeedColumn, ) +from pip._internal.cli.spinners import RateLimiter from pip._internal.utils.logging import get_indentation DownloadProgressRenderer = Callable[[Iterable[bytes]], Iterator[bytes]] @@ -55,6 +57,28 @@ def _rich_progress_bar( progress.update(task_id, advance=len(chunk)) +def _raw_progress_bar( + iterable: Iterable[bytes], + *, + size: Optional[int], +) -> Generator[bytes, None, None]: + def write_progress(current: int, total: int) -> None: + sys.stdout.write("Progress %d of %d\n" % (current, total)) + sys.stdout.flush() + + current = 0 + total = size or 0 + rate_limiter = RateLimiter(0.25) + + write_progress(current, total) + for chunk in iterable: + current += len(chunk) + if rate_limiter.ready() or current == total: + write_progress(current, total) + rate_limiter.reset() + yield chunk + + def get_download_progress_renderer( *, bar_type: str, size: Optional[int] = None ) -> DownloadProgressRenderer: @@ -64,5 +88,7 @@ def get_download_progress_renderer( """ if bar_type == "on": return functools.partial(_rich_progress_bar, bar_type=bar_type, size=size) + elif bar_type == "raw": + return functools.partial(_raw_progress_bar, size=size) else: return iter # no-op, when passed an iterator diff --git a/myenv/Lib/site-packages/pip/_internal/cli/req_command.py b/myenv/Lib/site-packages/pip/_internal/cli/req_command.py index 6f2f79c..92900f9 100644 --- a/myenv/Lib/site-packages/pip/_internal/cli/req_command.py +++ b/myenv/Lib/site-packages/pip/_internal/cli/req_command.py @@ -1,21 +1,19 @@ -"""Contains the Command base classes that depend on PipSession. +"""Contains the RequirementCommand base class. -The classes in this module are in a separate module so the commands not -needing download / PackageFinder capability don't unnecessarily import the +This class is in a separate module so the commands that do not always +need 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 typing import 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.cli.index_command import IndexGroupCommand +from pip._internal.cli.index_command import SessionCommandMixin as SessionCommandMixin from pip._internal.exceptions import CommandError, PreviousBuildDirError from pip._internal.index.collector import LinkCollector from pip._internal.index.package_finder import PackageFinder @@ -33,161 +31,15 @@ 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, @@ -195,36 +47,6 @@ def handle_pip_version_check(self, options: Values) -> None: ] -def warn_if_run_as_root() -> None: - """Output a warning for sudo users on Unix. - - In a virtual environment, sudo pip still writes to virtualenv. - 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. @@ -438,9 +260,11 @@ def get_requirements( 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, + config_settings=( + parsed_req.options.get("config_settings") + if parsed_req.options + else None + ), ) requirements.append(req_to_add) diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-311.pyc index 502bfb17a7c5dc45aaf38e2ce086d7fd8015c952..c81d412cde805f01d519b9a9eb1e5d05fb9c9351 100644 GIT binary patch delta 19 Zcmeya^j(Q-IWI340}!~J+{l$H2mm|~1x^3} delta 19 Zcmeya^j(Q-IWI340}wbL+Q^kF2mm|h1x5e> diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-311.pyc index b3225dc5c26a5b8e685d11bac0b6fede6ca5ed07..42bfa0c2bfdc1bb4c6c91baf1ab698c9d95dcd37 100644 GIT binary patch delta 19 ZcmeAU?GEKy&dbZi00b^4H*z&<0RS`S1qlEE delta 19 ZcmeAU?GEKy&dbZi00hp5HgYv;0RS_;1pxp6 diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-311.pyc index c5e8e9487bae058ac998a0ea5f9341bb4f1e8f0f..32d8eca3fdd914634ec2657bf7906f5d6a14d279 100644 GIT binary patch delta 556 zcmew*G*O6mIWI340}!~J>`R+6kyny&)L!XIb{Li2((Q zB_>Z`72CXpHH=YO7RX=8P$UOZCj%mQV1&SARdz*3IacWzW*-=U)C!Rm$!jFR%nik0 z3MTP!1Jkyny&-b8hOzg*rZUPgu#h7|T3zFht&enti+hE#?u z0gy@%NEKYh$iT1~h#??Kh>5|SA%&xbA%!!QZ5cCA4v3+0!V?eJFfvd4Yo>ZjxjeBb zFFq$VJu$g5zAUwIH90da6DTyfoLb zdzV9dh4)1ciz^%!7dR|7N3w=9O3MM2uVg5a2N@#^B6wkh;N;V6ijMNE(lg9HFaW6) zA}f;DNP?Lgioq040%9D0y_o(3i^#j diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-311.pyc index b5601643f00f3b45068ffb00f4def9828fdff903..3720a04a71e260d61a6dbc15b3f8b3980939ddb2 100644 GIT binary patch delta 19 ZcmeCw>D1v`&dbZi00b^4H*)D1v`&dbZi00hp5Hgf$J1pqGV1rz`P diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-311.pyc index d7365c1bce8a49f014bc44cb066f6046d40a0092..c14e549b4c1c95a044e22c599beb9755fd81e0e9 100644 GIT binary patch delta 19 ZcmbPQGPQ(jIWI340}!~J+{ndk1pqja1oZ#_ delta 19 ZcmbPQGPQ(jIWI340}wbL+Q`Li1pqi`1nmF- diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/debug.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/debug.cpython-311.pyc index 570a676f1700afcbcf8b57cd96b42012d0e146b0..621467a431920d7f5d84420d1f33f3404ff38220 100644 GIT binary patch delta 1845 zcmZuwTWl0n7@jk;v%9nHcH6zQ-TN->7N(R%1QISywYBAv0Pzwr4kTr}b9P;v*c!pf#)CjvH}72dsphG?Ieuuu^u~NDI2t%Gg;WE9jt=v-3t?&|TI#d%zeFbjTXC z3r2xRvP8-8A?zAIy8Z^Vd=vio@f=a-yQyyWP|XaRq~bLr3m#+GTxUk%+-Qbrfa+AQ z$nj+dz=~|fKsRFcf?t?+Qs4h{9J^Wf1^#ha+AEp41= z-&q1UC;hG^-#+;9=#SctpR^tKB~=Z4KF-$#-U^36eK|X-eBl|Fd|xYMTxx$G=$G>u zkh`5HDRZEy=~}(g&Jj(h_{ z*^-U&yLpxOMgN?5co7VnWn$*XfPzBNf2B|$-Kg_Y;}m47n+>*-&|x#}@mNIJJO&o* zMS#>x=njNq{vB~vG^$DvkbWuQEpKj+1qtla)E zzo2Gt7_RSBiPdZMDodg!f`B^&JFs_sIhIHAJi;3Y7@QsCch~ogO(D4lz||(FCZ0bu zd0=Xi&7klELKgt^a{=ix!X<#!5w)Wmt`R>Lvm~=#en)?L>qWG}88RON-iWKz>MeF1 z*)s^Dcrn05WEc6a;kkkk3jSRX>f6{AI9#9As8+G9gJ_xIe+};=Q+)Tv338Oby7Alj zM6=c`!ux1ZRxeq_*;dVRie<4i;z_#6M;WXH#hrEgA7x?JoU)jrtHC}VfFdYk?_mvM z^{^|Pv>`DuTJZwJGsLIGjv=fLQ4C(RwzmDh{iDk-b&TBx4}96qm#~@l6+%cmuqi;g Ucm5!)`Mp_;wug!rhzG~@A2}eX)c^nh delta 1837 zcmY*YU5pb|6rMZNzv=d8`$zw_?G$!dX4wT5BMH&vXBXK70w$or0d3ly+ghCI;GOQm z5_Ne1jhKMss%VUeFB*bDV~ycacrZQ+Axb7O`sRxd#1J*c1kbr;7nro)`M>AfbIyIg z_H8Ztc{Cc9;G4R3y18&RnqRy@B*~X5Pbbs!cH1Vp$k|kJ8fiupOws@wZhIC zSz!oSIXiFU1+Q8KyJ!>zAGU_yZt zM3N<{@CYd_#;I-&(g8DJl4ih6p70rCX4OmqU27(2gz8jp%6V*!_?ohr2HUuqfw%;X zQS||v&s+hviDjGqkSzfFYCVK9I3erZmn$}wx~@z-Fmm}beP7u|5o`o@Hr=S z0hhi*ur&Seg3Pam(!3W;@-u+}q6q2Bz#gLZ?grw75S-4_WP zMPUtqD+6d6%kvc~8!dvM`#lv3aah-CH$0V5*O_Cp)b&*7FzwX3^k|oJbtE8a&u}f2 znP5*q93Jg{4RBogMNQsRhkjO9-%wXycS zc|33<|01~=qW?%%NrT5y*C6_OijZynNump0n2A9)Fp!AAr3yjgrNvO^X~%TfQYM#~ zy>up}WVc}S0f1v+ZB4h%TC}@KV+Z+UE=xxEbGf#*oXHD9nGMIK{cL+7NQas5Uvp+c zOh6Thy7iXJ+}^(YU0KILFdQqJKyQWVKs@DTy1+I8=i&-$V&tz59fIZfeW(?E{k|uA ziXSNHV!UiEKUF%Y<5qZqmgO|+)-icpgCk!MDn@N*o_fARPP?P~SeM7kBg2bea(w`h zV+#{C#%Ala#$3m=s2C_a$@iBpLFVhJG|yE&BAMPdm0?oA9rt{eQ#WmpaP- z)Q$(R3`ToLt0(+r?2i{bQfHlZr^O0rNh09(!1N2Fvx^$CClTI8z{A-d053>8^KIsI zJO%pBRMhW4m_egDy?xuWyQg<;pJpa1U4$3_T>3Qf6yY6!`+Wq#Q`lVR*x)p6%(bQ* z+pc$d|Bb#uLRj-fnPvDX{h1ACFciDbf(STEPic3$>^zD%0w(T=J!5YQ;L)*#%|a>U zPe7?Z?xmLB=ep(R$<|}Q2LN8sa#}6y3tpF%_@%KKvV-3l+eTjG8`u88web>3@X7J= zBKFKvp$)qrf--gi1H|rOas9q($ccRyuMJ-i!=-R diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/download.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/download.cpython-311.pyc index 17cb0d053207ba393f9c6f7af556d450b92b7fda..68be8a4a09145073d209fa092f4fa8c7cbe7f518 100644 GIT binary patch delta 263 zcmbPXx6_t)IWI340}!~J>`R-uk@trHqt|9O!Eel>JVnYS_8=JuNa0N3TA(o5QCM`c zpQr+()8>3pIYvgM&3$4ujFa^x)-if-z9*r~G+9`>moa7XLg`2+7e-d`8D<|CK=cZc z70GKPA?yvs5E_~M$jrbd)DrW738WYnIr-`7sYOMCKu%H4Px%6k@trHW6@?d!EemW+zaF-I@pOc!Nm|PiOmReMtnV(l2 zpO}{tUtExyoSBvh6q@`v!#=7|!@OhPv}#IJK$U*fR7$YFbh!}bD)?c^;|y^N`o zounh3Tp3x#XPA9p0MRQ%RwS>Hgs?XhLuh33BQpb=P)p1QCXiyd#OAxwg^a>!Kv&;l w%gIkqPc14E1agXUCnw5EFjh~llKt!C$ixWLfStS`rtuLh^#zB5B6FZ|0L%?|+AbM0#Q1POISZ}$-lhxf%Kkruc*3;GhjDOx>EE+~w zlVkhi>(iHR8d(&+IWV+%SK^IoAA}%T;M!Q%EmlTiF zZnhGyM4C?{+L<0`8wTmUi!|+le7+Cd=hJp-j(JscI*4)CFJtog5$ku*LCv;agE?U% zPd{9vbHud+o_|Yy-V5$-5?&L>P{L=U)-`k|fI_XZUTN!&$O3KxtOAHiuyx)Kd{B9X z8|g*m*6qkqgo@%r^b;BsZ;VxvXJZ40#v#9rcgUBgpW>t@*GWKK7k~xP_GPne058<= zBEV*VEfU;z38n9Ym&L8vBC51D#-IDp8j-g~P1VY>VsXMcjmqM&b#Q!4R=$$gW$m5j z8;mJ<)<1M3^u+9b=l|*X9sA9AMVv_N7}+5wkct_z?$lXMIH9EG65GdjNk88y!SzWf zm3SE(dn8=kB)%rcgqb{mDx#LWXhEvyKTr6tRPi=>K?bK&L)MTC+NS5Hq|Re7MMx~B z$_v|of(l+@dbaLN)hL}hRjWI*j?~aq`gwkrGukQPo z{8ycPQk_&nz6X6jN@(HEBM4>1qs-(nTTaR09C96CKdj)NtvC64FjD~VZFv#`fs>5} zRi}ch?FS$-3@`yu0Z=_mUZHPf&64()`=vI#^yl3&R#Z>`cKHob CgbL6A delta 1316 zcma)5OKclO7~b(?<41OFuf1N!4vF)ii5=H2P!vQ%6fF+zf1PmN*58)hAv z=F&t$LZ|`}&5=t^?V*PreC(~4UJ&Y`64gpbJ#gR{BrX&o@&98gT*QId-EY77Uo-pt zvyV>QUbAjkR?2{J_Rcq#ZX8%s#5q`MT@?wMAV$aN#CTGqXiB7MTF>KrQdrc|+~l^% z(2V92JS%cECmibNd4lIfffh7Ra#s{-QFzo7C0f$96rU1hTGl+xD`J{XYd*=J5;L?t zqbC-h6;)c*+~#v)p3ZBY;R|AsE)pYRFyoV_ar-#fvFpSzZo)GfbSYxIW^}S&7@Zu; zT#teep1*y|>ICsfT%9Mgr7(V>-}C#mNN8=a?q>VSMJ59<4144-M$*HSS&z?IkSHC5 zCV~x6GvzY!r`8zqTey|$A|FD+mX^fA{JiJ1)E!pOPNf-0x z5DMs>7_0UYS}{jf5zZi-1qdbps-q$6z(ZFZ+O9gVzb1|0Z04s3c~b<=tK6)gJ;Tzkfm5qX)|BYbeI^=i|Inpjy@2k{jw){u*hhQ-xgzBf{wCAnM}?b+@ns&ULrtJOj>JHjHxCms#L4t@hnz z^Hro(b<3T)hzf<#fDL30jV~aS&}LrprPv(ERkUOPYN;^^b(`>8!}w?0OkRioLmfm@P z1uNjOk|x4i0AaM(AILSFdI;DuSwu(dBj4w`*;0RB3_ZBKd=sI8ptn>;RvxZS!ST~p zG}LP9T=`@~Ce-Ef!b}oFQUGCYtGCts0M=x(zsZ|z-UAIurJ(MXGh|ZzSY9;s;kCiI zP)D7@(vvA{r_HtoaN>he3$)G-gy(ap)=snSbI#fWU&_3am1R;;-&N`+p5Jg@9adcR zuws)UCS2{a!DU~5+6-8L|B#m8-|KA;dOT=~UeF#jGTCK=4ZqukzI+HZ^iGL)IWI340}!~J>`N=%$ZO6oE?1CQpckK+SCU$kmzblMoRg`Slvtd)If_4l PQNZW|0}7gaN?Psux$ZO6oCR>nMpckK+SCU$kmzblMoRg_nlv=nsnm>V2 O!0-YC3YvUcU@-tJ%ol(F diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-311.pyc index c05311d2bdee56b654489dd666bc652724b7cdbf..d9d41889af293849180db68883be2c6b8ad38aae 100644 GIT binary patch delta 2118 zcmb_cYitx%6ux(-yKT1*cG*|A`{=aWeYaa^%cHdqH`r~E1WJn-N1$vw+p_IUx6DjI zU`8M@8sZCc5KW3&V^T2G#5f7@75(8K{Q)%5h!l;le~pPHK;)P4-d&fp#Gjt*J@-5J zeCOVC&porB+`;eN!POV5s?3PUW8b_o)_3@|>V=aS@rW-MTw)DZBf2?v-Zl%hqKET{ zUe24hD+HhD=lpqGDb$H9$L4XBP%k!c4S8HG1jI(JF^|^?K{3RI#4s1m+ZG`rM!9Gn zTZNby=i*`$*F@|l#IF~c#RQkgJ8eRXxPjY{$97?(*vhr$u|sGR+d0VK6mHcQ@HvbP zkYpVCB-4hm3En9gvD=QOrK#cU*swG+HJp}*rCd(=$QWzD-|6vis+8HIWZ^=h*E&h> zUl88S*UoK*U(F7{E$z0c;yOY@s2r*5=eFj3`&;auj-ro8Ge~o(E~$j~@kr>@YT#7M zCYygABXpUJf{>)^;Omxc+uX{@;u=D#Tdn4qaio?mu=7U3C!-+y3M>&SUhf~sv)ZKaBST+$F#eh74RVHOT{ox^sx*TrHtIJ-|_8@$oo zZ8OO^Ny+e1fKty;RSlIrfxi0b>~vx{JEdf#skD%gGs4(#ZbsqLggiWYC^I^_RJJ2? ztWT11l2lLQ`iWXH9Z3r_8Cjw=mn^Wm=PB%h%RK?S9@Z~W>u2moXnEhf{C@{G;$t&`SH(;IH1oDxUi{? z*2$`WwYwSPGX3^oj=@ey@8xih{`uZzBYs@JxX)$4mGI?(=876hrhhGx1O7TN@rcS8 zU2kq)L3F-kzcjkwF5nO4!n|7FW{_$9bNf~dl)R$q7lsEhw!)tW`?02PNe40Z!2Xf# z_$*u;Igek}dq$Uy75T;r(E}~emgVqy{gv#~CR_{4x#Rd-Ju`j80CyD&tVmW<6{S@} zsq8o9!z>V&edL7gvX?ymn4B=#2xF-UuF7uEWjpD`+lmct$yUFEhB~R&y0+`2%wfp| zW+hO#x|>pJVNS7^jpoGZv?A4#J=`EF6(%qBd8n^k$c>L@r^Y28%qsp8KXK?EE3+7W vKN{0tIAXv9rP#27{y$}b>qp1hQsp?dg8o}CI>NW}uDh!Vd-Oxk?8g59Tk8%2 delta 2107 zcmbtUZ)_Xo8Gj#N?6gko+KCe<{(H{ZaqK3}AE(gJq?t*RY*Y%N1*+b<7$?4@PVa2* z?vj%3yiyHKE8f}2m zAMZ1{UGz%=3&oj^|A56r)m%kD2(8*e%8RxYWb< znA{~Mq$Hm-v0FSW_42(^AK%+&8d}7Z)X(>uxK$jG2Khk~d&D6r&8JP=CZYgSkk+g4 zJOG0krp?oOF(((Zg~hDAQq1O*tXwLo`XkIRfEAx=nAgFY=z=}{aD1xKdR}YU7{=ER zdT_nZ*#JbnfNE;oEgA1olYD31w{b6iX>Y@w)NpILZYSh4IY?;wi0M1h?>Tf|-IpgT zq~gVV|B=?w1!Cz7xpWgSbB6q+`VD&yz|3Zw>^Rpccfh2mE3G{-aa^ z8Z1xMm#l=aXE1ywq&`=-&|~?vMjG?uVKf_Mwz^*nQC25};-A(@mD@Z(FF{95Dq(zW za6BE|f3*s$zEF>#d$D(&E~14uPSVP>VQi>96Wi~tcJJpvmPn;b3!fmrI9=g1Zh5A@ zawSTO6xn#tsBub*?oX@4wAhtqE&2+{yR_KyY(41}@+wn_;)g>V)3tHRNNvA670A;M zYXNko{nmg+HXg3^P}0?2jc?MLU8kcawBknp&^5ZXuDiDH*1BbvdS|osXx;cmIu?&> zWI0}6BA>Wm)}Yd(-l*H?i^a7b{5tK21lor=YeMU(CUIz(Yl{Cmewu!~6*}W%!zDP3 zTf?!IeT|#wow*dpu_acIA9>LNSM?9?^#QEo&e7u-7a4*g{cJbE3$W*UEBfSy)h0YDp6N z=5q@5|6o$^H}_qIchPa|FW|!4$AS>X1EZr5!O79*p$&IOS@7Y%N1p%>YGY$ZIrEDa zg{9oWT6R^Cl|regWOK!QRw)Y$g~b9j?b?)*tO|LVqfaDXHPj*ebd2jda8g*Cl;x5v zcNxZMs&;LwIdMf$WaEitHx3^^3my3EaSmGXz2n!xiF4yYTQhYgl6YnOZ+QMEpEV>Y z#Y~37*-RtmGaS6H|1L9U0YU%!1X#QdM|jUh-0Ze%;!m!LKe{GwxhA(n=iwO_bF-oO ztef0)HOzP#Z+aL5d%?gRnL$dnn%ZWQWQ(;MIN3Zq!ff4RG4N3^@W|u{C4WwHXS|l} zcA$9MYd;gUZbyuuZ4L|^&Gb^Tuc&Xf{j0g+>T$)EgxHB ztlpRI*(1jMw&(4IYG)0mm7IgO}8 z_>~;8nOSahDM7kHN(s>NpHxz`=`JZlv<+`4(NMb)?WJnhT`rVU*+Nkj$IsQy=EZ_2C~Jx;NOBP8)Ch#|2{oj@slE(D4PeGA@~o((+gYx diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-311.pyc index 88854a7c5660fcdde666e7fe8d5822ee240272bd..a8bb0c5389f547a446786da8f305c881b2f64ab9 100644 GIT binary patch delta 3099 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 Ra$jRTcvN5l{yF^8e*sBE3a|hG delta 2781 zcmZuzZ){W76@S-%UK}S*;>30wCk}RO96Jd%*coL67Dx~C0+R-n#Ri{O7n~Jo*XiN&z*d{(~JLhGI zamw|5zjyCBzkA-f=bn47KRnOwpJOfWI2?8f%lOS#j$hh(p~cJIyU>5JiAh}IO?h9T zJAL7nf5GUs?k`74Rc~;`>O825! zlCI*jTGCOaQHge~b)|I7Bq?laU`?P5E;8ifvs%(ahOLDTH0DyA8;ot?ZtmfoikW*A zyV8Kac+GUJRWCnos%ehPyz8tbo#4K8J8_hCqiic@N2FNKUGifBmYD(vO}he2cRZOZ zPLG%Jc_pirL<|LoGui3P31xq-$QAg$X>XJLaISnrQPo_j2-i)q4kUH#%c+{kJvXDF z@R%Yh7ITR)A83}>SSK`C`|Lwi+aT7@Y=e-pCKvvLpS>t4QkrooZQ?9#=BBiTo6}a_ z$z}9U<~Uz&Q*7L#G@{RqD6<xvqn_fxwG~GG}Mmzj+&lZQPzPn7cN>;y*ssW++DBX7Gs6$JFrV;QEvL+yb*(K) z92ryVxw&NCz_neCt#%y%=80Gz z*rhgqCGL68Y`)AU;E!G3WLF^JyTFdZ4c|Ch0&Dl#fNm?zXdE5jx^1Scm8dD&(56Tc zIN;6hASU09ZVz+8a`!8ptthVZ?lAG5g;PCA_D1De&w0iQFw*;L?@^TN7LF;cQUC%0 z(ND~0;J*PkjBe^-w_sZ^1PhzS`~_0bR8@*|V2wJ3os(WjZ1S>?;a{8XcM9TZ#M@|b z8~Yrs?eV@qj5%V|S(=6)1pV@DQodMO3Wk_W-iaCbRo~O>H_#utfkC+&3b5~iJv_|* z0HfjY-gU18C6H=CK-c!HP9q0zg@bIlax+|JY^IWmyv&#i*ZbXl#=IM|nIg|oFza1K z8z-NFzYRp-TFec}sEhp_4n$|=v*gYMd=yQgm48PAYzDewOY9ze9Q*D5r%2g=pqmSs za;#xBHEQk|`SCiDW(a;7=;mBe6GiG$9*Jp!90BbgF-wpqAgf|CL4?3a z(ipV}sHfh<)8h2{Z^dM>+EyfjW~mz<4o8NZR{L_Nf5lAiXwrD!Y4ogEvA-hKL!>hI zwQn=fw>w!0?rjgThn2P`wln{ir{sBgid-{_=2&Y<(!30>e!~ly9YN-(oY`@Lu{-eB zuWNY7;T>VzAAIMbURqLI&FAqYt|8P19d7R&V59JG=OJ90gCqWdNu=nqGN&m;uA4K( z7j-#PE@MY5l7)8&D2$i`7e`|LcZuGZE2>%sFEtUfi4RG+pWrI|Ze%kaE#_Up*0)JO zki?j&KZ4Y*Tdi+o-wMAy^jUA>i{3=FWh+>Af65A#+qBB|kNjZRbAFh+brvh4`EmCqE)DrQw}-&~24mJ(aHl diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-311.pyc index 37b12ce51831e65b292f653bf800f6190316d87e..67fce90704cb5a145e0a91f1da02db4fbbc39f5d 100644 GIT binary patch delta 1381 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 Ss@Zms<2v!HzK0E%=Kc@xtVX8* diff --git a/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-311.pyc index 7b984e9f54f65e576c9c988e3a12b12996482f01..c9121aae3c6168b23092a6da8de68ca1ef71e749 100644 GIT binary patch delta 386 zcmZ3fv0j6BIWI340}!~J>`OD5$eU}=$dJO2!jZ$9%NNB5W^?B7=L$p#fZ1F*g1JIb zLSQy`j&QC>lt`{bP>BHT%K5z7oV9H zUsReGpI97Ul%HRcJW)_|vlr75Rz}Uu{2YH-7#^^@y_+!^C19}~(Iu)n~7f+l+kCm69XGJRkmh2WWdQ8)qsCDvrt delta 334 zcmZ3lu~LI~IWI340}wbL>Pyp`$eU}Q%NxbZ$dJO2!jZ$5%OAxLW^?8UO4Rv6-LaFAF2@WL{nqDITEJMSLKF8$>992!0SDFgcpngpCu#`UX@$a_SXGmDjhVLC$%!-C0*93q?F33oCZm6(H+KtK&o z4Mz=QmJE!~!vN&T!gvLY=^(z`lw}Os94+a}$f&h>p_B#V=6}+_poO=VbA5o z$$FC0%!`Hf6bq{t=j1$vIL4yMXB8ry{1{oqXPA9p0MRQ%RwS>Hgs?XhLuh33BQpb= zP)p1QCXiyd#N-S`ImV>T?TS+vHH(4HE=mOvA|Rp)MA(4{8zAwE!zMRBr8FniuBdaf ci?TDLQydc`&>ZaK1!2{XV5u)S6o3r|0Nqz+Z2$lO delta 586 zcmaFmanh4_IWI340}wbL>Pz$4$a_SXa}p~9!*qrkh6R%qIYc(U6YgYYso`EA4dP8+ zEy8EQ$WUSl(g6WAJT)9Oj9IcUJ`V$sCkNvdFs6g}@{?DJ>xU}9M2mQ8c(dTVEHRjP zF_RZV6C+Sg5mkhfp~Mv?!oZNF3}b^-PBs(~om|1gJK0}?UETvG!@!`zP~=c6P~wFU zS)c~;0$U0vP@DSXeu;R-z{&3=RON#aN>aF&F)}c$24VRB8Tl24%-VHwwuq&=`e~J%Xw`-u7RKc diff --git a/myenv/Lib/site-packages/pip/_internal/commands/check.py b/myenv/Lib/site-packages/pip/_internal/commands/check.py index 5efd0a3..584df9f 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/check.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/check.py @@ -7,7 +7,6 @@ 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 @@ -22,7 +21,6 @@ class CheckCommand(Command): 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: diff --git a/myenv/Lib/site-packages/pip/_internal/commands/debug.py b/myenv/Lib/site-packages/pip/_internal/commands/debug.py index 7e5271c..567ca96 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/debug.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/debug.py @@ -1,4 +1,3 @@ -import importlib.resources import locale import logging import os @@ -17,6 +16,7 @@ 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.compat import open_text_resource from pip._internal.utils.logging import indent_log from pip._internal.utils.misc import get_pip_version @@ -35,7 +35,7 @@ def show_sys_implementation() -> None: def create_vendor_txt_map() -> Dict[str, str]: - with importlib.resources.open_text("pip._vendor", "vendor.txt") as f: + with open_text_resource("pip._vendor", "vendor.txt") as f: # Purge non version specifying lines. # Also, remove any space prefix or suffixes (including comments). lines = [ diff --git a/myenv/Lib/site-packages/pip/_internal/commands/download.py b/myenv/Lib/site-packages/pip/_internal/commands/download.py index 54247a7..917bbb9 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/download.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/download.py @@ -139,7 +139,6 @@ def run(self, options: Values, args: List[str]) -> int: 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)) diff --git a/myenv/Lib/site-packages/pip/_internal/commands/index.py b/myenv/Lib/site-packages/pip/_internal/commands/index.py index f55e9e4..2e2661b 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/index.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/index.py @@ -1,8 +1,8 @@ import logging from optparse import Values -from typing import Any, Iterable, List, Optional, Union +from typing import Any, Iterable, List, Optional -from pip._vendor.packaging.version import LegacyVersion, Version +from pip._vendor.packaging.version import Version from pip._internal.cli import cmdoptions from pip._internal.cli.req_command import IndexGroupCommand @@ -115,7 +115,7 @@ def get_available_package_versions(self, options: Values, args: List[Any]) -> No ignore_requires_python=options.ignore_requires_python, ) - versions: Iterable[Union[LegacyVersion, Version]] = ( + versions: Iterable[Version] = ( candidate.version for candidate in finder.find_all_candidates(query) ) diff --git a/myenv/Lib/site-packages/pip/_internal/commands/inspect.py b/myenv/Lib/site-packages/pip/_internal/commands/inspect.py index 27c8fa3..e810c13 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/inspect.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/inspect.py @@ -7,7 +7,7 @@ from pip import __version__ from pip._internal.cli import cmdoptions -from pip._internal.cli.req_command import Command +from pip._internal.cli.base_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 diff --git a/myenv/Lib/site-packages/pip/_internal/commands/install.py b/myenv/Lib/site-packages/pip/_internal/commands/install.py index e944bb9..d5b06c8 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/install.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/install.py @@ -14,7 +14,6 @@ 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 @@ -37,6 +36,7 @@ ensure_dir, get_pip_version, protect_pip_from_modification_on_windows, + warn_if_run_as_root, write_output, ) from pip._internal.utils.temp_dir import TempDirectory @@ -387,9 +387,6 @@ def run(self, options: Values, args: List[str]) -> int: 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 @@ -409,6 +406,12 @@ def run(self, options: Values, args: List[str]) -> int: # If we're not replacing an already installed pip, # we're not modifying it. modifying_pip = pip_req.satisfied_by is None + if modifying_pip: + # Eagerly import this module to avoid crashes. Otherwise, this + # module would be imported *after* pip was replaced, resulting in + # crashes if the new self_outdated_check module was incompatible + # with the rest of pip that's already imported. + import pip._internal.self_outdated_check # noqa: F401 protect_pip_from_modification_on_windows(modifying_pip=modifying_pip) reqs_to_build = [ @@ -427,8 +430,8 @@ def run(self, options: Values, args: List[str]) -> int: if build_failures: raise InstallationError( - "Could not build wheels for {}, which is required to " - "install pyproject.toml-based projects".format( + "ERROR: Failed to build installable wheels for some " + "pyproject.toml based projects ({})".format( ", ".join(r.name for r in build_failures) # type: ignore ) ) diff --git a/myenv/Lib/site-packages/pip/_internal/commands/list.py b/myenv/Lib/site-packages/pip/_internal/commands/list.py index e551dda..82fc46a 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/list.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/list.py @@ -4,21 +4,20 @@ from typing import TYPE_CHECKING, Generator, List, Optional, Sequence, Tuple, cast from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.packaging.version import Version from pip._internal.cli import cmdoptions -from pip._internal.cli.req_command import IndexGroupCommand +from pip._internal.cli.index_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 + from pip._internal.index.package_finder import PackageFinder + from pip._internal.network.session import PipSession class _DistWithLatestInfo(BaseDistribution): """Give the distribution object a couple of extra fields. @@ -27,7 +26,7 @@ class _DistWithLatestInfo(BaseDistribution): makes the rest of the code much cleaner. """ - latest_version: DistributionVersion + latest_version: Version latest_filetype: str _ProcessedDists = Sequence[_DistWithLatestInfo] @@ -135,12 +134,20 @@ def add_options(self) -> None: self.parser.insert_option_group(0, index_opts) self.parser.insert_option_group(0, self.cmd_opts) + def handle_pip_version_check(self, options: Values) -> None: + if options.outdated or options.uptodate: + super().handle_pip_version_check(options) + def _build_package_finder( - self, options: Values, session: PipSession - ) -> PackageFinder: + self, options: Values, session: "PipSession" + ) -> "PackageFinder": """ Create a package finder appropriate to this list command. """ + # Lazy import the heavy index modules as most list invocations won't need 'em. + from pip._internal.index.collector import LinkCollector + from pip._internal.index.package_finder import PackageFinder + link_collector = LinkCollector.create(session, options=options) # Pass allow_yanked=False to ignore yanked versions. @@ -329,7 +336,7 @@ def format_for_columns( 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)] + row = [proj.raw_name, proj.raw_version] if running_outdated: row.append(str(proj.latest_version)) diff --git a/myenv/Lib/site-packages/pip/_internal/commands/search.py b/myenv/Lib/site-packages/pip/_internal/commands/search.py index 03ed925..e0d329d 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/search.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/search.py @@ -5,7 +5,7 @@ import xmlrpc.client from collections import OrderedDict from optparse import Values -from typing import TYPE_CHECKING, Dict, List, Optional +from typing import TYPE_CHECKING, Dict, List, Optional, TypedDict from pip._vendor.packaging.version import parse as parse_version @@ -20,7 +20,6 @@ from pip._internal.utils.misc import write_output if TYPE_CHECKING: - from typing import TypedDict class TransformedHit(TypedDict): name: str @@ -76,9 +75,8 @@ def search(self, query: List[str], options: Values) -> List[Dict[str, str]]: 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, + message = ( + f"XMLRPC request failed [code: {fault.faultCode}]\n{fault.faultString}" ) raise CommandError(message) assert isinstance(hits, list) diff --git a/myenv/Lib/site-packages/pip/_internal/commands/show.py b/myenv/Lib/site-packages/pip/_internal/commands/show.py index 3f10701..c54d548 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/show.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/show.py @@ -2,6 +2,7 @@ from optparse import Values from typing import Generator, Iterable, Iterator, List, NamedTuple, Optional +from pip._vendor.packaging.requirements import InvalidRequirement from pip._vendor.packaging.utils import canonicalize_name from pip._internal.cli.base_command import Command @@ -100,8 +101,19 @@ def _get_requiring_packages(current_dist: BaseDistribution) -> Iterator[str]: 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: + requires = sorted( + # Avoid duplicates in requirements (e.g. due to environment markers). + {req.name for req in dist.iter_dependencies()}, + key=str.lower, + ) + except InvalidRequirement: + requires = sorted(dist.iter_raw_dependencies(), key=str.lower) + + try: + required_by = sorted(_get_requiring_packages(dist), key=str.lower) + except InvalidRequirement: + required_by = ["#N/A"] try: entry_points_text = dist.read_text("entry_points.txt") @@ -117,9 +129,25 @@ def _get_requiring_packages(current_dist: BaseDistribution) -> Iterator[str]: metadata = dist.metadata + project_urls = metadata.get_all("Project-URL", []) + homepage = metadata.get("Home-page", "") + if not homepage: + # It's common that there is a "homepage" Project-URL, but Home-page + # remains unset (especially as PEP 621 doesn't surface the field). + # + # This logic was taken from PyPI's codebase. + for url in project_urls: + url_label, url = url.split(",", maxsplit=1) + normalized_label = ( + url_label.casefold().replace("-", "").replace("_", "").strip() + ) + if normalized_label == "homepage": + homepage = url.strip() + break + yield _PackageInfo( name=dist.raw_name, - version=str(dist.version), + version=dist.raw_version, location=dist.location or "", editable_project_location=dist.editable_project_location, requires=requires, @@ -128,8 +156,8 @@ def _get_requiring_packages(current_dist: BaseDistribution) -> Iterator[str]: 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", []), + homepage=homepage, + project_urls=project_urls, author=metadata.get("Author", ""), author_email=metadata.get("Author-email", ""), license=metadata.get("License", ""), diff --git a/myenv/Lib/site-packages/pip/_internal/commands/uninstall.py b/myenv/Lib/site-packages/pip/_internal/commands/uninstall.py index f198fc3..bc0edea 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/uninstall.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/uninstall.py @@ -6,7 +6,7 @@ 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.index_command import SessionCommandMixin from pip._internal.cli.status_codes import SUCCESS from pip._internal.exceptions import InstallationError from pip._internal.req import parse_requirements @@ -17,6 +17,7 @@ from pip._internal.utils.misc import ( check_externally_managed, protect_pip_from_modification_on_windows, + warn_if_run_as_root, ) logger = logging.getLogger(__name__) diff --git a/myenv/Lib/site-packages/pip/_internal/commands/wheel.py b/myenv/Lib/site-packages/pip/_internal/commands/wheel.py index ed578aa..278719f 100644 --- a/myenv/Lib/site-packages/pip/_internal/commands/wheel.py +++ b/myenv/Lib/site-packages/pip/_internal/commands/wheel.py @@ -154,7 +154,6 @@ def run(self, options: Values, args: List[str]) -> int: 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( diff --git a/myenv/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-311.pyc index fa16c76dd4963d7569fd7c056ae6cd9e7a90d9bb..d70b2aeb21df475bfc2a81ac3544734e671b56b7 100644 GIT binary patch delta 19 ZcmbQsF_(jDIWI340}!~J+{h)&0st#B1OEU3 delta 19 ZcmbQsF_(jDIWI340}wbL+Q=o$0st!t1NQ&` diff --git a/myenv/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-311.pyc index c5c4f04d8a879854017e01435b1b88a2a3aa5852..60fad01148382d212010a7b21988ecd26cc8856f 100644 GIT binary patch delta 748 zcmZuuO=uHA6rRccC)xZoq)i)>)+7j=&QZG_Hdhpnj5j=#w*ptv(4vOH(H(L}0-_Csd{=YXfdztSU{gtkV5y;uS z$E}|OefnVsjHieof*oY?f5^dZ$PBrHDPV33j_69J6zHNOyNan`WQV8>G09O~&D1ao zp=CtmJ|c>ZZUqFK$fO!#>yU5StFZzL+N(3EMFefh`cRrIKi0+=gyDhYWyb{1Li` z%>)qXyKnJTA;#x11Yh)Qr$xgoE%kAnJ(CJJzxzR2!_fr9Jq$2MC)hEik}Yrt_imvd zQ4}wHjupSeibJ(XQ|y6KnbaXf(;TLF=AY6}N&}Z!UY$y&!0pSeU}~y>!D{ODW2c}&B delta 745 zcmY*W&1(}u6raiNW*D@6s1r}$aWldT{KE|##(Y-)5isk0IEWDYra zQ3xaW4@gDoMe0pYp7dmd9>SiyD0uUrJ$UMSTPx=6&ToJ7-n`#?Z}!*pr)m48ZCeCv z@x#;B=b=6Gs0Ewngb_wL@$j4CG)#FZid^AJsCsI`Rj!3;FP(6W>!INpl%&WN!qNl6 z^nlzkQ5fyDv7r#M32VwG`6q#&Aa|uaJk)Kff&9! zKHPb6B5;@)tgumX^1+wH2DpK|G=WRZ);<^?Ip_jyyo0{LYfx>=&oD?bJp_O%&xby*`zNkT`%a zg(vq@zw1j!=g{E*^vO5p$bX68iqoxR6uDyDI{8n-RRuO64k45f$^elHPz4hOAaO;O z&5G2_h3Y&8|Muog_68BRC~umlVZ0}1iQzrRO4JkLATq~a1@1R{VbHtXWkLg|m_fi= zvAWvra&Z``-DotqA4Sc8^G3s^0_!DXUP#&z24*3cQn%jHihOS^A1m%V;YXTK!%sBa zjHp2%PWK+Jw>xV>k@qrl@=WGD(=T3Hyb8w>p;tsC`8e$#qaJqIeIA?>r(lcM8w~+| gDwNVOvHHm~CZ*Bj`<2v3lkZsWWNLCDTUSwh7p54cvj6}9 diff --git a/myenv/Lib/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-311.pyc index d3cad9d9b0d303c21afb47ddf0117d2d7ddd5203..21338bf1d4ed44262fe53fca97bd65b1bb338b92 100644 GIT binary patch delta 19 ZcmX@ccZ`o~IWI340}!~J+{k6a4gfM31c?9u delta 19 ZcmX@ccZ`o~IWI340}wbL+Q?7%Q6y90eYkU0@|77Dhv12<<6K~q4iBwe)^d}IK5Qw6rX@sz#&d*GOTiZ#- zP7yhfAQiYFqIZaB51c5VNd+U(25=hMMe*4}V zfAh_}_tqbe?~DgN3&dt^OZ)5)Va*UY_m zHlzNYdR}EQ*mb_q9zk8pvn*-_UaZ!nfo_#Dm6kE6xh7Z=?z&Q8+MT5>*(a3&bm~95 zrc@SzbDsO57W8G3po1U%B|SltR{NqfIZGR@Y`!L{&2iq^9lF~ExTPmNa@8--J`ILpJ`XuB#;!ey;Rl^NKN zw$$&$S{Tc~7pGK@=(ZDbGak{Z=vKdkdOYX&Hgp;u#NWr{yxsOa!(z=RM%laYQDWMlf}0M@_ee$L z6aFYo8HL6S|ZEdf)A3Lc2mm!dT&QJo0}n` zD)YplI+||z64^)VKS}Ocf+HnoP3?WRK23$xFZc+e_91jU>SD=Q^AKtA=AB%wxW>>^QWrAFW; zu!}_Ma+ZK38$H=X76FM?ui*E!b$IQmPWUrD%Th3%8HAn83-DLwHJ{BTh8csc&SPm? zz>2LFSNjUZN=?Yhe5tQdeNnk4J@8p)H}k@S&JO6yj)9)-+N4ujUi`8rR+g8Alym6I zK>~X_k8kl0&)M<{UoVOCaut6<{{Yo}ggpmiY*z_x+1IWzbnpM&_Z4`UJp%(>*)~UL WPhspSw(A_a_xKGnT^F5n(!T-JD@}F) delta 1534 zcmah}OKcle6rDG=$1@(=8ON~`CviS@oWvB;Ler9_X)5R^1VxY(STImbk~cPP$8q|` z5mJd1KoQGG(G_CZY$)Zksk~^Hd?dsIso^6byeUWs35ic6goL`{-WMxLB@oZ^j_%}9!UusM`nV+vQe&($hHJ1A+tt5*!$kaWNeRZQEI zwC08@5j!I3pc}2U*e#OQU8@qaV@y#MN4eBW5okH_>r7ET#J#)hHdUEYxUsJAkYil; z;TdivAy4fDXU`~k^B3Zt%KJC};*rSg{Nm;Ll5@Vi#2t8!jkYgJ-6rVG|3B}+O*XaW zgt+FIJcwK6dQrzfeml$qC@0>}L&!(C>O>tawdbd(auek({~`~g+&W+%K|aROnzuNu zPTbKPt*GvKf|43Nq!%@Ap;{Y{p~`_U%@kVkEWvdwG+y6QCsme!yZ$%2Vwg@tFFCaW zFMBo7hO9?z>k~%=G<;+{!g}g=jRD3w>V7lso1&;ERI>OG?e~xA;kB}vp zCi57AH)Au{jyth5OTuqR7wY4!zpIJeQ?d;cOcI=iQ;A&kF(f^DgQRy@PF!H6`e%t( z89N6j+f!;#MuiQpxVWsSHYL_Sev+5kwQirrFXzSg9cT>aR@2t_Ut^{#nV6%H}j>et$HOvET7f++CVRFY?6y@bwxw@1O;2TjD zmHC>GjXHq}VuHXR^Jb=GCT8Ji`ax4pfl9fW1-m=T)?p*Prco?$xE}8rWG`PJLsdL4 zMMMY13qJ+6^CG0MU+=FbTQ{=%dx}FI20pI6{1ufF{2?BRQ=cvGleHjX+L|0*Yq|WP!5w zD6s^zy|?h1z25x6uYER4!&Lv6dE?@a(h-Q>uI(tW+HadT9@Rp|D6f52uoo_Tm%`JV^A%#K+T+sb_pr~^58d|=K`x&8y~d_zS5 diff --git a/myenv/Lib/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-311.pyc index 7864a7fe3b639f1552840583f1697a109f3be3b1..e621d31e59b60d61d0235c200154f399a38f85c4 100644 GIT binary patch delta 629 zcmZutL2DE-6wb?JGMU+#wc9PC-L74+6-EmxNa>*!rLI+qrJ@%DtyVKzi!-~Dt%xT@ zDtJ*?f~ZF?dhpm^py0tlR(mfN@HFSq9xuPiML-pvet%+_Ma zqvf@`_t(~wOB-F4XmbQs#}r4uKnYB${Ekq;7Lyg_qhDqFEhGR3xBt>6ZMdbkuHlrs zkM1Q&+Na1{Ej?_e-9;ER&)jZp#4htr>91`|%pbRX>Hrcwgb=gRKsRh*%t8~P&k$M| zdKgLGH1B!SyyRyNPuN8t;VCIX;zuu-wim>q`OatN?5W)8Z)#mfracRzw#M%CdZ`|_ z+Fn|oDXn#ArG+7L&FjIq`RvU#tYukTimN%_eEeXeyRL0>H8UgPD7a=?95>I!Npo9F zUbUav^V#qHTg+xX^)OA&=_%X-nEkH^g#!S)>mX;EB;w#pZgCbD1;mU delta 579 zcmY+9ziSjh6vyYy&d$#4-fn(eA{Q?wXHaoTKm`ShM8qH#qJnl?2+Hi4gW20KcM`3% zNFf%&F^Je%DPmy}OKtKOq&)T?5W53AL2%y2<{mTO`M&pfpP4yqzHKI-;y5HOwh!O* z{<3k>deL*)JEDjJO$x{W&{ItdFY{{eX;%1|Uwfu`5oAH_eJu)^$s)|cBFZ8ll-weU z?-Lc|{zs3HFK!=4)==UBN#!q0Q>etf-BG_BJklwQzi-&HFhBmeWv{@))jU)@j~pRV zREeHYa-aR54iCOU4zP5v>~(0HA&HuKcU1n~PM+%_b-vp*3-*qG8(Q|gKWH?u&3pZU z%8hODn->ySFmp~)R?nJ~SZJfHIvFCi>%uHJQ+4bQ-m#zgrIj^oN+&PLv_WM2iWy|5 zvHi`j-oTGm-f(2hqH`udSwZ30V2{gEn^TzM&Glf-HxZ^NiQNfG=-5fHbpp9{@opMd zeDr*`KX_t1dr_PQX77u0;M))4ynQCtw~qm{&_80cDAiM)Uo-2D1a1$%IhlF@Fd^-u f*=3jInWYKYJeploYOl);P8iT>VqeS444?H64Lf$j diff --git a/myenv/Lib/site-packages/pip/_internal/distributions/base.py b/myenv/Lib/site-packages/pip/_internal/distributions/base.py index 6fb0d7b..6e4d0c9 100644 --- a/myenv/Lib/site-packages/pip/_internal/distributions/base.py +++ b/myenv/Lib/site-packages/pip/_internal/distributions/base.py @@ -1,10 +1,12 @@ import abc -from typing import Optional +from typing import TYPE_CHECKING, Optional -from pip._internal.index.package_finder import PackageFinder from pip._internal.metadata.base import BaseDistribution from pip._internal.req import InstallRequirement +if TYPE_CHECKING: + from pip._internal.index.package_finder import PackageFinder + class AbstractDistribution(metaclass=abc.ABCMeta): """A base class for handling installable artifacts. @@ -44,7 +46,7 @@ def get_metadata_distribution(self) -> BaseDistribution: @abc.abstractmethod def prepare_distribution_metadata( self, - finder: PackageFinder, + finder: "PackageFinder", build_isolation: bool, check_build_deps: bool, ) -> None: diff --git a/myenv/Lib/site-packages/pip/_internal/distributions/sdist.py b/myenv/Lib/site-packages/pip/_internal/distributions/sdist.py index 15ff42b..28ea5ce 100644 --- a/myenv/Lib/site-packages/pip/_internal/distributions/sdist.py +++ b/myenv/Lib/site-packages/pip/_internal/distributions/sdist.py @@ -1,13 +1,15 @@ import logging -from typing import Iterable, Optional, Set, Tuple +from typing import TYPE_CHECKING, 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 +if TYPE_CHECKING: + from pip._internal.index.package_finder import PackageFinder + logger = logging.getLogger(__name__) @@ -29,7 +31,7 @@ def get_metadata_distribution(self) -> BaseDistribution: def prepare_distribution_metadata( self, - finder: PackageFinder, + finder: "PackageFinder", build_isolation: bool, check_build_deps: bool, ) -> None: @@ -66,7 +68,7 @@ def prepare_distribution_metadata( self._raise_missing_reqs(missing) self.req.prepare_metadata() - def _prepare_build_backend(self, finder: PackageFinder) -> None: + def _prepare_build_backend(self, finder: "PackageFinder") -> None: # Isolate in a BuildEnvironment and install the build-time # requirements. pyproject_requires = self.req.pyproject_requires @@ -110,14 +112,14 @@ def _get_build_requires_editable(self) -> Iterable[str]: with backend.subprocess_runner(runner): return backend.get_requires_for_build_editable() - def _install_build_reqs(self, finder: PackageFinder) -> None: + 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() + and self.req.supports_pyproject_editable ): build_reqs = self._get_build_requires_editable() else: diff --git a/myenv/Lib/site-packages/pip/_internal/distributions/wheel.py b/myenv/Lib/site-packages/pip/_internal/distributions/wheel.py index eb16e25..bfadd39 100644 --- a/myenv/Lib/site-packages/pip/_internal/distributions/wheel.py +++ b/myenv/Lib/site-packages/pip/_internal/distributions/wheel.py @@ -1,15 +1,17 @@ -from typing import Optional +from typing import TYPE_CHECKING, 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, ) +if TYPE_CHECKING: + from pip._internal.index.package_finder import PackageFinder + class WheelDistribution(AbstractDistribution): """Represents a wheel distribution. @@ -33,7 +35,7 @@ def get_metadata_distribution(self) -> BaseDistribution: def prepare_distribution_metadata( self, - finder: PackageFinder, + finder: "PackageFinder", build_isolation: bool, check_build_deps: bool, ) -> None: diff --git a/myenv/Lib/site-packages/pip/_internal/exceptions.py b/myenv/Lib/site-packages/pip/_internal/exceptions.py index 5007a62..2587740 100644 --- a/myenv/Lib/site-packages/pip/_internal/exceptions.py +++ b/myenv/Lib/site-packages/pip/_internal/exceptions.py @@ -13,16 +13,16 @@ import re import sys from itertools import chain, groupby, repeat -from typing import TYPE_CHECKING, Dict, Iterator, List, Optional, Union +from typing import TYPE_CHECKING, Dict, Iterator, List, Literal, 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._vendor.requests.models import Request, Response from pip._internal.metadata import BaseDistribution from pip._internal.req.req_install import InstallRequirement @@ -184,10 +184,6 @@ 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`.""" @@ -294,8 +290,8 @@ class NetworkConnectionError(PipError): def __init__( self, error_msg: str, - response: Optional[Response] = None, - request: Optional[Request] = None, + response: Optional["Response"] = None, + request: Optional["Request"] = None, ) -> None: """ Initialize NetworkConnectionError with `request` and `response` @@ -358,6 +354,17 @@ def __str__(self) -> str: ) +class MetadataInvalid(InstallationError): + """Metadata is invalid.""" + + def __init__(self, ireq: "InstallRequirement", error: str) -> None: + self.ireq = ireq + self.error = error + + def __str__(self) -> str: + return f"Requested {self.ireq} has invalid metadata: {self.error}" + + class InstallationSubprocessError(DiagnosticPipError, InstallationError): """A subprocess call failed.""" @@ -726,3 +733,45 @@ def from_config( exc_info = logger.isEnabledFor(VERBOSE) logger.warning("Failed to read %s", config, exc_info=exc_info) return cls(None) + + +class UninstallMissingRecord(DiagnosticPipError): + reference = "uninstall-no-record-file" + + def __init__(self, *, distribution: "BaseDistribution") -> None: + installer = distribution.installer + if not installer or installer == "pip": + dep = f"{distribution.raw_name}=={distribution.version}" + hint = Text.assemble( + "You might be able to recover from this via: ", + (f"pip install --force-reinstall --no-deps {dep}", "green"), + ) + else: + hint = Text( + f"The package was installed by {installer}. " + "You should check if it can uninstall the package." + ) + + super().__init__( + message=Text(f"Cannot uninstall {distribution}"), + context=( + "The package's contents are unknown: " + f"no RECORD file was found for {distribution.raw_name}." + ), + hint_stmt=hint, + ) + + +class LegacyDistutilsInstall(DiagnosticPipError): + reference = "uninstall-distutils-installed-package" + + def __init__(self, *, distribution: "BaseDistribution") -> None: + super().__init__( + message=Text(f"Cannot uninstall {distribution}"), + context=( + "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." + ), + hint_stmt=None, + ) diff --git a/myenv/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-311.pyc index 34ad3752fb26e2adad7c7a8fcaec23945e2e847b..b0c4237328f2086e2a562c2f2d138abf152d9330 100644 GIT binary patch delta 18 YcmZoa6A(yI~`-JN>($GusL zP+B@(|NQ2?H*em|ydA&tE}Z#0l%6XoDUz`DU3z)s`JS=TDmXjVq}xFvKy0b8GYc*0 zT6OG_uh`T$Q;q3>IyU=gJ&^KLB)w8yiTVYkBGsC1Q`^$*YJ0jv?Es1I2Y-!+cG0d8 z*(>6kO{q`x+99(YubGjb<~f#derri2D;iD(=B&G zHGfhLT3mE7|AXB404*U)Uu_--N%{+Z3r&{RNhEYcBEfMP^)mNwa`&nmOm!I5%V^oS z1r7KuGB3)!TT})O`ALiWi!<%@n-PU#L9b;Lg{_O@n+@UN>TXHV_d2GP=-&8)BaTeSNYY( zec=+5a$1@$U73f$PF?mq1M5mja&( zco2D8g3)-Eva8q$I`Wo8N;hX=#1wyR{i2#LvHw)%Kr*whS4*X6BCD}* zAia*a{bU`{4D4Z_yNGv%>W|#Qj}A<>@V#;S1im zbqieQFK#`Jc{Odz*~}Sk@z=IJ2Jad5L$5=#dGu8xn%EL1&Ocvl-g0T0-K!BMQeg)L zzU1F;_YJy*Xdaz-qu5sh^#bOB;eXgqPEu^IxyMJ*s5c?*miUZp?0MJ^F4Lz49fL3w z+{(y*2!&fYeh`$jbB>vHkQ0Lq&Om!x%k$myqY&sPljWeAxrU;Eg8_gE_BKf>6 zdtfw~*~1%#TPoRnbI53NG#uMcGel!pnDOCiSiqkiUT7;+Eb7a6L_JHsEgnvKc*g-@1KzFc?{(d4#r!L5@-SFgBj`mJYF?x zT5kW)?%?ZoZC@kF#X0Zs2PVKX37#w9nUTvOJR|)SvqE=UVAdkZRdcS3jSqHtpl2^Y S(TsF|&YJq$KVvmt@c#oc*IE() delta 2536 zcmZ`*eQaA-6@TaX*|8lbalRZoX<|ERn>t@@zM8bOwA2}K(#`o;+N7q#M7}qTneAup zbE>vPBxoHg2&QJYQbSv$qKTFcAtv7bKv1zV0c$k`(I~3t!kSJ+LJ))t{Syh!eO?=A z*Bkry&N;tx&pY?rbFcHApToIpPhy5Va}&6+7$5n1}~rXr9C z5KCg|MtyOzG16$Lw#3r?!+~;Ak?2nLM0%3Fk>2F?$aauuIV(c<%7io77wH2jCDZ;$ zA5VZET>Mq=fSZ3Gy1~o;2wMX!q?*Vx7SeE1i3CX%-9_pt+Nc+8UbGDmAKi_*oA<~& zppU2IfT@aZ=I7+bg+Yn5o|H)7k}OF-z;9thhGhwvHe}jq$t4qV`2CpMZkK|0qh>ynYCm2{mnN1nwPyNHJ_cu5a^4s#pETzioS8-WY? zyGdYuGVPt??Q@->ZORF0H z&=lg`io3LA;?U?b(O~GA;QpcTARksjuU}BW5rCX^l&KjtrY7_Y=6wJg_#Mkt=+iG0 z-2e#k8QXc-r_1&`G7RyL94ipj^^&-Z`%~|H5n}q+onJLu#41=dce)zO>x39Y$SGe` z<0?=oT+@G8TMO_@e!cD%yvr|cSb(>6UwuC~e}faXB7{XL zYb`!y;zt_lp_;$k;19khsGSD2h_v|2%V2gae?Bka<4x;Ns@^I!#HWJ(LBp?QxTRn8 z?*zEbZ#TY(u?L$%u%e%Cx@bbBv-ziRPhV^9fQ1;o>d`3qSo&8Og|iZsB0!{wOdw*y zjdlp0?zN5BaMwy$5`&)T9j9qV zHJZw3J~c)8&jQVj6YLC9Y^#8?0vZLV0-6xQF$*6Xs5<;C%4el{n3tj`6~?@b8a&cW zs6Fcbc?Gpc{XTC-O?l`^08^5ulQ`Ax!@>U?2=a|Bd-)eyX8E-igGFXg`Xf&RRXQELBGtxvQaNipw zxA&Ct&1Oe-!3T43(vG}gF61b);{p? zKec+zS70Jw=l^N-mNU^=%pu^*0($t~Hva;McP<(4eAshYWzUMTC-0OtZpoKantSsS z!fLrIZx)J0s;SKv3CSu|)-89RY0uk)W|vCK^Tk4PNcH~0#8Sy#nlBSJ5#oQK1s}ifaDxg9@r2w(!oDxsXsLaXF?S2VH^@dNEDPGa-g<5!p zM_DvFol2>h=}cTrY0)U(yUzpP(j)tJ$TeBvx*s86Dr~ioS(d*s&<^MI?7$l`)bf`G z!=Ur`2MPBce_MvON`O!3}v@O2y4z1OK3(omJ@Mq3%DuZ_X4tfIkXw> z@wY=BcwPS>gp17byF-2OEAAP-4u9bv4ey2WZ1&5riqB#@L$h6O)X^Xl9grzQx7GLU*q6wQw)|fj5q<`u>4b znEg|@K0x?n*Hu0>`X1cj8^^}r@BHZ4dCa$Be9>aOVT~`3e+ho4+n@gt%w86OY6OU~ z80R2Y97{}VT9RgFRl>vpEwtu6lycTIQ`3}Xjx(DejP5mRR4r7akHxLR{wknB!21HM z+<&05K@{7l_-mrSn-Ly%H=Zp;A3xxS8pEecI9@^sj58y{fAdoZ>x)e|gS{p=;BOvm zZ=1~|6CLSkrcuVkwUV={=}bWvY3D4NW#S2~BN^9XO#D#g%Ktz1(U`_I2z!yH&aoKP3Z)aLpwL2o zA)VmwOr3#SeDcs{c$t6Y&~e=sSpvVwnU_r9$|~NKCqAoX)r%qh+n=M*B7-9@Jqf4X y_l5PrI%VhEUO2GD108wkNw_a;57vo({oNO8U{4&to|iru?;G|9PhnXbF73ZLHHcsU diff --git a/myenv/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-311.pyc index 49705edeeeff14fb3b2f6a390b5bd7d839482a4c..7ca9ca5ae5d5525f6a8db134a55b2d52885f5b85 100644 GIT binary patch delta 7510 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 Yb3nXl5yXRf5O1<|m&m)?P3g)10-C2Ly8r+H delta 7518 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 DPdy6O diff --git a/myenv/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-311.pyc index f38f37d0ea5edf0f200031ec37a4db6a292e7568..febeff2110710b94e02346f92b928007844d8441 100644 GIT binary patch delta 19 ZcmbQ5J2jVUIWI340}!~J+{o2!1^_sp1!DjJ delta 19 ZcmbQ5J2jVUIWI340}wbL+Q`*y1^_sA1zP|B diff --git a/myenv/Lib/site-packages/pip/_internal/index/collector.py b/myenv/Lib/site-packages/pip/_internal/index/collector.py index 08c8bdd..5f8fdee 100644 --- a/myenv/Lib/site-packages/pip/_internal/index/collector.py +++ b/myenv/Lib/site-packages/pip/_internal/index/collector.py @@ -11,10 +11,10 @@ import os import urllib.parse import urllib.request +from dataclasses import dataclass from html.parser import HTMLParser from optparse import Values from typing import ( - TYPE_CHECKING, Callable, Dict, Iterable, @@ -22,6 +22,7 @@ MutableMapping, NamedTuple, Optional, + Protocol, Sequence, Tuple, Union, @@ -42,11 +43,6 @@ 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] @@ -201,8 +197,7 @@ def __hash__(self) -> int: class ParseLinks(Protocol): - def __call__(self, page: "IndexContent") -> Iterable[Link]: - ... + def __call__(self, page: "IndexContent") -> Iterable[Link]: ... def with_cached_index_content(fn: ParseLinks) -> ParseLinks: @@ -254,29 +249,22 @@ def parse_links(page: "IndexContent") -> Iterable[Link]: yield link +@dataclass(frozen=True) class IndexContent: - """Represents one response (or page), along with its URL""" + """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 + :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. + """ + + content: bytes + content_type: str + encoding: Optional[str] + url: str + cache_link_parsing: bool = True def __str__(self) -> str: return redact_auth_from_url(self.url) @@ -400,7 +388,6 @@ class CollectedSources(NamedTuple): class LinkCollector: - """ Responsible for collecting Link objects from all configured locations, making network requests as needed. diff --git a/myenv/Lib/site-packages/pip/_internal/index/package_finder.py b/myenv/Lib/site-packages/pip/_internal/index/package_finder.py index ec9ebc3..fb270f2 100644 --- a/myenv/Lib/site-packages/pip/_internal/index/package_finder.py +++ b/myenv/Lib/site-packages/pip/_internal/index/package_finder.py @@ -5,12 +5,13 @@ import itertools import logging import re +from dataclasses import dataclass 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 InvalidVersion, _BaseVersion from pip._vendor.packaging.version import parse as parse_version from pip._internal.exceptions import ( @@ -106,7 +107,6 @@ class LinkType(enum.Enum): class LinkEvaluator: - """ Responsible for evaluating links for a particular project. """ @@ -323,23 +323,15 @@ def filter_unallowed_hashes( return filtered +@dataclass 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 + prefer_binary: bool = False + allow_all_prereleases: bool = False class BestCandidateResult: @@ -383,7 +375,6 @@ def iter_applicable(self) -> Iterable[InstallationCandidate]: class CandidateEvaluator: - """ Responsible for filtering and sorting candidates for installation based on what tags are valid. @@ -761,11 +752,14 @@ def get_install_candidate( self._log_skipped_link(link, result, detail) return None - return InstallationCandidate( - name=link_evaluator.project_name, - link=link, - version=detail, - ) + try: + return InstallationCandidate( + name=link_evaluator.project_name, + link=link, + version=detail, + ) + except InvalidVersion: + return None def evaluate_links( self, link_evaluator: LinkEvaluator, links: Iterable[Link] diff --git a/myenv/Lib/site-packages/pip/_internal/locations/__init__.py b/myenv/Lib/site-packages/pip/_internal/locations/__init__.py index d54bc63..32382be 100644 --- a/myenv/Lib/site-packages/pip/_internal/locations/__init__.py +++ b/myenv/Lib/site-packages/pip/_internal/locations/__init__.py @@ -336,17 +336,6 @@ def get_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 = ( diff --git a/myenv/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-311.pyc index b72504c7252d30439fe57af2b0f6ff562fdfb367..83189f8dc17e6c7490cbd58391143a15fc0d8de7 100644 GIT binary patch delta 887 zcmZ9J-%Aux6vxkMv;e2cmmtn=}vH&pkiB=iD<4E|M>Ih-c01 zb^){AcZt!+;>df4_=Z>a`HVvRoEB))f64_#J8LTe=9Ia>u%HHR$^U;WCgb%(U3)q;sDcWmLq(CzVyA2b_!d;^g~8Be zmenhDm+sfnb{&9LQWy1?Y7h41!dee*#g*Dnv4TxxXaB@l7(d6a8CRPsw>7=YMu1#_3`BXW**+= zc*c+w7#bQf$9W=T;|cqJ*&Fz@vjI2T9R@w~mDF1Ux4FXF=HOJE>P(QAxZe4S6mX>L z4cW$c_eAh9Z)oC(aKt#4akKjpSwWJHkX?+XkCFGr#q@5)v?>s<37nt2epBSmcbCU> zSa~N@Dfwis#gwd2w!=y*bb(hft1Pz~+`;@nuFrH^p$DARrq^<<(d7sJvfm*S?~-T& KyG)!pm;VFZ8poyp delta 1083 zcmZ8eOH30{6uocC&<~w@ z5ZAaMIKYT?k1zD_tM9pWgD!KToB6ha#UQZFQ|s*PE*u^v*~9xY+R zd!cgfjHF!(eYN2ICH_|TfN6+E)P*@OfD@v1)TW3-5S7&xd0maB(GFUk$W>+-rXPXProC1Vz&)>zpfz@}2`de~F4+fWnsgd^cqJ96jQ zTT*W(@PA!0pl+Ds%HEI9l#Ue`{f)&!0LTuIgIi=Cm(~YxU(L=^nTxR}`^^5UY>6d} zEf!|btWDK;2sxoWuT=;MVYn`1f5)qb2M_Fz#qe$2X5z=H`q#nI_(0!aSNvFfU-VE< zUvF3U-oBm#-Mw9V5BK8F`mp;7YZf;k?l+(en;K*?i`@-JtWmsbQ4cD$Y3P zr-xoSD|N64?c{?mm@3jOjLwRlmr~ukPJ8o{A_J?Qu;c0Q%jJWLX z_6NIOiEDK`*ei4=IG1Sg<)fT5!lu_UIL_cIgKJnFsUd0XjQl1yv~7*!9GSvjt0Md( z<8)kG*?fzH@^ws{Tg=jv3?3qB36M!G*ka`tnf?hTo5TJu!uHm1;ZtHf!g(xfDZ?wR zX>t|AYaWvc{Jv&Ty3Q&q8I&`S8I0i3wyoqEK5Hu{kMK)d6?vgaYbOhaqa1PT!0?T` zShp}T>u~A3sTV?#H?<;Jr(4a`mP_qs>HxP_FEXhU1S!>-+^h>`>ViV2?l!5}Iy>Mm RD!h%j(-s|!O~*|gsXuOX{ulrN diff --git a/myenv/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-311.pyc index 7f28deeb6736486994369948049d54dc878b40c4..e32a447cc690fb472be715bd5aa5ab71bab7d4dc 100644 GIT binary patch delta 19 ZcmbPeJ<*zLIWI340}!~J+{o1~3ji@n1lj-q delta 19 ZcmbPeJ<*zLIWI340}wbL+Q`)|3ji@81kwNi diff --git a/myenv/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-311.pyc index 5c009223aca8adca910236cf73743f3a17e92061..b745b9fc65c7ea88e045b222a73a9b3388115244 100644 GIT binary patch delta 467 zcmX@?dexP8IWI340}!~J>`T+x$ZIPimdQ}dQ=$M8g8&zXSmj#Y$uT0bjJ%VpL}WB- zcxrfUfO0)5CGs#u3=AovnG7{NOBnkYYq@KQAuh_e0FMO@hxT`Ir*!kDpx2_T@4Ty^KMp=I>_jCLsGhf@2;@i2L?t? zFGdL2;e1y~cSXup_Z@BroG+SqTru&usN{J?$+N?6hVexn`3pSqcLl{S2xw6S>u4Li<8aese>ZEZpp=FrTsBn~_oI0|SV>!7ucI8N_(N z#rJ^~EY8NjE!d+!L-`7q+y{2B2nUh~Cs>4wfnWFoH<-!8z$@J2Kg0P7kHQCDum~Rm Y8_x%RFcWMC#3m>i!^FZkIbA6R0OpE$pa1{> delta 417 zcmccWdf1hBIWI340}wbL>PutT$ZIPiRH6XlLx2lItYIzB*VbTY|AC6%p$W*SkEz6WnGvFA%-Rqke@){Q?+mHj%MlWQ_qDcXD!}>}A$?AnU?p zPq`|_xXDN46u6Rr{3}3Ql(6}ooIRre$nqkP@*?Dg1$F=c delta 19 Zcmexv^xcSSIWI340}wbL+Q^kF2>?D11#SQU diff --git a/myenv/Lib/site-packages/pip/_internal/metadata/__pycache__/_json.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/metadata/__pycache__/_json.cpython-311.pyc index fbf86b7f623bb183277ff06a4d7d760c8a22b603..def166f8970a6af08b019a4ebb1a047f5eba7bd9 100644 GIT binary patch delta 582 zcma)2&ubGw6yDh%$tIiGRY8+#Nmh&24HB!>Luo7qQ$>im7%#ajA-jnwNw&P%3K0f z;JS~X$S0W%;_|PV&SD}X!eB8BHa!(Cpaw2VHI_#;6lGwU53|k7Ea|wQzkYMQQNIl({yke*04quDhq1renGB;&;F)kz#!?Wntzis# ze%f*?$(Sa_-G6p9X)ml1>-%x!Z?I?#*O2z`veg;0Y?A+GA9=d`OxtmuJNpIipy2J> z)wt delta 511 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 delta 3002 zcmb`IdrVvB6~OOz@dH1=7(aL!+nA>VaUPJ6Vnz#?L>*CRL=sUe2pR5$IJJR%b`pXT zff&npKIMYDinuto>sZ+7?)?E%O$&+oWvG9}``pP0F@x=UfBg zq3y5v`u^_u&N<(?=YHQg_ujt9F1^aKzn_(*7x35m@x}hy%1hb#Z2VH?#Qr=cNP?t| zfu62*Ue#rhmchip`9++!+xqcrIIZC>9G^taAB= zSvwV*4Q+P0a)Yf_Vx59F?@J1Ez^jEHv+u$o@ja%2XJVbz5(vlQJluOS9v&JzBJ&tt z5<4<_8S^AwR}G2G2P*9>+nM-**2kC`ewTTW?MnD`GGk5fy8aE;3_imo3qZo~7TX60 zjptca;-T?nCVE8pYL9nJEo&uF&g@r7nn~3R=J0;{d5}S!tdX>`Udlut-LhY%q~GLc zKtF?Ql#I(h8Yyd&PnMjG_c6)Zg4Ou_qLf{@$uVce5uRncbmrAjg~|1Nt}?RVMDwP3 zR>fvRTka;CU9siCw8=h(+f#s)c{5dA=;_Vi)K)x1*hUHs?7`SeJIv58XoQsM`Uh;{^HVoCWXz)DYAYp`X1{R9_ES@kr|ITVD+Ix)G<0ZxrZoZX#NIhy> z+eW^~P+y4p=~bw6->S|1DZ-@P!Df>~HlHD9nH?7>p`4Hz5@YvJNuEXxqISs8mDxQ@3 z*$iwiyHY)YinR#?jz_KQ5_p`f+x$3PMECP>w%{HY1uHyv$CPCR3 z3p8%~A^QZLZ2NahN+XZNc_`Mm`np3m6`mP*etiRRRXEG|o;a=h@=s!us0#?`cgp1o zJ50M(uvBDcXJOb=nstty6^^gOgD+|-;ek1~fP&WI`E?VbU0@Vg=*~aKV28ir#UsL1 z#)Jz6lF%veI`r_0O6jEZu~5I9#9QZ*uKGE)=xRv18q&(OBo$*ez^A8bNXYz@YVJ^qKqA9&Mq*n60T-(t08yXx!U>6(AOM<9t zd}wo~?{#l4UKgG1Nu;ekX=|U_`@mN8Yg^SXZB?_@n}tbl!=lZfwE5v$?G|vA*J&s; zmRerjzOv6L@bc@yWVtY!G`SZt-AdvqwX$w~BE00bs$0v$5|* zDR#+5XqY;{-ieVqz-Hs=>;Iw{V2S&CS{eHkEDc-OpP;GXEbE0IHPncY1^BYz4NWgS z_b*_|Un~AafV=+lhI!H``*;XC8{5Rc3W+xxKV!MH<|}V8`V#PI7;8Ep{!K{SZ~6w) z{EAfbko&?(Cc@MUAG9oxf=YpZLMSBsoS^Klh9spd7D-aJO(~GiXs85B!AP@%JxW|@ zu3?^=s7@K>Xeb=<4TrFuc}g1@8W;!<4)7pNIR}4i`H)?Pw_BYC<&%~}S~L8#)x&b( zajR2fA%zvP11_tLMEY{3RJ|dLMR$hAKrOog!-3uU$2g?-XRH%$1^ny*+-|eNM{Syo zr)EJo@`X?i-)!^4)i(Z;mWfNk{|~v)vG;Uim&gKaN%-%V1xx8yY4elyUZ+&>bZ`BC E0DXVqXaE2J diff --git a/myenv/Lib/site-packages/pip/_internal/metadata/_json.py b/myenv/Lib/site-packages/pip/_internal/metadata/_json.py index 27362fc..9097dd5 100644 --- a/myenv/Lib/site-packages/pip/_internal/metadata/_json.py +++ b/myenv/Lib/site-packages/pip/_internal/metadata/_json.py @@ -2,7 +2,7 @@ from email.header import Header, decode_header, make_header from email.message import Message -from typing import Any, Dict, List, Union +from typing import Any, Dict, List, Union, cast METADATA_FIELDS = [ # Name, Multiple-Use @@ -77,7 +77,7 @@ def sanitise_header(h: Union[Header, str]) -> str: value = value.split() result[key] = value - payload = msg.get_payload() + payload = cast(str, msg.get_payload()) if payload: result["description"] = payload diff --git a/myenv/Lib/site-packages/pip/_internal/metadata/base.py b/myenv/Lib/site-packages/pip/_internal/metadata/base.py index 9249124..9eabcdb 100644 --- a/myenv/Lib/site-packages/pip/_internal/metadata/base.py +++ b/myenv/Lib/site-packages/pip/_internal/metadata/base.py @@ -8,7 +8,6 @@ import zipfile from typing import ( IO, - TYPE_CHECKING, Any, Collection, Container, @@ -18,6 +17,7 @@ List, NamedTuple, Optional, + Protocol, Tuple, Union, ) @@ -25,7 +25,7 @@ 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._vendor.packaging.version import Version from pip._internal.exceptions import NoneMetadataError from pip._internal.locations import site_packages, user_site @@ -41,13 +41,6 @@ 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__) @@ -145,10 +138,10 @@ def from_wheel(cls, wheel: "Wheel", name: str) -> "BaseDistribution": raise NotImplementedError() def __repr__(self) -> str: - return f"{self.raw_name} {self.version} ({self.location})" + return f"{self.raw_name} {self.raw_version} ({self.location})" def __str__(self) -> str: - return f"{self.raw_name} {self.version}" + return f"{self.raw_name} {self.raw_version}" @property def location(self) -> Optional[str]: @@ -279,7 +272,11 @@ def canonical_name(self) -> NormalizedName: raise NotImplementedError() @property - def version(self) -> DistributionVersion: + def version(self) -> Version: + raise NotImplementedError() + + @property + def raw_version(self) -> str: raise NotImplementedError() @property @@ -385,15 +382,7 @@ def iter_entry_points(self) -> Iterable[BaseEntryPoint]: 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 + @functools.cached_property def metadata(self) -> email.message.Message: """Metadata of distribution parsed from e.g. METADATA or PKG-INFO. @@ -402,7 +391,9 @@ def metadata(self) -> email.message.Message: :raises NoneMetadataError: If the metadata file is available, but does not contain valid metadata. """ - return self._metadata_cached() + metadata = self._metadata_impl() + self._add_egg_info_requires(metadata) + return metadata @property def metadata_dict(self) -> Dict[str, Any]: @@ -454,24 +445,19 @@ def iter_dependencies(self, extras: Collection[str] = ()) -> Iterable[Requiremen """ raise NotImplementedError() - def iter_provided_extras(self) -> Iterable[str]: + def iter_raw_dependencies(self) -> Iterable[str]: + """Raw Requires-Dist metadata.""" + return self.metadata.get_all("Requires-Dist", []) + + def iter_provided_extras(self) -> Iterable[NormalizedName]: """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. + The return value of this function is expected to be normalised names, + per PEP 685, with the returned value being handled appropriately by + `iter_dependencies`. """ raise NotImplementedError() diff --git a/myenv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/__init__.cpython-311.pyc index e0beb4885742e8803def84b635c194e998a8ebc2..56d84dc4ccf3dd8aad532e402b34405eceaddfdc 100644 GIT binary patch delta 19 ZcmbQiJcF5QIWI340}!~J+{o3(2mmU`1Y-aI delta 19 ZcmbQiJcF5QIWI340}wbL+Q`+%2mmUd1X}{a2c6IWI340}!~J+{pEr7XUp11{a2c6IWI340}wbL+Q{{p7XUoj1;zjX diff --git a/myenv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/_dists.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/_dists.cpython-311.pyc index ddc28d477ef3c64d80ef7bfb85b6a778db662be6..6d6972b03e8b9f5d236cecc6f7ebc291ddc72867 100644 GIT binary patch delta 1729 zcmbVMYiv_x82-Lt%Gk?DXEXUAOMSHVV$+WJI%&m@p*d5JR?|4p@3NI4xcl zaQ-N9EYpZ@0z(Nm6(`dK(n$E>1%4?}<2ITQn;3{D{xC5dBK+}>e%~3DEs;Nd>3P2A zeV^z3uIF?i|Mx-j$7ZvDNbA4(_UPbovm19Gk4;WFF_MvN$gWfBC6~^PS-0YmJc?KH z>Ty-JK@lZU@ku_#FZq>#6wve4*`N}VLOK_+VI?9(bY7Eodxb98D*g|7Lq)2ea1`FhEYy- z6*x&G+?NsD|2jyOo8s5m-UeT}FW?p!@@$8P9$US!GIQQm zVF-;?gXrxrs$r5!2%vad;H+1vxkth`kj8PY8ig4b9~Sgjbx8zC*WSo$`xH~h}N zF7`$j-?s^-#EffKstNVu!<;j($Rw-A=N^)j>Id^Lvvy-LT;9^x!jgySp2g#Tl z)W{k9dC?aA5aVmbtBu1L-vD>~7XAkQh(EyJ!7qt4JQb@pZ6hTok&FxIFoG{z1MosJ z1XD@pItLN{Y}VDiM0?401m`h~$2^;kGqd(Vq^60Mz$#ruf>Aq3SLQRX=GCDbLwF#d z(yRPS=*f~jj7%s8dMCT!Qd4j+)svkV8Or8*38_dWV$HP?AjgYXtMC}^TGu^fk=Zww zSu#aRrijL_k@YQ4!bsD;)?0Lp?v*i^is`OfJT2aKrfyhiPpi-ZVQ}ASwb`1F>Z{j$T|KPw-cSj7|pgG#N!#b{?<-hF79Y`Vf-s7ZG8hqbsx#A=PA?>DD(7| z52*7r@d-_^L*uU{c$Iz@>IXDYH8L@tC#Rb$3u@-z9_k<8t1iI(wylPrh#|KOJ?)+0 z>S~XM2uu$=G$4m>ZtS)%wd_kR`Pxdpwk3Oe$=(h}+YcEXD@MQ_&tp3bbZi~6(5a>= z%uuK!Q09gwCbH@*jSUpur7%c=o|a1A5cMR5Qxx8#@IHmp6fRJpe?s~e)ytrD1hEMA z^|#Uneg~dAq#@eRZ&~RVJNsA2YP`=PgRQVzW2jTJg4p>ZGglAyI>jh5STqLnp}9c~ zk?t|j8cSi9E`rc?N#JQ-FfUwQ|7opGue-iYmil(;{0RWb zZXZ4c1Ko?b7MvTx1}oi}4K{BGLT1C&ny*QS$&)iM(3t+-+P;X^{6I@L_wbm}(EkGy b3~zk%*{uvFi~nz2bcFBg(t{@$^iSm5YNS$;`$WQMYND=s!z_x+Rz_S*tZp77}Cp!z@`+r)I`wW9PnFi){Y2oA-X_ z+;h&o_uS9sV(0c}oq#O^erYT}C1>JkuiPuIuXZE<(oHAP#3O~s{Kq%~<7#i382Une`ucJ{s__JA&)qy|Q$_f^U=NattS zCYFJiReKlbyU(=neX0JJKMu`;?SRMo(VR+?9zUr$=v;1F%O+emt;?=imqi;}XRI;n zhPZV@f&VF6ze^xeP9jUA0+qMp}Ar5+cTEdHN?P1v=S^D+`xkIw2n_~>)V97!s zIj<}t8kdQEHIzeYU9aG6WS47;;z{;OKfIaS`vU!|NX%7-e~HMei!r`K%r#98d3u?| z97sVtLvfbkbAXdeF5MU8gBl(Fnw+j#E1v~>@O$#8rfx|_mM(z+2iMPOjAOo-#u?W* z$?HpZXQ+}cGPAT5tBKmZwv)ar;z5c6z^tsRug@PBB42Z%8un^W>tt1Q(NA?(2=2+?#l8cLGs4wK^%Ib!(E!Lf&VQTs^!c!O+M= z0lE9qPo}803LYlTod%7{9p0Q^z)Jq8Jw1fE6{mWpf)fE6vtlviGA{d6Fo8f!g(R^U ziYyKm4ltE{uJ)`-Qm2b&D&tKZlKw&@k2#sIE5xIuus(_pkfw%wGGCt~r|+$pNAem< zWNJ{!(uRvU)1c5-BltHazc>6yqRT4Q$uW~a{};KWq47ZT8V18O{+rQ!+kMIP@C5^g3lV+* diff --git a/myenv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/_envs.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/_envs.cpython-311.pyc index a390d053e3a4bab9be5557d8e94f5ce617199528..a50f65259502f715f1247ed053509d52a3e2e190 100644 GIT binary patch delta 39 tcmaEp_&SkyIWI340}!~J>`Rm1$SbbQs61I!S$VRjavh`P<`c>)ya4S~3o-xz delta 41 vcmaEz_$HBeIWI340}wbL>Pu7D$SbbQs4`hqS(#C9vWIdVqt)i)$|}47{wNDt diff --git a/myenv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py b/myenv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py index 26370fa..f65ccb1 100644 --- a/myenv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py +++ b/myenv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py @@ -16,13 +16,13 @@ from pip._vendor.packaging.requirements import Requirement from pip._vendor.packaging.utils import NormalizedName, canonicalize_name +from pip._vendor.packaging.version import Version from pip._vendor.packaging.version import parse as parse_version from pip._internal.exceptions import InvalidWheel, UnsupportedWheel from pip._internal.metadata.base import ( BaseDistribution, BaseEntryPoint, - DistributionVersion, InfoPath, Wheel, ) @@ -133,8 +133,6 @@ def from_wheel(cls, wheel: Wheel, name: str) -> BaseDistribution: 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 @@ -173,9 +171,13 @@ def canonical_name(self) -> NormalizedName: return canonicalize_name(name) @property - def version(self) -> DistributionVersion: + def version(self) -> Version: return parse_version(self._dist.version) + @property + def raw_version(self) -> str: + return self._dist.version + def is_file(self, path: InfoPath) -> bool: return self._dist.read_text(str(path)) is not None @@ -206,19 +208,18 @@ def _metadata_impl(self) -> email.message.Message: # 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_provided_extras(self) -> Iterable[NormalizedName]: + return [ + canonicalize_name(extra) + for 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) + # strip() because email.message.Message.get_all() may return a leading \n + # in case a long header was wrapped. + req = Requirement(req_string.strip()) if not req.marker: yield req elif not extras and req.marker.evaluate({"extra": ""}): diff --git a/myenv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py b/myenv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py index 048dc55..2df738f 100644 --- a/myenv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py +++ b/myenv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py @@ -150,7 +150,7 @@ def find_eggs(self, location: str) -> Iterator[BaseDistribution]: def _emit_egg_deprecation(location: Optional[str]) -> None: deprecated( reason=f"Loading egg at {location} is deprecated.", - replacement="to use pip for package installation.", + replacement="to use pip for package installation", gone_in="24.3", issue=12330, ) diff --git a/myenv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py b/myenv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py index bb11e5b..4ea84f9 100644 --- a/myenv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py +++ b/myenv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py @@ -3,11 +3,20 @@ import logging import os import zipfile -from typing import Collection, Iterable, Iterator, List, Mapping, NamedTuple, Optional +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 Version from pip._vendor.packaging.version import parse as parse_version from pip._internal.exceptions import InvalidWheel, NoneMetadataError, UnsupportedWheel @@ -19,7 +28,6 @@ BaseDistribution, BaseEntryPoint, BaseEnvironment, - DistributionVersion, InfoPath, Wheel, ) @@ -75,6 +83,18 @@ def run_script(self, script_name: str, namespace: str) -> None: class Distribution(BaseDistribution): def __init__(self, dist: pkg_resources.Distribution) -> None: self._dist = dist + # This is populated lazily, to avoid loading metadata for all possible + # distributions eagerly. + self.__extra_mapping: Optional[Mapping[NormalizedName, str]] = None + + @property + def _extra_mapping(self) -> Mapping[NormalizedName, str]: + if self.__extra_mapping is None: + self.__extra_mapping = { + canonicalize_name(extra): extra for extra in self._dist.extras + } + + return self.__extra_mapping @classmethod def from_directory(cls, directory: str) -> BaseDistribution: @@ -168,9 +188,13 @@ def canonical_name(self) -> NormalizedName: return canonicalize_name(self._dist.project_name) @property - def version(self) -> DistributionVersion: + def version(self) -> Version: return parse_version(self._dist.version) + @property + def raw_version(self) -> str: + return self._dist.version + def is_file(self, path: InfoPath) -> bool: return self._dist.has_metadata(str(path)) @@ -215,16 +239,15 @@ def _metadata_impl(self) -> email.message.Message: 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) + if extras: + relevant_extras = set(self._extra_mapping) & set( + map(canonicalize_name, extras) + ) + extras = [self._extra_mapping[extra] for extra in relevant_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 + def iter_provided_extras(self) -> Iterable[NormalizedName]: + return self._extra_mapping.keys() class Environment(BaseEnvironment): diff --git a/myenv/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-311.pyc index 9f70ed4669752649e89059b024ce790b193f9f51..290f54d64c4e5c0d7020dc6f3581a3192c8a7c9b 100644 GIT binary patch delta 19 ZcmZ3?w3vx&IWI340}!~J+{h)#2mmWc1Ofm6 delta 19 ZcmZ3?w3vx&IWI340}wbL+Q=oz2mmV|1Nr~} diff --git a/myenv/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-311.pyc index 7b4b61071089f99b6f3843b4d1fab6b52208bb93..a1fe43e1938421ad04c301fba7be7ab69f0783e1 100644 GIT binary patch literal 1861 zcmbVMO=ufO6rR~Xt)wU}iDJirluc+!)uwAoO%KJG);1KG#E>{Ctq@%{nvuKqYFC|E zr&#!)K+dIyf(@Y%T5uEGLJmFT*h3HPZ5<313k5?@y~(&IpZaE25|VLC>D!q%-@JKm z_x;U&S19BV(88}@)DIPe{t%l!={;~10oXzW5$vM|u3#*%;wufcqDrg+)+)Nhnr}2R zl?+A-qL}F48#@@GU6?5;=mSJD4-qkU;Cs6;Q`&)Lx4%IZlVq1sDfg$4lyH(IZsgW{ zmvh);KBSC$VE|BXx{Ol*+6^yQy92>j+Tc|H%--hc698L?q6#LcqTGdmD(VV^ z@(r$NRHp_}XF!8y0BI7LfOLU~N_7G{M5iV(NTzNQ^PyJB5`*e>g=7KeNJhAvTqp-T za(&;8z{hzvARahRThq5`lTl8Ch+D4J3?o3E>swcAeU+ z*h#|w%}$B>%>q`N%4o^|*BjMM^`sp^kY8=-MDQgwF~WPRv=$|K$Kf<`qlh_9Qjo3T z^zv5H5{*;8e!`fGgjqnx-u%1OyBv~SUH;Vl-1Vyql&?i$vs%8nFlQ}`Vl{wS?+32G z!98AWY|!9-^@ew^%Dsrb*>r1b?h57Arq`Tuyda_sG^ZLNp+27))YxurB&GxBUgS8f zmrrdKyMKNjoZ}w>Yop)Iv%i^_UYM7*ryq|$Dejr}zG=s%JuIL6;pX#ed)Mdoug~q7 z^ZVv}Y|am#58Ht$j3anAstq@T0Rq`H?*Q0>mRJ=kk{&709%yx-{Rl1&><2d(_UhM$ zEK#dy4I;K)>y^N2X_gyV$GF7AKc|G5j8DAJVnyId2I?nj*Sh>qd6CB#L6=_x)<&Ik z<6o8Hv0E^nP5(HPqMz>k{Beo|H*c|V&@JUf-o;&l-pDx)6lUEQ_>ALxw(k196L5iq zH4taP7e9& zJd(>vmc#mOynVil#QN_%^;vkiRLUm#!Jn3LCORRx3>|I5Jqk$3?6l3jV8!lLHO+&# z{p_63o|M}C{0tf!xQ^>qN|Kyk(<-`p_Kn6`JsxGi>F%1ApQmx CI?40^ literal 2099 zcma)6-)kI29G|(}z1zDc&DkbRQjM&&U{}qhVDO=a&@@2_rhzss;&HgFH*;~Dy}fg0 zQ=2nF9s))PK2;j1LQsee=|dlU@Ue)0z*!1C777LN!M6+PgXGEY%fBf9tok7qhfBUxdlY-EnLTNQE687E);SM5*U>B8fK7oataFw!}SEa1DS~;0d zVw6B1Afm1!qS53QoVNr2u;o)EIfu;D-$FHUpjBw(nHDN!ue1v3*(_y-KT$a_afqu#IZP z2g$Kr<4m!&p{ z)@p)#!QI|NfbZ}fw2YUL1#;N@m{)|B6I&RVhJV;#T_Tnh(BieexH)QD(C@SqwAu1? zJR*c;bR*V5esL=<&3Qx5xF5Y86TiJIeFBGnG za6n=1Gy4nMElg3q;8&`J>C01>j5*=RGJrAR+3pf|c%i&Ry_H zkN)T%e%wC{YF9M+m)`wNYCZKtA9$n>G+yevJ-9LT{mi|y_sx2C^y$mzn;J?F?jj|f zc`l&Y343q@D#kGZN*qzMpg=a`P3ZsIz|ZlnqkP_(+0wr?bL`M}pZoGP_SM_Q3pB?~ zHAq6Plx_cj|F$tZ2?lX-zrp$dh2I%uo@E_PYdC*OY%~FY)t(DadL|zAOf(c^e zq_mq-v%nQV6RGJ86I(hMO2UB5xpzT;jBAVjyHI1=nYjzqrkx$ol^;ZXQ)g?vMjRBz zxhSHInrhg-v5!qAsu&vtXn$u4Le>}096FRmh#omTB(}W)0Ixi8>b6<$xdPvV(OEX5CKMo~<`W5*`sA@o?C`6VOWGo9JchMDcmt}pvXuHu2m_RB;7=|q3ZpG&yDsU?k zWl4rMJ1rz(L(m;%T9LZ0Wto`u!l-=EMd>)1rV>QH@@)W!_tvkWj@Q-kXW6&v@>`j1 zs=Aihm}?^F?!6%oAu7Gf!?cke$8Y*7E~OL^;gdC%Bkl^EReSS E3#Iw}{r~^~ diff --git a/myenv/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-311.pyc index 8cb31a5ee1ada10e6e143351dc1dc832e3beba9c..e91121d967de01aec488c63d77df928c8b06cc87 100644 GIT binary patch delta 4297 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 Rul_u;#vVUGM3eWA{{raFs2u1OPAq1XTb4 diff --git a/myenv/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-311.pyc index b7e4fb30849bdc4d00606414239b071518c8a48c..7a09b9ae0dbdce65de232c05b101aef996d32795 100644 GIT binary patch delta 19 Zcmeyv_lJ*bIWI340}!~J+{jhL4gfkF1uFmm delta 19 Zcmeyv_lJ*bIWI340}wbL+Q?PJ4gfjx1tS0e diff --git a/myenv/Lib/site-packages/pip/_internal/models/__pycache__/installation_report.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/models/__pycache__/installation_report.cpython-311.pyc index 8bf7316dc4474295e3bd5ec95f30cc8d7e30c69f..0a33f1637ad78bbb9321a758f6dd3cee466c571c 100644 GIT binary patch delta 19 ZcmdldvQLC-IWI340}!~J+{k6Z1pqO(1b_el delta 19 ZcmdldvQLC-IWI340}wbL+Q?`=JAS8UBhz<1y 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 E3m*?0*8l(j delta 6243 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 diff --git a/myenv/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-311.pyc index 122118973030b9b1a830c17886afcde229ace62b..bdaa0914cae584efcf570f185031b9acd25ef902 100644 GIT binary patch delta 672 zcmaKp&r2Io5XWcU{>UcFMy1+B=)sDY;2+S7w6qA45^_leS%k3UJ*$u(_%^-dlBe|G zK}sbDui_y^;-AoepwL4K9waBBr`}fLsVC>H*^ra7Z@%v{Z|3a|v&Wg!boYnnWq@q+ z*SEcQ4B)R060;^S-X%B(4nA(e$!f;9LhcPdawpY8m7@lPKYaFpgjJE+xzFf8WF47xv6(! z5{y3*oPz)#sYkX=UHXPFeM{IP#n}dBV=|^>PRW{*t%;|o8E0fyYWt!gI_>u>m0Irt z50_0!N<9#1Ye{KwNXoqvqm&=bRjWa>*=h&vgH|)FRL7i9m}33$Il1&YM>yRXQr&J_8v~6;<(wTovU~@_}-}l5-S{-028KH)Cae{V1j@6IMF0Q* delta 746 zcmZuu&ui2`6n<|qlP1~hraxA?f~eP}B0YJM9_&GcvVs+qTyogS+Cp1#(q2kn7wKWa zQji?>?m;R33!eN7Jj$L#{{Tng$&>G8Hw%Tn$@|{-&AfT@W^(So4PJg~HUl8r{(3R^ zDFA-4s7=mEd5_2hG{o=XEG*6wS%I>p>(J~@kX?VQ`e-& zC+4Wvcjv`9a6_C@?hs5M#~c!3Gs^`jTquXs;sUuO#XBp@6{-3e=mF?>>={n(x>K2@ z2Lom5P8u0EaJRDJx7d3=^^#=&X#Y4#PNUuaUV50`uP4?hGut2-fnA2qov}O*zpvlE zCbT;=>5plYln%u^u`@I+VwYed3Z}{6*T4^)Wdx(eutF%$0)q!Dw?YA<10?@4*sD;T_#eNQ BkD34g diff --git a/myenv/Lib/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-311.pyc index 6692b2e0eb2312ad1fbf004963919b29ccaa9128..7cae9c787543beec0b9b827a67da8b7aca9d3aae 100644 GIT binary patch delta 1371 zcmZ`(O^6g%5Pq-!rsrpO{`Oar-Psrzo46AX8i^2LE zR1bpnKd+W}O*q#REzQ&|Om4_#NhrBatM6x+!Ht%}%&VH6Wod4JJ(8xS!L2nr$Fg{@ zZYDIEY;L6@s`6I$7;Q-{x3_13>nY7x`C(=QOi1WjD*+J(UN1>VatVlCueE7m>N z=V4qHoH@;ikF$pBGyWCk3dN$lowI0F{+ByKmj`>sPEl$Nu8e;`jYW)Il(+K#F6~A2 zWkveMwIJdGKhD_XK1=#!sR9|Xip3oOEmT2NDt);7--XYpkRKKs)RI3IkIjD!CxG7# zTS5{?NAb^!CumPDmv+C0y@GbCVI-1n0c#(!Fu^OV)x(hGr_xdSg}h%nt0Su}m&*HB zg@(Z6AmV(Z;rM;6xiL^h%R-Jrpe;u!aK=8c68lt4JHf& z@*S_%2^janS~78A$TO3bb_$s@qp-Ee1ysiko5I8r(uhg7dGsk1#)UY6&I*d838Rg9 zY953%YaTx&Y=GeZPdHEIy~(A*!X_Dc&u|4FAGDjubW=|l47 U?a}b;$#8q55@qI1#AIO40Un<^-~a#s delta 1366 zcmaJ=OKclO7@pae*Iqkz>@`VRk-BP)wS=Z1p&p>3DM2Ad#iaG6_+nho*l}5V&Fn^n zC{laKp+X2$22{>Slp-#uzV?8sA}&Z=sDxHMAaMb4F$$-g`2Wd+L;_~D-~XQfF*Bc@ zdUUGtWhRp%uofSD*g26WD9?S51zk63HciSoz*C4 z&Lpn41 z(aO>5wf5d%u@Rh*4*%A(0Jq5o-5^cicGiXl(*ATebddHZ%1E7jMQcJ8VZ=tr{f;l-#%Xf2eAD-uaEAhS17HFG81R0bsD$M%4+tHb7zqK zry%p4wIJdGhZoy?z|_fly1SSE#*g zo5z1~r#~xvQXQMXk1bN1QBndWn-r$TN#s%_H8FOOBZtBL*sU+9Oqj$gifJHm!VkLL z-k>X7%)EfAG#r%QyD~p)iIA&fh^^?oAv)>u3->rR0xZxVqZHUIzs diff --git a/myenv/Lib/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-311.pyc index fa378a9986ea44db11d75d7158c5133021ecf452..53604f7544b2ab671487354311f2d20015cfc901 100644 GIT binary patch delta 41 wcmcc1f0v(kIWI340}!~J>`S}9k#{*OqtxWBtlJnlHs`QeGcs~bUcqh(00nLg1poj5 delta 41 wcmcc1f0v(kIWI340}wbL>Psu$$h(}CQDX8|)@_Vzn{(K#85!9ouV6O?0QwdSi2wiq diff --git a/myenv/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-311.pyc index 3a9ab829800b183411cc295119a63fef86688ec4..8f1b5fb70b848a7775bbdb3f71ad4c5fa91e9b0c 100644 GIT binary patch delta 132 zcmX@0c|enQIWI340}!~J>`Pm}k#{x+qx9yL9IZ@@UW@g)85u(+8}J-qblLosXA=`+ r#O4+JhZq?PCua*jW@OszFJ#1IpU=ps@__+6`4KGs1&3^r63|)z_=6+R delta 132 zcmX@0c|enQIWI340}wbL>Py?Ok#{x+qs-=&9IZ@@-i!6Q85u(-8}J-qblv=wXA=`+ r`N2e$Xme9sJXe0U51fSeDiFMHYP^>$x7UPjJlgQa%V9! y+E13@-^6IR`8>Zd3uDM+W|38l&YRbX6fiPIOqLfr#mKw)mDqYlMvlp|Bzgd;z#4!6 delta 94 zcmZ2xw9JTiIWI340}wbL>Pr*Y$Xme9sIj?@U51fSZ1Zf6HYP^B$x7UPj5?b)a%V9! y+D(?>-^6IJ`8>Zd3uEwPW|38lPMg<>6fiP|PnH)u#mKYymDqYlMz+bbBzgd)O&V(e diff --git a/myenv/Lib/site-packages/pip/_internal/models/candidate.py b/myenv/Lib/site-packages/pip/_internal/models/candidate.py index 9184a90..f27f283 100644 --- a/myenv/Lib/site-packages/pip/_internal/models/candidate.py +++ b/myenv/Lib/site-packages/pip/_internal/models/candidate.py @@ -1,30 +1,25 @@ +from dataclasses import dataclass + +from pip._vendor.packaging.version import Version 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): +@dataclass(frozen=True) +class InstallationCandidate: """Represents a potential "candidate" for installation.""" __slots__ = ["name", "version", "link"] + name: str + version: Version + link: 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, - ) + object.__setattr__(self, "name", name) + object.__setattr__(self, "version", parse_version(version)) + object.__setattr__(self, "link", link) def __str__(self) -> str: return f"{self.name!r} candidate (version {self.version} at {self.link})" diff --git a/myenv/Lib/site-packages/pip/_internal/models/direct_url.py b/myenv/Lib/site-packages/pip/_internal/models/direct_url.py index 0af884b..fc5ec8d 100644 --- a/myenv/Lib/site-packages/pip/_internal/models/direct_url.py +++ b/myenv/Lib/site-packages/pip/_internal/models/direct_url.py @@ -1,8 +1,10 @@ """ PEP 610 """ + import json import re import urllib.parse -from typing import Any, Dict, Iterable, Optional, Type, TypeVar, Union +from dataclasses import dataclass +from typing import Any, ClassVar, Dict, Iterable, Optional, Type, TypeVar, Union __all__ = [ "DirectUrl", @@ -64,18 +66,13 @@ def _filter_none(**kwargs: Any) -> Dict[str, Any]: return {k: v for k, v in kwargs.items() if v is not None} +@dataclass class VcsInfo: - name = "vcs_info" + name: ClassVar = "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 + vcs: str + commit_id: str + requested_revision: Optional[str] = None @classmethod def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["VcsInfo"]: @@ -139,14 +136,11 @@ def _to_dict(self) -> Dict[str, Any]: return _filter_none(hash=self.hash, hashes=self.hashes) +@dataclass class DirInfo: - name = "dir_info" + name: ClassVar = "dir_info" - def __init__( - self, - editable: bool = False, - ) -> None: - self.editable = editable + editable: bool = False @classmethod def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["DirInfo"]: @@ -161,16 +155,11 @@ def _to_dict(self) -> Dict[str, Any]: InfoType = Union[ArchiveInfo, DirInfo, VcsInfo] +@dataclass class DirectUrl: - def __init__( - self, - url: str, - info: InfoType, - subdirectory: Optional[str] = None, - ) -> None: - self.url = url - self.info = info - self.subdirectory = subdirectory + url: str + info: InfoType + subdirectory: Optional[str] = None def _remove_auth_from_netloc(self, netloc: str) -> str: if "@" not in netloc: diff --git a/myenv/Lib/site-packages/pip/_internal/models/link.py b/myenv/Lib/site-packages/pip/_internal/models/link.py index 73041b8..2f41f2f 100644 --- a/myenv/Lib/site-packages/pip/_internal/models/link.py +++ b/myenv/Lib/site-packages/pip/_internal/models/link.py @@ -27,7 +27,6 @@ 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: @@ -179,7 +178,8 @@ def _ensure_quoted_url(url: str) -> str: return urllib.parse.urlunparse(result._replace(path=path)) -class Link(KeyBasedCompareMixin): +@functools.total_ordering +class Link: """Represents a parsed link from a Package Index's simple URL""" __slots__ = [ @@ -254,8 +254,6 @@ def __init__( 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() @@ -375,6 +373,19 @@ def __str__(self) -> str: def __repr__(self) -> str: return f"" + def __hash__(self) -> int: + return hash(self.url) + + def __eq__(self, other: Any) -> bool: + if not isinstance(other, Link): + return NotImplemented + return self.url == other.url + + def __lt__(self, other: Any) -> bool: + if not isinstance(other, Link): + return NotImplemented + return self.url < other.url + @property def url(self) -> str: return self._url diff --git a/myenv/Lib/site-packages/pip/_internal/models/scheme.py b/myenv/Lib/site-packages/pip/_internal/models/scheme.py index f51190a..06a9a55 100644 --- a/myenv/Lib/site-packages/pip/_internal/models/scheme.py +++ b/myenv/Lib/site-packages/pip/_internal/models/scheme.py @@ -5,10 +5,12 @@ https://docs.python.org/3/install/index.html#alternate-installation. """ +from dataclasses import dataclass SCHEME_KEYS = ["platlib", "purelib", "headers", "scripts", "data"] +@dataclass(frozen=True) class Scheme: """A Scheme holds paths which are used as the base directories for artifacts associated with a Python package. @@ -16,16 +18,8 @@ class Scheme: __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 + platlib: str + purelib: str + headers: str + scripts: str + data: str diff --git a/myenv/Lib/site-packages/pip/_internal/models/search_scope.py b/myenv/Lib/site-packages/pip/_internal/models/search_scope.py index fe61e81..ee7bc86 100644 --- a/myenv/Lib/site-packages/pip/_internal/models/search_scope.py +++ b/myenv/Lib/site-packages/pip/_internal/models/search_scope.py @@ -3,6 +3,7 @@ import os import posixpath import urllib.parse +from dataclasses import dataclass from typing import List from pip._vendor.packaging.utils import canonicalize_name @@ -14,14 +15,18 @@ logger = logging.getLogger(__name__) +@dataclass(frozen=True) class SearchScope: - """ Encapsulates the locations that pip is configured to search. """ __slots__ = ["find_links", "index_urls", "no_index"] + find_links: List[str] + index_urls: List[str] + no_index: bool + @classmethod def create( cls, @@ -64,16 +69,6 @@ def create( 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 = [] diff --git a/myenv/Lib/site-packages/pip/_internal/models/selection_prefs.py b/myenv/Lib/site-packages/pip/_internal/models/selection_prefs.py index 977bc4c..e9b50aa 100644 --- a/myenv/Lib/site-packages/pip/_internal/models/selection_prefs.py +++ b/myenv/Lib/site-packages/pip/_internal/models/selection_prefs.py @@ -3,6 +3,8 @@ from pip._internal.models.format_control import FormatControl +# TODO: This needs Python 3.10's improved slots support for dataclasses +# to be converted into a dataclass. class SelectionPreferences: """ Encapsulates the candidate selection preferences for downloading diff --git a/myenv/Lib/site-packages/pip/_internal/models/target_python.py b/myenv/Lib/site-packages/pip/_internal/models/target_python.py index 67ea5da..88925a9 100644 --- a/myenv/Lib/site-packages/pip/_internal/models/target_python.py +++ b/myenv/Lib/site-packages/pip/_internal/models/target_python.py @@ -8,7 +8,6 @@ class TargetPython: - """ Encapsulates the properties of a Python interpreter one is targeting for a package install, download, etc. diff --git a/myenv/Lib/site-packages/pip/_internal/models/wheel.py b/myenv/Lib/site-packages/pip/_internal/models/wheel.py index a5dc12b..36d4d2e 100644 --- a/myenv/Lib/site-packages/pip/_internal/models/wheel.py +++ b/myenv/Lib/site-packages/pip/_internal/models/wheel.py @@ -1,6 +1,7 @@ """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 diff --git a/myenv/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-311.pyc index e9336f56d43b8971f244d30f9bd50769230c46b4..83bed51e2e296bdd4588f32259d4634e14033f23 100644 GIT binary patch delta 19 ZcmbQvG@XfSIWI340}!~J+{net2mmR71Kt1t delta 19 ZcmbQvG@XfSIWI340}wbL+Q`Mr2mmQp1J(cl diff --git a/myenv/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-311.pyc index 8d4897b3edfa01c5ac12a76105e1e9926c0833aa..a71bee3132ca58506187999c0fbb2e171f01485e 100644 GIT binary patch delta 2330 zcmZ{ldr*{B6u|eeFIW~@-cQkG7i9^Mmpq0D#vIY{2h2SRsS{V+hXRO39C7pJv9OiL)Nwh!+fRTXINk z6zZv}n#)eCHWu5+m)Qvkgyn?9S)_15I)vwq%X@tE)~S&287=+BCk0`8y~+TATJE~e<4U0b_a*jlU!^gxX~9vB13!oe)L zyp5hFNqWuAn%QD;@oBp4cswv1ms$eBiK&({|4fR&L0E%UQ{oMg`!PQ9 zBHYHGBFFHRm4P@M^>Rur4csIK@-wS-Xcc{Hr>D!SPNsKmcRAY}zKl+l)nQ6>WG-F3 zVsLdj-OVnCUfu6pAaUeKfk=9ec_CEu5TbA(+H63w?!hzBn+?~4vnGSH&>WL%nLGS= znqm#^H-;pNJgK7hYQlnYC?_4EMLrZ022d`ajxE=N8)vMg{taYw6AG{>{;_`@iS>ky zSY{iBF??j(Z`jQh-I+LI565@yg;q*b#rUd=ZFNg7#ZpmHx1p@6w6VBsvbH(bEuMQJyqj9>{4o|zHb?tI0+778j(K_2(*&c3TJISo~GC&rKCa{8{*`pX|0wwl5RT!gXOpe--nnu?RZ%wKOmUR4wX@aR*mws6liz}V zJeur)W0+bSjkl65@DP7Xwn7^QrR2q(;sa)LlVbf(Zq5z)6EUSJLL6F$Izog&quC(( zr>=%4a#`vpU_VBhm4qIGsPBCwiM!iNQa?tf#lw4;pSB+K@`1DweZVl+JG6|FlOID# zwg=YYX!a%;Kyyw8^x>MEb%rx!{1gx5ltGMqBc~S(UyPCdO2a_f0{rMuyBsqau~(C&pTm4E-h_@XmNzXPn??QFQGJI z5HG#Z0ypKvvO#Unmo!|fMl32?6w-I(cb!bpiofJ-@^(p$RCnsSVlyIkv4%{}=QtGK zF4pd8Vv>tZk#3Z5f#A`TR84ow{?@BvN%l4|XKD?d$P@R!`hpcmH@GHGiWPD5WCgKW7%ki`?-NV9~ z1b)%mYPR_7m^&U3>(eQDVRdeEGtmpgZs*R2vQP2j73cDJTiu-w-GbE=y_30`r3K}4 zpVvqd*yOreBk=NT+7#B4#V2BBf{CEEAe!9Q!`vPh^X^vvd?`l7z&oYa#nelPB7czq z7fBL#5bf`u?i5H~SRQV_wHaFcM4V=22&;)4Emgmi@4a_Eac`{a@6Sj9xAe1mLt zgkC}e;Z4Fp4#mt9puKf#s+t6{oL*M}sp5L}k`GqEdS|5AS*Qa8Yi#vc~rVcP>?c{I;1k2mPxAMFG*y8r+H delta 2310 zcma);drXs86u^7>qLfyVQjvnZTltV8!n819A`cxRDhs-ah`~}32U71>Gv{>TbeY*Q zO*~n~d{!}YYT_^-hRr7<3o*t-=Uf)MIGmbIvupu%|G8}U+;3WK{9{e?>$&Hid+xdC zo_lWx&%n?bupY5m%^Lox7~HY4^rZEn9$X3-jza8Iu6!89(WSX%irKEiv&N63r|~w+ z=fEXVl~9QLqmqreyeS89Aj-8F43?m6M8ki2O<&pitU?^fzF2g0nd)fO$$(C@F6zU>g!J54noVe#(?HQ>M?#;sGJ^?1e1h;MfL@j`5asJ|6#^a2QhyVlkMw)VPRTEJkqH+`@;! zyUOQ%Q!+71B5NQlB{UM25t;}sILl$n3I~xwN^&4m0nzOL)kz($cQ}o^sAm)QI9@mP zdcKRBaXoIvuB4)xaN0%2%ed7GYh(d+)Da@8rG|8bmCDv6JMaqmEP1X0{CGEgPK=1w zPZl$AddB0J@M7w*H1imo#(SAtU<0nsS_+jol$FXi@Yk$8(17nbi;9G6Dnwq@?ffUC zZ|m^4hjhO6-jJ?CZVlPw9pdtn zG9&$SWu^}L3qNo-Cx|qxQLV+?G?Mk;KkicaTPe*u4q5w1BhF1rt;*r@I{;U3du2Xc#jh*pf`a<0_0X?usw#$bkrX@Ge@>tX*mw@f zpgQfxA7^{vTV=+a<=_y;!cHVjTyXI;q6hn4ZG~$}a`hn{oW~3E?29jx{u+65gkt1C zb6}mk+}qjWQ|A%Ei&%xvJ~BSV5i+e~?fzya``8WA^%H^wS}D7UIkkoGJvP<861S5p zc#Vpy=4a|0#uK&4#vu}~;?>#=<8>}>NX2Hi9j)`t@RKrO{z)zTf|nK+l-?$@@LvB$ zO^S!_=`$X=Le_CSJ=XVlV?&y7IlnH3?`uO{lXi7D8$sUBp8DozXU)n^^}ZL2ok-o{ z&gkM&D4HKCpFhynxkl1QOdB$InXg5TI3f4>d2nD!eJo@swe?Z3nd)0gj(mQ^Q){8Q z=zUfTxr|F8lb?0^eJt=c%cc&BJ7nY!M!?6^eMuy>D1vh&iEXlybcGO0_<$c-s&dbZi00b^4H*zt`0{}111W*6~ delta 19 ZcmeCS>$c-s&dbZi00hp5HgYk_0{}0j1V{h? diff --git a/myenv/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-311.pyc index ef0978d54214559dcef023fb0eaa3aa86f536f3f..5be73122c3c7c2c33e5aa68a3e32c8d34520da4e 100644 GIT binary patch delta 136 zcmccWb=`}1IWI340}!~J>`ObokvEftQDSpBiy8}~{N{NaZcL1xo1b!NF);>g7T`5t zW{ltLD4@v1Sh6`;D3g(~X7gF$bvveh+t!26y1DJshkM_Pa-8J delta 134 zcmccab=8Y^IWI340}wbL>PtJekvEftQG9bbiy8}~+~#>4ZcL0Go1b!NF){jY7T`5t zW{lhHD4@v1SiCt|D3g(~dh=P~bvveka)l#viX5hITHW?qa^qM diff --git a/myenv/Lib/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-311.pyc index 4bc727ff0972f0b182e128527c0d4a7f48e94f67..41737bbb89b7a7791659da47ff35f52fef1f197e 100644 GIT binary patch delta 19 Zcmey6`XQBTIWI340}!~J+{pFJ2mnP524DaH delta 19 Zcmey6`XQBTIWI340}wbL+Q{|H2mnOn23P<9 diff --git a/myenv/Lib/site-packages/pip/_internal/network/__pycache__/session.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/network/__pycache__/session.cpython-311.pyc index d923e4c5c9ca10ae07de5f13be0b7a77c4dfdfaf..d74385fc25c275506de5b5352b9ca959535e7909 100644 GIT binary patch delta 2523 zcmZuz4QyLi6@J%_W5&9M|rfr%vTUQ| zfTvM8{anj}S})cU0n8$$L2VQp)h4lt+a|@Wdc*^mE$`c8l1`xkU-6 zZDN}m6ocF@QQFlGv4eA~(y4~T5a%`}tVYBL=cP)Q+AVeiUm%iQxktTMyq61QN{`wr z_HtgX^r;)gjhs7_esw?`;M}QfQtuP*K1W}8Wp45u2QzD!{RUz zoIm$%Df zY?b&Hc0e7++|KnF$t6cFY*;ctJ-G9Q2(yAz`z#U1gKNPD z%>VJ15%=(z7EoH{J#y<(5oCZnU&I!!20(2CwfQd9!_^?D?Q+YK5o*F+sQC!jIza1` zJ$bF~j<}bLArQlIPW>D23s{bBgr#~tdgPo*lSBGP}?gB2JcTdja_IAna$NekQ&{7!i}HI?2H_?{Q;x@ zi0~&iFDvf*w{snx2ykc$^c}Q#@O9nMB@)Gu{+8p%y|yGLr`?)TCCV}PI`ABPU$@3UjQ`^XdQO0UPkdsL2r4G7nnr7u9v zu&%zwy1VnEj@jrfHrpqYnEvy=aYMz2=(!01iC;nf9~K&j62?*kzOsLVBUh}YvvgXf zAL!2ve9uTyZ0}G@_#a$J%+JdyiQdL~ZiJ5jg64c8tV{_Gzz6Kbp&qivt_^v}Q##qa zM(kKWXegeuc=G>fS=uOu_n!5)hT zyd~%|Dd{6JrDo*jBMF*Hre=es`P@!+IsOLuq5ie|j~WK~wtE^|HqjHTET>(FjTR)vfo9{+by-#{55 zs-N2SA?ZOH{51U)JaRT!O(d0YHj`8|`T}}NX0oa2OgatrcfqFcogq-lzP;V$)6o7B z!bya~0J+jERp7`C&nKuR(;9YT`zSf4-?PI@$guwKPCKzNjP+uyn|1B1VkgF%7jP=_ zJ;jlrVK8%LGf5>Q)582{v;!6R3K8faGT!~on5IOb*{SKo^g)^88O)C+`X(~I*l}Cs z%!LWy{pKf9euMRcxMrywRMS#ckvG#Z$PYh3`w0u~3RoSNg~CrC-(@jw6b#kJYgb6s mnFlWu_cC#>5cjI#03pSvVygl^{}=ym6bv37q0jH$PyP!ftbuv} delta 2439 zcmZvee{5UT702JT9XoM;|7c87Cw6S7juXdeOXDVOk~$;>rwL8llplLcP!r#zPTzB~ z`)mr)MDs^CKq`!K)HN`sO8iI%QzuOi1Y?Lz444?*23 zWm@1m@8j<|-*fMMzVG@vzx)Av`#38{AF4$jn6Bw5m;RjQTv zZq=&vYW48()&oqz(59`{-Ktw}Qk!I4q&4dv)ho4KYtenGPxq^S89OizsI5{LYisnN z8r0j=HW`;_A-!E~m)fay=wUT1b*a{=N7RVaWm=cMR$VJ~xprWkzFu7~g9`0heS^9| z>PoF!kE&6rtF(=JkJ=-3wbrX|Qa4Fmqixpv)IOdSkSV-c zl;HQ<&$6mD;yxt>;v8oyzQDasG=$~QI68~6ymT)dHQ<0Ej1 z`D;h9Q{~Lq)taP>M<8NpIB+9h#YY>irWL+D+1Q6sa-_2W>Z0O>p73_etThU&F zw)d)Ca6QruqT9v;E2g|jdLi`Mxo3rUv-CR93v>6(EwIPxa@?Arjb%3+)^=NQ^?PiF6IS`5OK>Jw}MPShN%_&Y7H=tn%m#29R;jk52+ zU9}!I2;Z&U;GMYYiknawRO}T!l)M=+?}mqJ>L01IuRcPlTL_yFIjfesGiO6gik;9> z_bA(K{({W`z~yRV`yl2DRMYG_UdBFL`UPd#X=Ysy6tO9|;_hY(W_Qz5tXB6c znE=)lT0jwd;6n4k;-oXb%OG9pf(JeAtQ21K+-}d=vYDwKsP~?1T*NNoQNk4AF~au< zkHdewDf{nG8UwJeS$}WS)KZT3&ZGX^tlqMvcf*1TBv7_dbfj2G8 z4tj7~NzS1s?lw~M99|B-?)nW?{+2*bHDnWSl3swtwqX1JytgTN5@Fa8UTO>Z2YU+R z`8F5}UQ?Y)r!sfU&CY6iBAuA#q7rICPqS0-VklzyTrock^)cp!){b55k8pQ~+aAFE zA>M_@I$pBpR|(YcH>>_cQ$0Z_B>xunw69E({gtkEECjndcl3`^RT<$`LJ6Ui zaF+0U!XFTFo5u2=<_skXZE&{pS#|~vMNWMAj?{3rMZ8C)e`|&tb z#QRi48(sXBuyW3Glq6hB#UD^4i_e+ywVdI${L#AWt3IOi1;RfF7fsvxu$5heb=}Ek znf`>*Zy-XJd>tiFe*$Lr*Vz%Mih8T$r>mqwH{l$_qCs{P_C}i;SB_6UjV3;ZV^Piq z&7zIlEj9n5%tZta`~vAKzVlZg~Z&RJQ+7=+!19%AkMuZ&s5or`*p_TX)-pBR(46YgQvPH9Z;4&+x{vm6j5Mr@W z_7n3^?1BXkjC+Ox%qO3?9XscW_s$xbbVBE%ibA_E=Co8sRKw4PgFYvvinQ7NT!>=Q zj{OOdPNk=pCZTjwns<=6Oenz=|U(A|BJ5Wk|3zVIP?z9ar#7B=t4 zaBsYsEyDNXF2>;b_(G}dCO6?}h>bKJkT**|^uj@Si@>PA+^wHcXh-DACirAl@Ntov zPNhXPRWy>>L8^|FJaWErKc6R?Fo4CzhlooHc;wN`e0SsnHc4LSYl2RtTq)NRDJ_!C zq%=c3O+B9@xM?1Fx;nJkX}pJN@eJiR5Cq{{g!>3tM6N6=G(5~Ba|vN^;ezm3oXwlr zF&|?wbMeM<#vXyC?OXQH(hIo?r>SojhPjHVl$PP5@H`CBK@R@sp@=?Ga%l!g9U;hL z?sZaU2=pb&IVQMar0{p^JnR^6a*kkM{8Nl$uzx&gK09u=Hr~mY{o$cyh2H<4=DA&a G*na_aH)%fr diff --git a/myenv/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-311.pyc index b9424764f53b85089c54cd60daaac2c547ea3cae..30dfa75cc6890d38660e42cd9a6b14d8443ddbf2 100644 GIT binary patch delta 19 Zcmew(^hbzmIWI340}!~J+{jhL2>?2#1vLNw delta 19 Zcmew(^hbzmIWI340}wbL+Q?PJ2>?2M1uXyo diff --git a/myenv/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-311.pyc index 593121255a09be97b19ac6d2ec28e07ced2fd697..36529b62763199dbc40bda55c9df3132ef62ceff 100644 GIT binary patch delta 19 ZcmX>oc~FvTIWI340}!~J+{m?^2LLnG1r-1Q delta 19 ZcmX>oc~FvTIWI340}wbL+Q_w?2LLmy1q}cI diff --git a/myenv/Lib/site-packages/pip/_internal/network/auth.py b/myenv/Lib/site-packages/pip/_internal/network/auth.py index 94a82fa..4705b55 100644 --- a/myenv/Lib/site-packages/pip/_internal/network/auth.py +++ b/myenv/Lib/site-packages/pip/_internal/network/auth.py @@ -3,6 +3,7 @@ Contains interface (MultiDomainBasicAuth) and associated glue code for providing credentials in the context of network requests. """ + import logging import os import shutil @@ -47,12 +48,12 @@ class KeyRingBaseProvider(ABC): has_keyring: bool @abstractmethod - def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]: - ... + 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: - ... + def save_auth_info(self, url: str, username: str, password: str) -> None: ... class KeyRingNullProvider(KeyRingBaseProvider): @@ -151,7 +152,7 @@ def _set_password(self, service_name: str, username: str, password: str) -> None env["PYTHONIOENCODING"] = "utf-8" subprocess.run( [self.keyring, "set", service_name, username], - input=f"{password}{os.linesep}".encode("utf-8"), + input=f"{password}{os.linesep}".encode(), env=env, check=True, ) diff --git a/myenv/Lib/site-packages/pip/_internal/network/download.py b/myenv/Lib/site-packages/pip/_internal/network/download.py index d1d4354..032fdd0 100644 --- a/myenv/Lib/site-packages/pip/_internal/network/download.py +++ b/myenv/Lib/site-packages/pip/_internal/network/download.py @@ -1,5 +1,6 @@ """Download files with progress indicators. """ + import email.message import logging import mimetypes diff --git a/myenv/Lib/site-packages/pip/_internal/network/session.py b/myenv/Lib/site-packages/pip/_internal/network/session.py index f17efc5..1765b4f 100644 --- a/myenv/Lib/site-packages/pip/_internal/network/session.py +++ b/myenv/Lib/site-packages/pip/_internal/network/session.py @@ -3,6 +3,7 @@ """ import email.utils +import functools import io import ipaddress import json @@ -106,6 +107,7 @@ def looks_like_ci() -> bool: return any(name in os.environ for name in CI_ENVIRONMENT_VARIABLES) +@functools.lru_cache(maxsize=1) def user_agent() -> str: """ Return a string representing the user agent. @@ -230,7 +232,7 @@ def send( # 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")) + resp.raw = io.BytesIO(f"{resp.reason}: {exc}".encode()) else: modified = email.utils.formatdate(stats.st_mtime, usegmt=True) content_type = mimetypes.guess_type(pathname)[0] or "text/plain" diff --git a/myenv/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-311.pyc index 9daef4c9e40e014ef056e2d1766cc4314bc84c06..402ea217be1165b61fda2fcea79cda366975f88b 100644 GIT binary patch delta 18 Ycmcb~c$1N9IWI340}!~JoXB+^04}Hn0RR91 delta 18 Ycmcb~c$1N9IWI340}wbLn#gq?04|3F`2YX_ diff --git a/myenv/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-311.pyc index 94a9a4cccf66377bab82629f35fe86fc8df134de..b1ed7b12dcfc492ba65133c56ee75980a79f8fa5 100644 GIT binary patch delta 1645 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 delta 389 zcmeB+z8l56oR^o20SKHA^`%8@_g|UWlHp5)zV32vp;!H4cO=iC;CR^JoW?NfZO_p2i zWs0dq#hLkex41HkGxLf|67!N%i+F&h-{L4rERWAi%uStKE$$NF4isu&xFIY)#iqgM zF1z3aou%v-*)^`PYkXi}WHq`WBsN9&0>2>;EwF*m7dQ-W@Co(gUf|XPq6It<`T~ny zkv!0>&1Mn;?2Pe~-R0*o&f5G;ejN+r-OW=~ycmIE4^*QVUv0KlTgb@xd-7fN-HdlO p&(!$ABw%=f0R?SdsGZKJ%)+RDLCNR?1CZWO45rWtzRB9U$pFu4XI}sS diff --git a/myenv/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-311.pyc index d501ff1ad61c583f9effee44ab0942700d496514..b715f8cbff1f2512597fe95e7ae843667598697a 100644 GIT binary patch delta 4723 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 Z_XYi*0^fH4`^idsLnim=_lXlV{}-SZTYvxn delta 4696 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 I!aS(-zjSX_9RL6T diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-311.pyc index 8fcd55c628250534bf57968fc0a917afb9215443..4a6e627d422a94b35f8c3ec8db1610668d24584f 100644 GIT binary patch delta 18 Ycmcc5c%PALIWI340}!~JoXB+*055t46951J delta 18 Ycmcc5c%PALIWI340}wbLn#gq(054eu3jhEB diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/build_tracker.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/build_tracker.cpython-311.pyc index ea4d391764d8344dde3756507f1c52f48315d762..b517848b87ef25f4d95baff5b31ab2b52f8708f9 100644 GIT binary patch delta 1637 zcma)6O>7%Q6y8~{ckS5gwH@2UZftK-i^P#a(-v1G4Izosw4#Lr3995Ef|H%tP8=tU zZ9yQYAR-P3ilTSm&?0d%hawKRNEH=_P;ubaUiSdugv5!88T#0U9k_UfNS0(NRsXtP&;{+T2G)&&K_pqC@@fz* zaM4hUNYV|yomB`^X|?&K^5=JLSTDNnD}6}vRQ1D8LHW8b)!_G z%ywIJsaaxa$a?#eNtA?2w6VCSV1}iSFQO1Tjf3RKlPRItTuoH)ngKvCkH7Aa3 z+vg`F-Tu`-Nz@@^`C&Nlb$SrVEQhRYD|K33VJNKQ1x=GB;jci3Ov7>G49P*k*hzNu z*)wQF*chr~x={Op@gzA9{lNjQ{d}-AVh9~uTdvY#t+|<1ggTqxZ1x<&B!{}f!Q_iO z_$8Pj7eNiByco9aTBBQVG7y7&Xpb1+4iB9YuQq@}Wp$%cbHZ>rerJ%amW%Z=wd$BX z$7wMmN`tZ(r`cnv z(404T0Yx+5iJc}%7>^~?%bZc)g;!#qgcHf@J$GZX{JV9*`Gvn@52l8tR&+{p-S%^8 zPgACR+Mdsabbugj2zt0{YRt7aN;rO>IG*>q?s%2FuH6Zeyxu99p zGVe6XQwLS}Hn3x5r!DmM{;?0p8PPEdXodfCSf!m1?XH7XTdY_Q7wh$8io6H6lXF+F zuCg-oql@$r{bDx8Mv!+B;S|DY1d+b8NIi>yCBrlhwmw~~({pbw)6E8-9t@v`1b7>x*NwEaWsePRlU2rI2}GW!?AVDj>rb4d&&=Qg77C>o24;KUL`$ca+?7%Q6rR~#ukG0D-`I&8CtfF2QU{up{v=SG5XVWV)F@O+DitFr+w9nJ>OYM) zA{1AVAmRj6(MYt%oWh|uEJa9AMB1J>6@)~!2Pij+1S*^mT$nd*lBS3QBk$)o@8{e1 z=DnR?rXEdepJ-Ye;wyXmqx^#nErw5S44hpndvjilOk^r0t?bMBgzPB!%Yj@#$Z9EA z4&_1^Nr*_xVPJqo+P5%5H~G_Axd=ha(cPWtBps%UxJ-9!SB3J5*|x51@%_y`U2d)O zKp2F0o(Pdl@4rG~5_%b#+B!0Qq+?6wbo^(~qlg+Qa6Igu~R6Z8)eVP~q@fi*&$yVy5l&4^< zL#?__6YMA7VVq^Ee*}-RG5>n^oN7`TScJ9SWa2Qtm?jE5{4|uwf zsWxx}EqmFQ?Q?SXJ6D+&iAnsgKXU4jM(22dtyF8IVk?vwrmg0yv}{Bn*Kq8>V?BFu77JnJ}D}2_52^3*1y^EE2ue-ZAoh zH2rNf{n`8%7rt8kCVK9>=sC6>{X3IJTak=Y{@lx@9jB7>oF=l|3Z4-@&<_Fvb9X-X z(y`mD*5O?&noo==ceNeDawT-&h=uN5M!Vc0^lUTDFD&h zF_2yYPyt*VY;Dr0lj+q(QnUCqLg9SqG=NAQMu&O;_KKiWuzkLtqwQO)RxGk=m5qwQ zZx8AKQyyRhKwJ&t&VUR>nx~tMp7*dWEF$eV1txligYAS%s8}h`5KHLCdZ`kz~&F9E-(Uk7OzKolpE vI+*BRt~7taN{Niq8u!Eesej0R)w7xLd+2}s9-zT{2Y>gQuO>CDK;i!Y4m)_n diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-311.pyc index 22db946bd714e5133df089c7936f996f72398fde..8403fdcd4c53cf5f9d64ac3ccf94477c4ad7b630 100644 GIT binary patch delta 19 Zcmew+_)U;&IWI340}!~J+{pEY0{}Xo1)u-` delta 19 Zcmew+_)U;&IWI340}wbL+Q{{W0{}X91(*N; diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_editable.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_editable.cpython-311.pyc index 392a3d4ad4ba03599acc8f52d226c26fda34cdbe..4aa2f87258e8f19c6ee80dfba29172516e65e966 100644 GIT binary patch delta 19 ZcmbOwG)stUIWI340}!~J+{h)s2>>h_1P=fJ delta 19 ZcmbOwG)stUIWI340}wbL+Q=oq2>>hc1P1^B diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-311.pyc index ee974bb74d5dce09df3eef8387a46fbdfc0b9869..15ad4a23a662532c13da6c835df7bcbca0ef563c 100644 GIT binary patch delta 267 zcmbOv`$&d&IWI340}!~J>`Uw0$oq?t=?}wXPNrT_p%PY*I0U4y)G*9un9DTzG?Oeh z3rutY>*PjekPwrpk@puPlMLfzPNrT#r4m+sbtfNY(blN0En))d(qzBIlwW*{JtwocBqg(`2&Cf{b53gB zEw;4$qTIxi$vmvqT(Uq>Q6MhvpB%^&plLiH$-N diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-311.pyc index 2f6f85cb99f1e8bd5a1f26d6720bc36ce027bd1d..ce08a366b6faa1d5eca854a5ac476c423a8752bf 100644 GIT binary patch delta 19 ZcmZ3%zk;7@IWI340}!~J+{iVL9RM!I1hD`B delta 19 ZcmZ3%zk;7@IWI340}wbL+Q>DJ9RMz!1gQW3 diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_editable.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_editable.cpython-311.pyc index 78ec8be4b44fc4215c98dcca099429bd91f18fd9..e6175f077664bb5ef91098d439e035003cc24301 100644 GIT binary patch delta 19 ZcmaDN^hAhjIWI340}!~J+{hKh2>>@11nmF- delta 19 ZcmaDN^hAhjIWI340}wbL+Q=2f2>>?j1myq# diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-311.pyc index b55d95e9a92877d4b47604660dfc49203ffbe895..0cabd113bbb4dde8b192198c906ce9362bf1dfd2 100644 GIT binary patch delta 468 zcmbQQd{&8fIWI340}!~J>`QyPkyo9SDTi_L4@N~%h8l)q(-g)UrrAs>OmmrQS!-BJ zm?w9!D)X{{)I-1m=E;ey!jsRkim);VGn8;n{>Lb#kiwD;R#IdJ)y`VOFq-4f92uo1E3iv3 zRS8eFW0zvIoLtUsDN@7>R8s^}s>yMStvJ7^BsFF7DfTih6`+s;5Eq}F?8PB1#OJ=k z0-^`R(gYH>xXLq9Q*+`Ii_(j4 z@e~(i=Edix78fU`rxxi>R^)YOG~b-b`+$*AVX_zh1~!n1Mdp(Pq!=AHOAE9x0suJa BXo~;< delta 519 zcmX@BG+&u_IWI340}wbL>P!2vkyo9SX$j-xAB>8e3^feJE-8!)7$+C935zq-FfC(b zU|0>r5Kzln!&<^RIfqr5mklPyz_5S?q}6c4Kq&oI?@N5%CtNP_1zzC`>|nmZ!9BT-LuIlphlG&+b1s1{wFx2|9e oqu%86JnoDZo5gt_FfuAm{=v6_4WzNiV)8nEDMqKwC;3|#0rF6P)&Kwi diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py b/myenv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py index 3791932..0ed8dd2 100644 --- a/myenv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py +++ b/myenv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py @@ -3,9 +3,8 @@ import logging import os from types import TracebackType -from typing import Dict, Generator, Optional, Set, Type, Union +from typing import Dict, Generator, Optional, Type, Union -from pip._internal.models.link import Link from pip._internal.req.req_install import InstallRequirement from pip._internal.utils.temp_dir import TempDirectory @@ -99,7 +98,7 @@ def add(self, req: InstallRequirement, key: TrackerId) -> None: except FileNotFoundError: pass else: - message = "{} is already being built: {}".format(req.link, contents) + message = f"{req.link} is already being built: {contents}" raise LookupError(message) # If we're here, req should really not be building already. diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py b/myenv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py index e60988d..c01dd1c 100644 --- a/myenv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py +++ b/myenv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py @@ -27,7 +27,7 @@ def _find_egg_info(directory: str) -> str: if len(filenames) > 1: raise InstallationError( - "More than one .egg-info directory found in {}".format(directory) + f"More than one .egg-info directory found in {directory}" ) return os.path.join(directory, filenames[0]) diff --git a/myenv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py b/myenv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py index c5f0492..3ee2a70 100644 --- a/myenv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py +++ b/myenv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py @@ -40,16 +40,16 @@ def get_legacy_build_wheel_path( # Sort for determinism. names = sorted(names) if not names: - msg = ("Legacy build of wheel for {!r} created no files.\n").format(name) + msg = f"Legacy build of wheel for {name!r} created no files.\n" 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) + f"Legacy build of wheel for {name!r} created more than one file.\n" + f"Filenames (choosing first): {names}\n" + ) msg += format_command_result(command_args, command_output) logger.warning(msg) diff --git a/myenv/Lib/site-packages/pip/_internal/operations/check.py b/myenv/Lib/site-packages/pip/_internal/operations/check.py index 90c6a58..623db76 100644 --- a/myenv/Lib/site-packages/pip/_internal/operations/check.py +++ b/myenv/Lib/site-packages/pip/_internal/operations/check.py @@ -5,28 +5,25 @@ 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._vendor.packaging.version import Version 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 + version: Version dependencies: List[Requirement] # Shorthands PackageSet = Dict[NormalizedName, PackageDetails] Missing = Tuple[NormalizedName, Requirement] -Conflicting = Tuple[NormalizedName, DistributionVersion, Requirement] +Conflicting = Tuple[NormalizedName, Version, Requirement] MissingDict = Dict[NormalizedName, List[Missing]] ConflictingDict = Dict[NormalizedName, List[Conflicting]] @@ -46,7 +43,7 @@ def create_package_set_from_installed() -> Tuple[PackageSet, bool]: 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) + logger.warning("Error parsing dependencies of %s: %s", name, e) problems = True return package_set, problems @@ -60,8 +57,6 @@ def check_package_set( package name and returns a boolean. """ - warn_legacy_versions_and_specifiers(package_set) - missing = {} conflicting = {} @@ -152,36 +147,3 @@ def _create_whitelist( 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/myenv/Lib/site-packages/pip/_internal/operations/freeze.py b/myenv/Lib/site-packages/pip/_internal/operations/freeze.py index 3544568..bb1039f 100644 --- a/myenv/Lib/site-packages/pip/_internal/operations/freeze.py +++ b/myenv/Lib/site-packages/pip/_internal/operations/freeze.py @@ -4,7 +4,7 @@ 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._vendor.packaging.version import InvalidVersion from pip._internal.exceptions import BadCommand, InstallationError from pip._internal.metadata import BaseDistribution, get_environment @@ -145,10 +145,13 @@ def freeze( def _format_as_name_version(dist: BaseDistribution) -> str: - dist_version = dist.version - if isinstance(dist_version, Version): + try: + dist_version = dist.version + except InvalidVersion: + # legacy version + return f"{dist.raw_name}==={dist.raw_version}" + else: return f"{dist.raw_name}=={dist_version}" - return f"{dist.raw_name}==={dist_version}" def _get_editable_info(dist: BaseDistribution) -> _EditableInfo: diff --git a/myenv/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-311.pyc index 1ab4e244e7fdf0d51568c65f4558cb5c5d3543b4..4eb2ec2aeee3a562603a45993db65d6fb616c677 100644 GIT binary patch delta 19 ZcmZ3?w3vx&IWI340}!~J+{h)#2mmWc1Ofm6 delta 19 ZcmZ3?w3vx&IWI340}wbL+Q=oz2mmV|1Nr~} diff --git a/myenv/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-311.pyc index 854b3ab8abdaceb53384ddbe993bbd67b5eb2d8d..a70a0dd6e6a2d0c35c8703ca9e004284670672f1 100644 GIT binary patch delta 59 zcmbOuI8TswIWI340}!~J>`PTHHS$;f{}sY12ZEd;|C^2MwSl@AcBnn KC_9;*lMw)L1PizT delta 57 zcmbOyI7g6oIWI340}wbL>PutV$ji*i$hTRLHHS$|jFExi12ZEd;|C^2MwSl@K;i)d K-{z_8oQwcirVEq+ diff --git a/myenv/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-311.pyc index 0e45614336f391a60d0782280de367872be13bec..1aee0175144406374e7344b59b649e0b55c8f211 100644 GIT binary patch delta 4122 zcmc&$3rt(r89v9?4~#KS8!!YLV=$N)^9T@vd4zWo9%*rST_7ppUIN4y=*3-AN`ZE1 z*RE>w_?yx-ZR4n2$~I++bTu`rHmT{PHQS^-Hk78Q>1$i}QYWLOQyNw4&N;>nshUoc zChgkyyWjsf|9>9;J?DP*Q`N_>tBkK2jnRl)jlX(&r22@_f}KZl-=3Fp`CN5sH}7U#?=O%%yod2(IDeH?%@0>gHGB)>5C z?k1w6;S+^sQXBh3ZhSP7TxenQzCqY_%b#>(`%z7LZ8$+BICcEb33iYK9Z|qxxAKwUxZU6)U6UW9 zU{M|~$kt$sa=PSCTHL4{+hWJ~E_ki-QJe|Y-e2N+MO~%l@F3`GuVPX8sP?1^Z-j&O z720Cjz6jo|Z^ffZY{OM-NTZrn3hA)g=)?m`YST|JepI>8tj73B_+87x_@L6Y&8osj zAh6>oKK!z-72^zuYV+aem4UXi7@q`l$CEe+Cp)g=Ugg=HqZ)5hU<--4c8zC5SfDz> z5E{2dcwlRU5v?7Db|=G2sj=EJ^pHK!1n2rpU@41DEJGLtn$~${gRg6ov2~rs3DD&= zcdXOoMK~n%B*SN2xi}x}-R6|9^%>s??cFDhy^%Hu1qRas4SU(W7POZ)nX3)Vq#nF;>ZcZZ23 zcG`P4Ie_Ykrx~XBdfdQt=lSG2#-vm44m=LV{xZ^zO4?u(nT;$}u$hHC8H$~Edp4u7+#-`vTcxnGen|7@=M`Gw$ zjHp>1;rbW#YmvO5k2Av#e*reb0lz&fx5r@lt*WVRJhU<5|OcX^nGGGntVYZ7jZO&0nfqww50@95&pzmXsbsQO4p3 zz=M<4e$HHch6E%J25&^);#ckN5En6ov?#+9(tRni792`Q{WJ!pj9l|P}}Oa>`eQSd^` zl!#a1^pv~VqHn;bXF`ZR&yIwj|239_?cUFElCnY8U|b7X({ngOIXV573KuD3-+EJp zTNU>MKft&buFUvw3*|XiIYWPOeWQ|XF4EE-WQPbX=B5PJSh({(qMs#fiQLmI%Ds;?;+9NJ&b35Kh@(%3i#`9SPdHY2 z*d5efN^~ykb3+M&7#bM0nQw?lFy-wgj->i za2v!!2Kf^6zy^bz)(R_Y2XsM>Hk-;humE-~d;fFcRmj$|SIq^N!5U91Ti!^)O`!n3 z0EdTGvCK|~BFgAT#)@TXY|67|jJzZA#E{=}Utr8X?YVzc6#dZk%&~YnY+0tjX5j?f zd?q9MH6oKgnm!NqV{gqTVO0qI|6u$7DtjKBdUiE?*Cq5H{vj2-u~-hPiy2%LPEZ`r zJ)kPxhOsRuENwc&EmgcS5kgcxYdSmpGfS9%4R*t&=ii_2R^!qTqIfmh7~&}TATBwi zVR|h}FokrCMj>NTNY7|AiZ_J}jK-jJTgb?0EK0CEXIYMSgyNVSPrVWtO+?!0P!gjo QQ#c<(t~4Y=@eAkw4Zx-LiU0rr delta 4067 zcmc&$dr(x@89!(5K3JB8W!dG;J_J^lhrB^vA`d|k31tQ0Dj34O2+Q6DFKcQdh^8i~ zabnaDqa96()v-3Ft(n_&Y@3<3{t?qhtftfuT5Xbqjt+kNxG@Q@IllVMDU1Xx=zOcCEIvze z^KK?b__C!OK8JC=FIURr^B9lxt&#Hie8vsF0;!NMWIW1OBo*_;j2nF=QYl|5mGNa# zIbY6n(Z01(1z#am@|8@E@l{FHe6>`=kJK=Q$+u3b5zFunJ8>B|Q zQQE+7V0yE!NowYsrH%YXX%oLmYT;X$KF+sUYUNuo5))(#X~^QUN?Z6X7^zS*60C=i z5HD_lw{dAog4l6Uh0tYkh7R5%W{4iKL(GH%m3^vJND@1QWO1vILi8PC$Dk@H?1~1p zLh2z6-zB6GpA<2L*b`US)q?Gin%~B9q=?;vYQawA9>F1+h(DE`MCOH6Vkyf{Gpwip zH&o84bmFsJ$PibF9ZR)|zjL`va%B>~9fC_t6FXP<*+U~InYktX5+jkTNo22(C3*xm z>!gEpmQ8ehbmZnmrH3eUh;pZp3kSHAsXWrKNAxUjSXd*bi=L&_LcVBUKFGyP_T>W{ zj1me+)(3?`Hi0YJCrz%1CqpeFzWsC=wL&pj#}aU;ty86hm3?X*2iRJd6U$n$@FGXn zn4F7iEC>~}PeDZzR+5Aw^Q|Jj)nd-4dF|oqu4zq zY#@tKxvcLdVxZ~GLNnPQyF|`A6fQ1oWK*0fY+CXs!)Q6AzDQgyhusiA{Hem>qBMT7 z@M2y2Cqcqe;mxG5S5SG7yA3)t&)`^iSL0K4MtyeKV5Bjzv z_-k;o?L%x)o_b(N!=(o*;GM`sb19m12C7K<#lvd@M|3<T=;s*xhISY%i}19`8D5Yzs#rG?PW+IOmKTc9&XUeM~f5 zNr|?QA#^S|3EBzHn*(*8gejMhJmK1z8@36yAxz}FPh@Ic6P5xy!wjLrl@~GDJLC)< zldA*$VUAE>V2KNMZ&6q}Ts>19=JX1ar4ek9RozZp!djNQEx44ivx_WY(Q>yt8%uD! zJJ~XsJ&}DdIk3F%au(9sW5K(jzsG5mm&$l6;hCPKl!uozf+kS5Bn9@uxveR1wf?e2CpNYR=C91<65dau|592DT!H=8#qAbfUE=bZBHe^M2EF- zt2ds_$#Fgbe!jgulnRP=d~PlX?6BY`;qVU6qW_P9qIN7`U^O}J7du`-?(eUs0ayYgOYnVD_N} z{A=a)flREWdrG#!f-r&aDtkm;h5raQcfEn%SI!Te!uYRHFpMrbd z1i0dzOe#)C0rn9Q8h8ehUF7|%n$gn1#~(IKpp_5hNlhRIx<<;Awvj+nxLbrsAboLj zGkSV^!7Jqkcy+|dsY8j9Ng{3nP3SJF$tEXf=wQjTzACI|E56N_ixc3G&zYfVldlt( zM<43+i+jh!fq*DD28Vs3W7zN5H(BY}=aeU5y_5+b__7M0>hzEJN5ANIj1LTnlIR!_ zA93s%ClO)iNk`V;s2obbB5S2>nthXQcNCnFT-pnyl5A71NqVeZAUEK68Qk*s#5Lmg z%!wylr;}&4-!d1@nhS$EXdg{;=#7PQw(Lulv$nEhhGT|>J8>yNq%#(V0iGVUtyNh| z{-#B7Ni3efl5%t11GmiWv*z}o9>pep6p0eDF6nN?7tF>N+%y#gV@UkM!oo*p(2g}( z3+k%5Ybc^#kFM$KEDdR#TP0^g|Cm)0!tMi`a6SCsKpw7wKOAu3W-uMJ#crm?b^`O-#rJ6S z!BN}|FCILV9H6!=3TtWMSqj^z*aW?g?TQ3KUm)jrzH;NSMjUI`WZp3+1vz?6catl; z^QE|SA_dXsLcP*+s8?k%YO?MaQ*RkAD*( zOz>B>_%6iVM(QrL?zRpSeA8Ujoy5&0sk_s3a}G@KtsLA_!M#*M+=XgG41@Pju zU0p~h{B-)HiFPgfDX>X63!^8~BELgq@<-!0;n|bdr_5LtME^gi{oks)AoJ9{jINvL zKm3C#s6AZ List[str]: # 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 + # such versioned entry points. + # Currently, 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 + # we need to use universal wheels. As a workaround, 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. + # correct ones. # # 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 @@ -507,9 +505,9 @@ def make_data_scheme_file(record_path: RecordPath) -> "File": _, 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) + f"Unexpected file in {wheel_path}: {record_path!r}. .data directory" + " contents should be named like: '/'." + ) raise InstallationError(message) try: @@ -517,10 +515,11 @@ def make_data_scheme_file(record_path: RecordPath) -> "File": 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) + f"Unknown scheme key used in {wheel_path}: {scheme_key} " + f"(for file {record_path!r}). .data directory contents " + f"should be in subdirectories named with a valid scheme " + f"key ({valid_scheme_keys})" + ) raise InstallationError(message) dest_path = os.path.join(scheme_path, dest_subpath) @@ -604,7 +603,9 @@ def pyc_output_path(path: str) -> str: # Compile all of the pyc files for the installed files if pycompile: - with captured_stdout() as stdout: + with contextlib.redirect_stdout( + StreamWrapper.from_stream(sys.stdout) + ) as stdout: with warnings.catch_warnings(): warnings.filterwarnings("ignore") for path in pyc_source_file_paths(): diff --git a/myenv/Lib/site-packages/pip/_internal/operations/prepare.py b/myenv/Lib/site-packages/pip/_internal/operations/prepare.py index 956717d..e6aa344 100644 --- a/myenv/Lib/site-packages/pip/_internal/operations/prepare.py +++ b/myenv/Lib/site-packages/pip/_internal/operations/prepare.py @@ -7,6 +7,7 @@ import mimetypes import os import shutil +from dataclasses import dataclass from pathlib import Path from typing import Dict, Iterable, List, Optional @@ -80,13 +81,14 @@ def unpack_vcs_link(link: Link, location: str, verbosity: int) -> None: vcs_backend.unpack(location, url=hide_url(link.url), verbosity=verbosity) +@dataclass 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 + path: str + content_type: Optional[str] = None + + def __post_init__(self) -> None: + if self.content_type is None: + self.content_type = mimetypes.guess_type(self.path)[0] def get_http_url( diff --git a/myenv/Lib/site-packages/pip/_internal/req/__init__.py b/myenv/Lib/site-packages/pip/_internal/req/__init__.py index 16de903..422d851 100644 --- a/myenv/Lib/site-packages/pip/_internal/req/__init__.py +++ b/myenv/Lib/site-packages/pip/_internal/req/__init__.py @@ -1,5 +1,6 @@ import collections import logging +from dataclasses import dataclass from typing import Generator, List, Optional, Sequence, Tuple from pip._internal.utils.logging import indent_log @@ -18,12 +19,9 @@ logger = logging.getLogger(__name__) +@dataclass(frozen=True) class InstallationResult: - def __init__(self, name: str) -> None: - self.name = name - - def __repr__(self) -> str: - return f"InstallationResult(name={self.name!r})" + name: str def _validate_requirements( diff --git a/myenv/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-311.pyc index fa2174d61b591a892ff4947470a5ec64628529d3..85b649ccd98649898631bdd38b80da7414b85adb 100644 GIT binary patch delta 1158 zcmaJ=&1=*^6rV}5AK7d+-EF&Ht#FNvUQRb^s;Ly z;z=w4#gpKnB8m$2=E>_8AUsAC8JHkL zxB}-%C4%RGB?4?MhPhgQ(YkN7+>6v}+kPmyb%#PevEZDf7emc7>#p1KBNxv!U!YyS zeDGapF0d>}5#&Mec!k{~&$pD?t#xa6VRmbbTO;2v4av7HMjh(%k0DS=1=9lppP*fm@r|tnoY}XhRQ+H zsK@xhhjIV*3Rr>r>{|?P}Y%Y_Gbv0F${#5(+gNmQDM;R=B#? z@8}AI3C?)bXZ%)#3Fryj1T&PI)L(#1C}aFbVzV5grtpTa>-@Mv>3XYW_X{agX_2-~&$4+?`LE}F1>6=f##<=Y+kdxErW-w5XtFo>22Zso=aHavOAlvyxbPVl gzTm>PfN^FU9fuvx{pPSEBB6NTnhdTD^(3CyKjr}coB#j- delta 1441 zcmaJ>&1>976rYhsTJ49t&U)8g+i9}IN$hoqd$pk{g#1 z^`Sd;UKUK)SAhr6ynOEZt2-@WIB5994!{LkRKlJ;n6_8{Z0arPz`B9uK1%cb~ zzZH=y#kF`D_=CpwrQKN&ZV^Eo%88?KDs--K9cp6`hH*{kp2iK34X#5-GkvH{e3h9} zBt01|F6YabJ40EAzFSv5Z_pdW%`JeOz-+qsfXZRe+FHh95qL_8abl~LT6(9SS+46x ze&V{;gfS5B3}sOh={E1mPCp zkkSfBdHYr4+HY8tzIeTv2kQr~M4O40LUCq~w&e&+Xj6%G#pu2z8-SRr6sz)`x#mXP zycowruGRVb#~-z~s`LA=H801&(l*f-giHU`j`by0Cno?N5M@@;WEEKi^c8;&uy*k5 zXw(?LeQ}4t=gybv^CpKuy5$tljqE16DNR>ClRI*W)Rv4vuRLl(W&&O;t^`4kBa^& ztgUS;&+<49dC%NWN?%uT9V8wC1t*@|FFn=zc(XSWMYxX3jR>C zg6rbVbF*ScB%eVZLdr>u_aTDX#v>@!YyCdx7{^UH}e{ xUHlMmN2io-liJqHcbg2Ysb`y<*-C#H`gz8nu*Gk~f5^QU7>3i!)h&hr{|7?~FF^nR diff --git a/myenv/Lib/site-packages/pip/_internal/req/__pycache__/constructors.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/req/__pycache__/constructors.cpython-311.pyc index 957813f642d36a8791b34521810ff17253cd5547..2e6504632277264cb2294dbbf1e8171fdc0c993d 100644 GIT binary patch delta 4783 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 H|NHS@s9Q(g delta 5253 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 delta 5382 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 J4VW-k{|9be`j`L! delta 5316 zcmZu#3s93+7XEKYLXd~NAs`{hGm1O}Q4tj|0v1G3w7z3VejpH%coR^m7PNMq+SW=> z)vn#Pwr(xN~x?z!jQKSOV5PQRszc|JONl7!EqKkRScvu`LSmA&*@{=Zoylbn*%^e$Yk9qledgpW$=y0-? zlBF>CktQN6a+2TPF5Bd70d9v2y1ne3;5z*yOphKXb|t|xE0TlXh9A?ylTjHOUK4yH z>X6zi4SN8#K^@Yy_lecU?ssi z1jXR?I_v?L*TV~mCp>JVjxc|KD-rG7+hgZ|QYGrZI+{2^JaS80&`2N~3}79G096-gBqGx)qU8U1Mt(2#1&@ zX>hSFs_J+cE-HT12V<{k?$4;YXQ$cQ)+IXvm1ZPmrz>D@bIbGZ$>KW~SagcM-OGFI z0XUzQoa#eO5$6+3xbCOiL093Yv}toMBkeCj7?dtfF8XBhtP7K8U5tu-sCgtR`?;0F ziO;P4_1agpC!?>0X<{c`mk>gdCSnp7GYAf)dl;*HG$V((AU9(-&TBZsYUI6WkM|L5 zMNqU|UYCdB1_qM}CG$-$pyZ93>2TAOlPs2H7YT1e7;|oRrWJ*%(~QA`nfq95Jqb7n zXeaQQP@GkiBo;!?dp#bR`zdy`0zsa&MpN(rwk#S>#+3-aPjvon2JC;R$rzlHJCEsw$3w6&FN<};Kwb(?>2Tg4N~Go= zHin~i8GgRGj&P7QN(|R{hqRHynfy5#UkiMYpQ8!rptL6~-o+;FWnY2X8&16t%1>G5 z7rRZP=)@jt#vs!+txvI0=1nOOI+AEs&3NkY*&yuR&f*#PpW znxGXDi%ar^hbKrVvcv0j+B)t2PT4PH$CU->D$ZjwVW{{e)*W0>GMCK}NhG%BA~Hs$ zhHpW@brdE!F{o>F9dYVH1QRxkErs)?_n@VvGtX*@mLXr!J7u?w`S1n_y@_Cn;~R*k zUa<{0WhF0%yJk(VY(`Si%iCQ3fS)_5p>xV@y&a07$KH*_g!}pZ$hCy4z6440B*E+O z%B(ql@p{Fn?|(+Y8&~9>+;$R%S8wKGe+XsS!b=Z0BbPMAaboxl9m) zFq$(;^sV7+9(3Zi;jic2#h!%9s(onqbk%i@p@)=Wc`dxR&|ETv4aMN_dIENr$FGF< zVO^mkL7WhgE|0C(PaKT%dK$0-;;M7w#W7$dGwRX6&q70W2?l9<^&Iv}@Hf?qC`dPI zmYeC^Q4B7>ZEL42yC>8bGIt4nT9XR*)*9Hyu(viBm0qr$nJOw7_X{j8-cD0D0Os;teo{dVBL zSX|D&08?GvZM((7ZiH&r(cZ!THO_>}wjukrjT!Y7ECkN_dbBZQF~aHkbyLX(?irC( zxkz*JV`89c8mjf*(cDVK++J*m!^MBMVTYznoGM?E!si5HJJR)nw-MM0ECj+Pojw*l zENn=I-Hn;)Ut!a)N5FF*A9Z`?V7ot0l-aY53GBb{&&FYN7LShXSoDBSf-V$MAKr&8 z3I46=mzo+Y^11Nv5u(NxPSLyk?Jl>h`uqj;B@>KK4s0tXxV+2+ zA1*7?r)tpEKZ16-IqH+d@(YRO=MyVN5-T8o`LED9JYzK`4Gh*5LS#!Z^TNEA%((gJ z8cj|-ykdt0rE`*nZ@n$$nt{v6@7K|#$lQ$47iV$^c}lnwx4Fyhx9C)+h^ttf2JGfH z5G)DmYV9HhZ3%Uf6yDM6AW>q@Swsorn~5?bD5)K?2MSt~lZ0upGQ#wSB=J{R*_s>Q zNhA$*J9YN8R_bR^7?!~Yt=@@Ys9JS#G%1T#KbC%ml>b9;M?m=*+Mf}(3d>sf-|E?@ zhc~(4vb)<@(q__0C%Bv759Xe(z&;CF3DP>F6?-0>MJUx}hh1XkcS zFIL>`mPj>MoMhn?fv`%OMA7>lopO)NXTyW?lq6E*GX&q;MunV?RCq_u#WHtAp2J>( z^!5>qOQ^joEKNi@jWjM0>>?0D$Pnnti4-%8r|=}eu`UZ*_)AwII|V;>J)x%y3ttv| zqFc+@lHgJIY*v2|SwFI3i(Z+87k?h`Z*>Ja$L(BvukrE6QAi2L*B7_lA>(3-F-;Sq zX!5LNp91$BSSK(aT03nj&5S~`jBT1c&TR^oa-~T z-5!rz#dQCQi7PPCh?w0tHDM0S?bwEAj*vp6a|UgXvLsMp{O#M%Uf(t+3(;k zpLmB{N(P$1K9FG%3zj-&MpzJ~T@(m$+KeXL^8*{s`2;<4S!--&gUjL$9g$z6y!Pc*AIOdT`_5CYC}O zXwlU*H#gUDb^FsTeFaO^M0@9SsjVY*3=XNM&Gx)UZr`27t<#=*5Cy43T!v=LoeNE4x3#fDo$5`B-y zYhjW;9VMXm{@taMb*UiA%zLn;(kRTrcSD(a`a3A;LZw@`Ti@*8dY@HorAw$E%+pw0u_waM& zZ4?^^fs=qV#~m?Ur8qNMp>W1qlc0reOMgr!eS}Z z9Lm9$z4k*>^<`wP9QGf|X0woOgbxozuCE}2aXy!?$ma6kyM)K?F6wjm`E24xbjX1w z^bLQk*hqucCQW+I?1FBh^YhI;_nz;Z z@0@$*&fvAK&|OtkB)Sg#d1JaGuo#NNrN#E)A(v!G=bZ&!Gy+Q?Nx#xtz9xe%X-v}P zuO!{K7L@1Wdvw}67JZUlAZfqM!djP>3= zh~cN+T@b~q-s252g|I!Gco{?k875bd7GZqu?SVLE!TJ};2HfcERYlC|H+IJ43E3bT? zL9&s3ni$gTSW(0F2NZrQe(8^go7rq(;54EYm;B!~vOdwy@D5?8lrG5Nb)}n%d8DKR z8vC&l(Sc8tjQSxBHMb}W#6%!Tt=b#NKqF2Cz9r7Hz{MS$fP9?fAsX9qc5con>YA&} z>!Z0hh20Du01elIJ;V;GqUmimH{Hp;k+KheR1=i)fjR^`@U=Q1JB2k9vjIHea-sE4m$FgDk>Lkmg;%r=i`@jj7rpQgOQWUdx*RHRHy@s1PL~KB}g4 zhIhk0%!S8^azA{j!%6KCPQ{)=o|2aPMl3oq+_8;K!jqA`FoNGicG7147O|jxm{#qe znYHrfbl%X={3*NdAzcDue)ULFsw_AKU*vJlEY9hDPCorp&WymS_tE*PDtXd)K=fTl`oh= z#`~$(Q5I+WXAJA((#(t@#2&WgLfLQLApigX delta 3095 zcmb7GYit}>6~1?$-t|7bUVHtD3x+$xejrI^^M&q*dFkQet72$^Jvu&OP5f_uO;m+hezJDRB@+mfBDm3ya*LgnS79YMEht8(WUH`J`Yx)nPD zoqmPoI7`bWQ_}Ux@$IfP9O-hn1E{BStBTZ zXYP7U;aydSw(1fQ)TC0(HwH=WI<8MzU_q_44kC<#pS>RXn!2w zyLW2i9@y6FCMU&ouoq0856;j7;)lU0kG-%#(CiWa2+mK`v>S?+Kb_TKV`Nn~@78$R z#Ev5gCxC>TB)%IuLdV6gLo>AVX87a5ZT*%rY~>W^SzCf$1yMy-G$o2mhaLP=d%0blh& zCvW!E+igb?*#)UoIGd23*KM(dyqV_=s;beDx}s{Dbb(1~M$dAX4yIO3 zNj3Dn=Ju57>~c<1W!+2^E*i{~vRumN6v%YacKjNWnXR#sAY}qAjz&tDAyEM&O*w7a zL~?TaqMTupoHrL?2ox98tM*8pyq;gaz_>avMo7VR=t$xqCMC{fBdc4joaHn*&6b&N zT5i=a^33vPvN}ttdQ(VY<}DotcsK)ahEO}M=6kMDbH}z8so4mq{|=jTWQ|gCqZi%J z?K9-C{HmeCp_TPC;~to|b{H&|0oO(&bHD)a2PhRzy}~Z#Rc_NwGBa^S=6XuAFPcnoP8!7%Qs zW`4X5`8?`46;{d_c%UJVR&P6N=zs8k;n4rTXRm=3;}pcz8>AfV+Ki4>$bc_aDIvaj zq8#g4({5_3`aAk&Z2z0H_rpCu*n4|wBYbc(e6T`-!S?%Yy%m?E=LG%iwF<#^70bK# zRGiz*+K`|2yh1A;(kGR74OY4Wk@g1!;1NQ_hF;R$w^qDaEUmu&&g*~fn)p-K#75V# z&8}k=5)Q^}c-whD8morOXUX5rLv16L+ysm!H>1f42}NS}J9bxG&i+~YiL*lRUByo_ zJ6q+cnTm6Ja0{C5M)QT5N+m%1&mrZ3;j%PR=?Qkm9uR;>2;hLu*uN@nWVQ#rhEB7; z3gYxtIA0;~?ThhtepC#1497d5#lMUI*@5t{AoviTMffVhX@uv+rH<&ReFj5T0O!iNFlx~wJgrm7i<`X?sj)at45!MQn` z&14woM^Ve8RU7uYn%DZcWpX*IfB6s+ z5@1LkMqsGij}Y^mVEk}E*?}w}1mdtsHeq4qw_1)LvXI>*8}{W8k7QpSNnoq`&uA>i zdAt2a^}D;OtE;Q3tEy$3wLJN#rSM!q!7>S(|3?oDcMd&NSj8TAs4X%TD+!b^NtR^0 zS{f@0l*P&e=UeYs!Og^@{|sDhK+(^LYKwHEB-fmjoIX?!}Lh6C8_2kBlk27xY{eNq?5xVEHuz%d&&M zBAqy;+k|w%y41FJu?dS`8hUop3P)NiVR=ghJl|VfIBA=(4N9M9Oq#Hralm8E>ute?n{9pfm4m;B1 z{B0U0-TzIQ?UQ`Y&<|5`elN3y;vNOg7o2H7&y0K-EySaT(MXB-ht`$J6Yu@yVxx&6ng?;md zeRIw}c&X@F)}9(GUS=&LQ4Fi5BsH7hG)=~bvgIrUFP6bI?Kp`tWu@MS6TFKSIkW`V z6`Aj$fi)CA!Mlmr&bPw7<@Igij6|JrtBo7eo)b>QlA*B94yf0Y>LqtP{@i898k46DW=(V<&9R+9Ia@@10?n`U0 zzH&FMw5BCKX4rTlp=(xRL3awjd_VlQp@WUX>iX@-X|jG#A93P`XrVp5P&RVpD36C? z3Reg@f*`HLX)+JZnSAbq?uKfn=zye)O0@d86vur+^VWBp)l|J3STIFI_w+DDis?GldRgeoh1(bP!G55o)X zJ?vYs(7tM$I8wfOqya(-sk6LYQ@&Q1Gn;5@;34ek0MfvnslEh^< zI6}!J#zDi*W3+h{&f%?0AMku%3m)*bJ|Fu4{@C|@^!698ePe~tNt_nvgjFRJA4>{W zK8v}G#9MR>xVW~1IpH^JZ$e}AuWPij(-7=;hZe=-cOp6eDsgj+#f5}tX~s=}q~Tv6 zoLvz%xqyAVt3tdWA)g>1T*IOq&qO;BeBSEsVy;x~_2*eVT~D6{gLWdJ3Q_q(II|dE z<~H=TG%=i@6h1Be!c}_O|Ct?^T%LKCXU^&2?cl`CNyOvh(Ch$W9nEp;^h9k+9;pp+qW@OLB z&7gD33f2pOEt}ATzPx4HGPNGj7#p%Kw28P;mx>)eXNMRzBnuMpm*hp_6iVV5qKX)#(oUPc9Au_y-jpepw%`pS?j55U*AeOyFd zf~MC;L}23n)C=3YS&6WP!<0*i@-lq1!`-qdOD33H!qwc5Af2*sS6IK(%l53aN)qO)7;Ah;s^`}SIB9w01>zC-z3Q@@z-I)-sS7WeY4_Guc&}%?b`^( zD;EppjG9blLvVKQ*5X}rwYz5bKNFb0W(W50m-_SGE!KR@XIg}BB_^KK?wgz0I-xu} z&z_i0l@%Lx_a8JNmI$9Aa|(;WlY=*~$<+IU$64@~IEkkacb4vpND!t=bkUGp!c<5F zQKqAd(8kXRbr*rV5nLW#XznKn##`X|!4@nkesjxvXr?y~{(|ih8Wy)+NdEUkOSa-~ z5fG-MIFZ$L#_!+7*+su63L+bK!|(dt>~r8f^f(6KR}VdMt=K@so6F-EEuhJ(XdkP- zSX4g?j}3Wi$xp);1er#!Qc~Op3wf#k96DyTub5zGD#RNgcDE~acj!IV(>%dODLabB zi*yPH={CVG6fJ!l;2VRD*21gd9jp$H*verc?1FxIFI3517>$&%1~L2ZvZuh4;lh3T zX81;DHMA=I>;||gQVo+z4QnP!tLsb)d_!r5S^Vq1tI#o7G+{sE6-+$CgRD*T?jL>* zH>iMxVHZRr<>^g66KR5@!{zWw#9cs-Dbct~zZu?-)WJfe#*r)GaaSP!CfGX?V*z++ zDs*Qmw|NklT7_x1THV0@8v^P;HJOZ4)Z_gGt|zdTz^m}d*y$oN zhWYOFU=OoKvY{;HidVDJHXIu^iVn!!B!lY`Ze%`~IKWoJQ;G985_8{b^U+ffjSnY+ zY9bt>7ghG+8HM3cJQ0tEL#l{1X3DS=p~`=R4ET@X(WKi^O5L~MJIVGnP1L1J$zLNd zfWRo#6n!kIV;0s#kQ8OM2!$JorUl$b_D>b1pV%0+LRwIXM9i0ks2JyoOI4PD9&bT< z1O`cPPLD6chPgLx<^U(hatTWc1s{0$m`j=&$El${sCeYFM4uOp2gfuDo4Ue_BpV9i zf&)<|YSSGz*Ry^2leZ7q# z^jWrS;m?tr#r#|N;m;HJHh~uih{I%y8d0%`L?!G(3Kt<=1UnIrM2s==!ag;mX)#3~ zNyxkrMZdDdd5M-1XoIib?rGW1=IS~Zq+I)UHrrx;{|dsdZvWG!0~ULOAQhd}{soCT zm&5n1lB4+KCl@SNBFsADC1{;IocFJ^{Urh(cz7~$y~rgt!zK(b;{IktVr8U-s4^li z(K2zEmMw|H0FT_~hCO#U*=9I+M~7Lj`BV4Zv7GJ9I{FapCcI{uC@^FmJ*rTBpHxF( zh0}iKGd*1>`>))l`{C(YwiW88$1pbZuXCp^Ot;z^C_tcOd+}q~gq#-aX6lmtuyArU zI}FYDbm5|X_pI74l8#7Utz?$0e0LIuoMR!5MNEX}BGSms+z^d>iFgo6%)9DP;^727 z@r2ZG!<+ZiuMu@XEiJPPG3b9J;(D2di(N=1(l2p&8^L%rJa%6>Y`E9X4y10lx76le zjm!7@a?IVb=}|~Z*HMVY`;aPQ4BBvsF`hwVG%^k^-uLz{;n=xXI<`pl!l#83lO$#- zF48XP^RiN0I0}JH@L#7+i}c88=<5}QvZ+52<30koU$yW;`1AdB4i|ALf`*w|Rt(q8 zcvuMx%`~x6n4W3OD`!RpUl-H~e-c*Fkxe*T7$9TBd5L zD{iS!jW~z6krc>zF9C{iX3-{UxKlI~uL*JA#9@{m@I&Wyv4lLPD%bNZs7m}v+HR{P zEm#?2Z%RdTnctfdoOys(?3Qv9(BUk9$ICi-1NVTjK>lH delta 6708 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 Tuple[Optional[str], str, Set[str]]: 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) + f"Could not detect requirement name for '{editable_req}', " + "please specify one with #egg=your_package_name" ) return package_name, url, set() @@ -191,18 +192,12 @@ def deduce_helpful_msg(req: str) -> str: return msg +@dataclass(frozen=True) 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 + requirement: Optional[Requirement] + link: Optional[Link] + markers: Optional[Marker] + extras: Set[str] def parse_req_from_editable(editable_req: str) -> RequirementParts: @@ -211,8 +206,8 @@ def parse_req_from_editable(editable_req: str) -> RequirementParts: if name is not None: try: req: Optional[Requirement] = Requirement(name) - except InvalidRequirement: - raise InstallationError(f"Invalid requirement: '{name}'") + except InvalidRequirement as exc: + raise InstallationError(f"Invalid requirement: {name!r}: {exc}") else: req = None @@ -364,8 +359,8 @@ def with_source(text: str) -> str: def _parse_req_string(req_as_string: str) -> Requirement: try: - req = get_requirement(req_as_string) - except InvalidRequirement: + return get_requirement(req_as_string) + except InvalidRequirement as exc: if os.path.sep in req_as_string: add_msg = "It looks like a path." add_msg += deduce_helpful_msg(req_as_string) @@ -375,21 +370,10 @@ def _parse_req_string(req_as_string: str) -> Requirement: add_msg = "= is not a valid operator. Did you mean == ?" else: add_msg = "" - msg = with_source(f"Invalid requirement: {req_as_string!r}") + msg = with_source(f"Invalid requirement: {req_as_string!r}: {exc}") 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) @@ -445,8 +429,8 @@ def install_req_from_req_string( ) -> InstallRequirement: try: req = get_requirement(req_string) - except InvalidRequirement: - raise InstallationError(f"Invalid requirement: '{req_string}'") + except InvalidRequirement as exc: + raise InstallationError(f"Invalid requirement: {req_string!r}: {exc}") domains_not_allowed = [ PyPI.file_storage_domain, diff --git a/myenv/Lib/site-packages/pip/_internal/req/req_file.py b/myenv/Lib/site-packages/pip/_internal/req/req_file.py index 1ef3d5e..53ad867 100644 --- a/myenv/Lib/site-packages/pip/_internal/req/req_file.py +++ b/myenv/Lib/site-packages/pip/_internal/req/req_file.py @@ -17,6 +17,7 @@ Generator, Iterable, List, + NoReturn, Optional, Tuple, ) @@ -24,17 +25,11 @@ 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 + from pip._internal.network.session import PipSession __all__ = ["parse_requirements"] @@ -136,7 +131,7 @@ def __init__( def parse_requirements( filename: str, - session: PipSession, + session: "PipSession", finder: Optional["PackageFinder"] = None, options: Optional[optparse.Values] = None, constraint: bool = False, @@ -213,7 +208,7 @@ def handle_option_line( lineno: int, finder: Optional["PackageFinder"] = None, options: Optional[optparse.Values] = None, - session: Optional[PipSession] = None, + session: Optional["PipSession"] = None, ) -> None: if opts.hashes: logger.warning( @@ -281,7 +276,7 @@ def handle_line( line: ParsedLine, options: Optional[optparse.Values] = None, finder: Optional["PackageFinder"] = None, - session: Optional[PipSession] = None, + session: Optional["PipSession"] = None, ) -> Optional[ParsedRequirement]: """Handle a single parsed requirements line; This can result in creating/yielding requirements, or updating the finder. @@ -324,7 +319,7 @@ def handle_line( class RequirementsFileParser: def __init__( self, - session: PipSession, + session: "PipSession", line_parser: LineParser, ) -> None: self._session = session @@ -529,7 +524,7 @@ def expand_env_variables(lines_enum: ReqFileLines) -> ReqFileLines: yield line_number, line -def get_file_content(url: str, session: PipSession) -> Tuple[str, str]: +def get_file_content(url: str, session: "PipSession") -> Tuple[str, str]: """Gets the content of a file; it may be a filename, file: URL, or http: URL. Returns (location, content). Content is unicode. Respects # -*- coding: declarations on the retrieved files. @@ -537,10 +532,12 @@ def get_file_content(url: str, session: PipSession) -> Tuple[str, str]: :param url: File path or url. :param session: PipSession instance. """ - scheme = get_url_scheme(url) - + scheme = urllib.parse.urlsplit(url).scheme # Pip has special support for file:// URLs (LocalFSAdapter). if scheme in ["http", "https", "file"]: + # Delay importing heavy network modules until absolutely necessary. + from pip._internal.network.utils import raise_for_status + resp = session.get(url) raise_for_status(resp) return resp.url, resp.text diff --git a/myenv/Lib/site-packages/pip/_internal/req/req_install.py b/myenv/Lib/site-packages/pip/_internal/req/req_install.py index a65611c..2132785 100644 --- a/myenv/Lib/site-packages/pip/_internal/req/req_install.py +++ b/myenv/Lib/site-packages/pip/_internal/req/req_install.py @@ -52,7 +52,6 @@ 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 @@ -222,8 +221,9 @@ def __str__(self) -> str: return s def __repr__(self) -> str: - return "<{} object: {} editable={!r}>".format( - self.__class__.__name__, str(self), self.editable + return ( + f"<{self.__class__.__name__} object: " + f"{str(self)} editable={self.editable!r}>" ) def format_debug(self) -> str: @@ -244,7 +244,7 @@ def name(self) -> Optional[str]: return None return self.req.name - @functools.lru_cache() # use cached_property in python 3.8+ + @functools.cached_property def supports_pyproject_editable(self) -> bool: if not self.use_pep517: return False @@ -283,12 +283,7 @@ def match_markers(self, extras_requested: Optional[Iterable[str]] = None) -> boo 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 + self.markers.evaluate({"extra": extra}) for extra in extras_requested ) else: return True @@ -542,7 +537,7 @@ def isolated_editable_sanity_check(self) -> None: if ( self.editable and self.use_pep517 - and not self.supports_pyproject_editable() + and not self.supports_pyproject_editable and not os.path.isfile(self.setup_py_path) and not os.path.isfile(self.setup_cfg_path) ): @@ -568,7 +563,7 @@ def prepare_metadata(self) -> None: if ( self.editable and self.permit_editable_wheels - and self.supports_pyproject_editable() + and self.supports_pyproject_editable ): self.metadata_directory = generate_editable_metadata( build_env=self.build_env, diff --git a/myenv/Lib/site-packages/pip/_internal/req/req_set.py b/myenv/Lib/site-packages/pip/_internal/req/req_set.py index bf36114..ec7a6e0 100644 --- a/myenv/Lib/site-packages/pip/_internal/req/req_set.py +++ b/myenv/Lib/site-packages/pip/_internal/req/req_set.py @@ -2,12 +2,9 @@ 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__) @@ -83,37 +80,3 @@ def requirements_to_install(self) -> List[InstallRequirement]: 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/myenv/Lib/site-packages/pip/_internal/req/req_uninstall.py b/myenv/Lib/site-packages/pip/_internal/req/req_uninstall.py index 707fde1..26df208 100644 --- a/myenv/Lib/site-packages/pip/_internal/req/req_uninstall.py +++ b/myenv/Lib/site-packages/pip/_internal/req/req_uninstall.py @@ -5,7 +5,7 @@ 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.exceptions import LegacyDistutilsInstall, UninstallMissingRecord from pip._internal.locations import get_bin_prefix, get_bin_user from pip._internal.metadata import BaseDistribution from pip._internal.utils.compat import WINDOWS @@ -61,7 +61,7 @@ def uninstallation_paths(dist: BaseDistribution) -> Generator[str, None, None]: UninstallPathSet.add() takes care of the __pycache__ .py[co]. - If RECORD is not found, raises UninstallationError, + If RECORD is not found, raises an error, with possible information from the INSTALLER file. https://packaging.python.org/specifications/recording-installed-packages/ @@ -71,17 +71,7 @@ def uninstallation_paths(dist: BaseDistribution) -> Generator[str, None, None]: 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) + raise UninstallMissingRecord(distribution=dist) for entry in entries: path = os.path.join(location, entry) @@ -315,7 +305,7 @@ def __init__(self, dist: BaseDistribution) -> None: # 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) + self._normalize_path_cached = functools.lru_cache(normalize_path) def _permitted(self, path: str) -> bool: """ @@ -367,7 +357,7 @@ def remove(self, auto_confirm: bool = False, verbose: bool = False) -> None: ) return - dist_name_version = f"{self._dist.raw_name}-{self._dist.version}" + dist_name_version = f"{self._dist.raw_name}-{self._dist.raw_version}" logger.info("Uninstalling %s:", dist_name_version) with indent_log(): @@ -509,13 +499,7 @@ def from_dist(cls, dist: BaseDistribution) -> "UninstallPathSet": 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, - ) - ) + raise LegacyDistutilsInstall(distribution=dist) elif dist.installed_as_egg: # package installed by easy_install diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-311.pyc index bfca572fcbeda9ce6e5a36bd0f3547dd392e2ba0..770e89c854e8800af91a53b2814836c9fd1385d0 100644 GIT binary patch delta 18 Ycmcb~c$1N9IWI340}!~JoXB+^04}Hn0RR91 delta 18 Ycmcb~c$1N9IWI340}wbLn#gq?04|3F`2YX_ diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-311.pyc index 312b0d3cb8ec27ed2f39cc7c56bdb7158d0022b6..84c7476b1f8a238712c2cdcb4971cdf8b56837df 100644 GIT binary patch delta 19 ZcmaFE^@fXUIWI340}!~J+{l&03II1U1n~d> delta 19 ZcmaFE^@fXUIWI340}wbL+Q^l}3II0=1nB?( diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-311.pyc index 496670159c4c6f9787a0b2a718486441a95941bd..740301ccdb11032baed0a9187d8199d4af7c3aab 100644 GIT binary patch delta 18 YcmaFB_<)gXIWI340}!~JoXB+z056>d761SM delta 18 YcmaFB_<)gXIWI340}wbLn#gqx055z64gdfE diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-311.pyc index 78bbb893da1da474b6615b4a5068075cc9f5c18b..04c34689f5775b1eef861a630cefbdbd41441f2b 100644 GIT binary patch delta 2887 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 delta 2579 zcma);eN0=|6~N#1*YgJ$gR!w4FwYnWFVImUf)f)G1BC#|2m}IamJ|$rU=w1xy>{MW>HPXBFve zfS!ZzSpAN(=cMF9T1q7Ol3W6BTQlaoX=Z_*h^FB&+wZLHXfTYw)B&})sFuhp=B|6@ z{=4S>l_JLrU%wp69$eMyEY>vvv8p%NOltx{6AbF{;svAJiK?`Vp_`$fp^u@LVIRX* zh91y6pMV2Szw6N&m*W}(@QgEHV#lC^@T${IPOI-ZCk^CD@Om<~!)*N<3{OJV<06yr zuBXPi6BklugtXph82;+5!zZ(SM`$9&S1tOM1QD3S06W>K$ ziJabo66-Bygg}qmozbC#b#qLOw@0pqOqGRHK&jgWFIB}WJR1@jan86gp7VguAM7!G z(ZWkYOng~?g<#0=S7=KlX3mHcWgBypw{MK87_;D>9bWWHx^xI$^Vg9O{MLVrRO0bn z#0q<=Wnxp~)i?E_&=U(!Pt7Y5RZc#gpvnm)nU-b~r<7z^!ss_d=cy8no#82Pu1QKp zPbeKcJ&p!1kSh2jID%f@RXZN|CVo9{QckC7G({)b#FAQ6rV}#>h0+~3hacDOa`9M9 z;f&5O%reB`)7p3;dPgB%S7*9|tEpZU>Z*xHGYO^AJxB9hNAp{@+~bjt9Gy8wr)GrT z)W6>yy+~PK$Uur?$}V(GNBM~-ah%d2Bni_bC%2(LZQI7lIGXVe zutdb<5azHiG+LA)bDOc6W175SWJrcgZ01HxhqFz&m=0F9g)2q}WdrR&`Fv3-nogw9 zgRzOJGaxrMkuZ!kh8+=9No_}o^MY0+ILhG$ZjGydX#Chf_QJc5KNV)LBwsQeSEi3o zBxWX*(}`3%#f{SEaI5gfo@b+PGw@fGWTP$^Y^f>Zm;Nr!A6B}@j?pSQfDBVDlA z+G;8|27c5U;<3xSVL0rDf42t6d8pozMc>@o;nn?_!0&gQgk;+&(ZQXz5YfYDZP$qb z-Uzi5qxv8;uY;vN&Fsj!Dj+2 zx3@#h?mLEY+=ah2y4BBj;|U}1&fZbd31VcvP%ths^USB~B?c};YBp~0R-_sIdOxy_ z{7kiV4w5a**7RnKaI#qj{-mb6%tTMJR=Ct%L2RsmsyDmCdJ~oP>IMuhkfjz#ng z{XWxQSY+OW-TQBs1S|tY6F5ymc~Gr9aE3hFO}?Ng3Ij7jkHXSO6PbV;BR=04E~L=QLcuES zU;+#$)dwSwkv)_cn>2y(zIUr;DHu;k%8+(g09I^*!%;o6|tC@stFnt=T+1Mj|!a`^D@P%vn0SgvW+1nl1{=iQev z0Fkl!jv-?7@{_Uw7JP4`Ci06N?bhd9lP z^9!@HiR3IDQa>N7(wFhfXI{D{P%a;auN|py-NWLn=?Nj4&Pwn$41V>%ycx|Zv@a^CJ`!Hw0nR@TH;g8yI;D^{PT$Nqj<#by2Fk!)#u+W!#XxA+f2$$!59 diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py b/myenv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py index 5ddb848..1dd0d70 100644 --- a/myenv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py +++ b/myenv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py @@ -10,9 +10,6 @@ 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 @@ -52,7 +49,7 @@ logger = logging.getLogger(__name__) -DiscoveredDependencies = DefaultDict[str, List[InstallRequirement]] +DiscoveredDependencies = DefaultDict[Optional[str], List[InstallRequirement]] def _check_dist_requires_python( @@ -104,9 +101,8 @@ def _check_dist_requires_python( return raise UnsupportedPythonVersion( - "Package {!r} requires a different Python: {} not in {!r}".format( - dist.raw_name, version, requires_python - ) + f"Package {dist.raw_name!r} requires a different Python: " + f"{version} not in {requires_python!r}" ) @@ -246,9 +242,9 @@ def _add_requirement_to_set( return [install_req], None try: - existing_req: Optional[ - InstallRequirement - ] = requirement_set.get_requirement(install_req.name) + existing_req: Optional[InstallRequirement] = ( + requirement_set.get_requirement(install_req.name) + ) except KeyError: existing_req = None @@ -263,9 +259,8 @@ def _add_requirement_to_set( ) if has_conflicting_requirement: raise InstallationError( - "Double requirement given: {} (already in {}, name={!r})".format( - install_req, existing_req, install_req.name - ) + f"Double requirement given: {install_req} " + f"(already in {existing_req}, name={install_req.name!r})" ) # When no existing requirement exists, add the requirement as a @@ -323,6 +318,7 @@ def _set_req_to_reinstall(self, req: InstallRequirement) -> None: """ # Don't uninstall the conflict if doing a user install and the # conflict is not a user install. + assert req.satisfied_by is not None if not self.use_user_site or req.satisfied_by.in_usersite: req.should_reinstall = True req.satisfied_by = None @@ -421,6 +417,8 @@ def _populate_link(self, req: InstallRequirement) -> None: if self.wheel_cache is None or self.preparer.require_hashes: return + + assert req.link is not None, "_find_requirement_link unexpectedly returned None" cache_entry = self.wheel_cache.get_cache_entry( link=req.link, package_name=req.name, @@ -534,6 +532,7 @@ def add_req(subreq: Requirement, extras_requested: Iterable[str]) -> None: with indent_log(): # We add req_to_install before its dependencies, so that we # can refer to it when adding dependencies. + assert req_to_install.name is not None if not requirement_set.has_requirement(req_to_install.name): # 'unnamed' requirements will get added here # 'unnamed' requirements can only come from being directly diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-311.pyc index 1d652ec3a3dcc1a064e0291f14b287d4290d415c..b45883d99f7f617f40a3585cd0c012dac91f25c3 100644 GIT binary patch delta 18 YcmaFD_=J&bIWI340}!~JoXB+x05B;9A^-pY delta 18 YcmaFD_=J&bIWI340}wbLn#gqv05Avz8UO$Q diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-311.pyc index 1738bd7af508de298facf8d96bc074c5d50fb8c8..fe4d2e78c35df952b32b72b76dda070dc72efff2 100644 GIT binary patch delta 2569 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 delta 10345 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 delta 7023 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 SZwp_KAM^T8{|_#|zWon=h^eCh diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-311.pyc index 1941391ecc52934a27a3e3f2c36fd38edefde966..9e8bae680b2639c74666840f887613076eb28eac 100644 GIT binary patch delta 1982 zcmah}ZEO@p7@pbN-MhW+efD}EZE2T&q&=huJqiIN5TFsOd_@uoD|j62v@E&XE3;c# zOlzCSk7@`)wvl3t!H?8bjDMOK6B8rEKN?M1)5LQV75?$hGe}bX)B$gkk}k7bQ5Z| zs0~CWLE;-i#80C3NlRkk{%i z@@i6(N%VhhMJ)ifsV8iAxr_dbSk!`G+{mGQNDEy=T9_o}Jg^(6)uJ|O+!2(HEEI4j zSD(gC=m4?uTHeYJ80Yf^U9+!xGIc&MZijlm58E$G?VIs9>PIIo9_J96;3hod+&Dgu zD8A&EAb8`RIWWChOl0F3BeK{jojevyJ9S(aX>1Z z6>5sJt0v>Z91z@GCBbMM+rNs5UheU8!sr+r{)F(VaA~62j^a@?<~fE&;iABvJ+{h! zI{C`*z>ra*x-q1jC)CtShSF&&r9pGku%C&JXh za;l|*8iZ~aUJp!ruf)oA(JRJcT?hPSIacAKQg=DoJj-7f-w~$=D$OXIS_~=WaIze2 znm)w7vfTKi-139mGCR5?cP-0Zi|)VjU@ZzywpLJ`1pGDlS&qJW@Qs5Nj*INW6%j>} z<#1$1oT-E6_kcGL`~v}0T!^7S(|<8n`5&&bva(W106S~zYFjZAu-kY2yM=o0mf+vh zAlwS=*b^3RhXs%qPKq9G3rjP~vUgsjtxOIvNHTC$jZA6+s0LGEg|4x$`xK!KMhEOK zeXnu%(ZXIS@1%0NMQHBSh+eRAqq=n_ryC}r7J<_Rea?PMzKz=# zjs=D}+-iRt`o6WBak;*wndBZLyXiGwJ_~o@Y5SLOZ-6D8Bj|=k#%S1Xj_A=|He(Zj z3CRaD!1Zg9o;5SjxzD_XYv4nnwi_Fkg4yL@cF~um?F)A!Cvew#(55+u(>1!0i5`c` zY;^Ex$|z0tA}Gof(2@G5@%#3B^}7zS)#3W}KtnSO*rlTz7_d;e+e>@g`EHaQAB#lZ zDp8m2B=ZjJ9AC~2k$o$i5Lu{lZ`=E0lepdfF19ndnK5kvn8#I5*h|Z{)z;7%{*WoR zF<`#XfPJ)~)Z{wA{DBlQF3`OonYBrG8@lkvwiMq8?Azl<*9Dmwf2vd}P|2O48y3xi zL|MS;RtCEn^xI#=8=Ia5asJ_A%yrsTgUN+TJce6bH`rjhneJ!0!vKz#z#V{{8u>zojGZRK7Q8Dab#t9R1uq75{gQ@=wcpKrI>5MM3=S~D$PsdGguv^w zH*aVjL8svqNeu%X|tuBunBx|+YVZE1^n*W+;$ zSbLvd9q0+qn9#3GC`B~L91Up223R7<7k)ACwDw`PvU*4alrUt9249wfM zp{m-)SXvjRylJ%QWgY6s1>=T03Pv;R@}Mj^V)C2&bY;Y;DxG!U69IrZL&VWG5rPPI zD1=rRplkpn?Ij}ekvplc21ln{bYId1PF7Aj!xd5USxNfgw9LlBVimxj>?>xyUJu@0 zdEb0WW0jJ3P@!@8*8ifu0U359I0DgxT)f1J@bf^54$Du0%^uXO>bWB0qrxlOgSo&4 zWV9gz1_li1^FgqUPRiH81gLxoo}#IB5P?xCIVM`rRIAFyOqHG$NG{{6B$F3`cp=nH zugS-uUHeccZHN?n#CilArAQ;-1O#3rt=fEhcvWX^h>O0VlCaC2vHRE_PSMMcUbuK(>;$X4Li!R((OFp^ z%|P`d(Gx8mOw;;HrMz(2j9hU@w1OpYl%gG>8zCzfqVdEYFz0@VMbN!=1@aXmR!2j2 z8|X}j#eR$(1dv_vfm*G5Cv6G4SAzxQcRkx$eLL(YZk?#Srw~h zQ*4@Dv1<;+!S5OKPOU|0fxStU^DfP;xV2WLRr4qwE;HxbG_T_2drRJ@`4zt?5EJc$ z7*?hMQzvYP*o&q)@tf+` zrcrSLQuV2ptAW+YszKsVL&T|?i6twm;nT)NFuVd!V=4Zo){t7qSRW|UBJIGJM4yEh-3p*f z0I?Vt>~bX9b11>oD#C47*RpHfl4Tv`DFxXn$9}P``mG;N^c%;igoaW>@JE`G?4`u0JNU-`yT z%^Y9i_H-OxHDivFBmX4{61tbULIdK*EaM*lvkU&oD32gD?n}keQ*K{mqk+wEdp@u* zFoI5a8I0V7#xRat%1}}$^TOyxkibV(XdLf00xq)2;OpSx^WbnC^Q0@Iit1B>e#Ul& zdcmR)+Bi9cF)aJY{PUC+DP4~aHlWO)QEGHu13C#O$MXJ+0mQve|KtWMHx zjh1mnZ%6AL2%`wQ*gv5!pqe+r8^nC|&oGt58k>xM*?mTM3+cnxRnsES;|fxQFW{X# z(HM|$b-3dlX&VxD44N|tZ;InWF=-HB%$g07pi@Pv656Oyqw$Rr)qJc!?qiPlhfX~F6&`VCyvCdxkTa;d8$2#BJ zdOH$Zj`Y`^g1hgYV0PQ?Bh&@6)y6pwq%~`qIX!or)a<~*S)ihZ98tjqJ1P0u_Qb~C zCTDpvhDI_K(DO@=rvoL&*`-7*eh;>~AD|-KafN?z_59@Oxjb^qHMr~=T(S(pjNeUs zns}07bPt+6npN~R!LF_y6d$nP*LGSO14o}>j$}yY^-x)FvK=@vp4=q<#ZDxL`47vC z#43`P-Ao=`UqK%@1@r(wv&(cB3JL(LGtaOisf75DeUN&C`$>n{gVg#358gH*oIt>i z@h;X3IjGVWJmPN&btAMOJcodsq-F$UBefzF5l$i?uXtcE=m2o8VoSg+RwgGoK7!-nX0>Ug{WL_K(!f z-OQN|4x!p6*gR*`%hpKUjz?iNye0~=t8(ycdC3&HWr{4DB6W%FO($&k41yeO91H3B zKI{R{A|0ojagQ@zvu0-tGv#72uk#P9$>sS{u5gH1dlC}0vy(lMkrFK)&B0jd)PWYp z=?qL7uNE&TFWwGxh`$Xqg}@8n2G*$qUOewaz#i0`Q?E4L?L;>|R3OreUE-)NiM~3p@@aS$ NMhZ3e|3}X!>|ay8@O1zH delta 2147 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 Xr{q2vldqQK-=aoDs1eR|K2rY&5|me( delta 4529 zcmb_fYitzP6`nggvpf5oT|akiue}ez9=!O44K_B$KtvQbaVVu#vw$|PXDkf6wsY5M zgdJh3(ugD$0S;;?X%kbaNl}!NDpDV6h?-XIZ&RTbjg%_<%#TV&@GGrK&$(l;Sud$n zb?p7--h1vj_jSH=&%Ao_&$-Zh!JtpVXYU`*jt|wG4@KwyjQ!-gzDzGeLRF?B{ z!IgCtl&m7^uDn`sXWgQ#+ui{kg4IU;6#LZ+fjTPO3Q7D>FPm23dZK`i^Q z95R{Z!n!`Ln0~B>O&5+FfGhHmkd8*L%C=Ip^5a~Gfa@Cb!^f^%Qw0hP*>)9YI2WB5 zug0b#LrCx%*r6El5H(Q8Q_^R8#kuZ_gE#clO+B@wrFaxNH^<;d$~PmV&FiV_1Ks;d zD~mv@YOpBGWqMnkvBWTTV46=Iv&Lp}lcNRe5j8Ti5ym|mSrsgJqK?SUGc*J>hbCr6_g@EgrYHqw-95Kc+A^vZ>kf79FkqPN}9J8tS7 zOIio6@OrEXlHST1GR7+j)>?vL?_QRKvtAnaJ@2;K)oxW}T1H6FR^IdWu?^7Xi)vA9 zG9o+$BfiFYFBz;Qs3T|~NF&%9Zqc;GXHIa1+BOn26Bq)ih5NpPaL#|tEi^-Lrz^JVqDTMlF6y^*bkQ)n zXaHR_B3v|RSHYEVm1Zjw+DPPU6?yw)AaPy-YqN!A8$MB=FX zL4I~p zW~&%9CZ-LU_ha2=#fO^-yQ0Hv54;vNj?f8w$ugYw*_OD5uUR>h_~Jf3vua{=(o7hN z*bOu{ou8PoU3qKLR*p?gOrm8vC|jK#k__U zFg`@xN*C4&fx5P)VH6c9TnWaXJ9sg>q&F>TO%8eVkDjaRXQ`)9e()-@{nOmyR^A#d zT1CU{?D-JN_&)em{f4ygB(jCEb=n#$(q)n$x>Fb8bp= z8}(`@@DP-V0=$C+3V}GUG68^#2+~PiXh2STdwX5VlNN&qJ$xYWgW{DnZst#Qn4PvNFBm@ zg{k5R>2?evnHUT`jC}vWLwu+D-4xuGD~Df}UzT#{dCo(p z&FO%V;lhkBH-?d5!W^Bk43{9iXy@bD=TS=4!ZR(+O%v2kw<|I@mO7&>gl^R};Y&Y* zf8xfD!KW=o4H;h-1R5?Fo8kqsKvSR?U|g#DapRJ1(7$G&{s)m595$ZKh_J1chV8Oe z(>SrDhg;J;mz#$BMkj_NOnRIfL*_?mCW68BG%{_)N|2z&*-f~ubs}IFfo-WNqbrDC zsw)C@Bk49!pni!=2N6z5pJOUBe^XB{X=z-~?cTu@Ef()gaq*PeF=!5(#T+o4#^$hk zm-2^|gzwc83n!MeC>o+dcGI9l9l*H1T9 zpC=Fu6+?=x6@yTU_N6vZm@;3?TZ8-uSf#LBoJ3r9F~)Ae<(kKtO5xHRt)ZIMP%07*@gHc0eDMGP diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-311.pyc index 0b8b46d9705203673fed761cb47063235f177c33..d3076b988b434aa8cf5a2accac56392daaf3e3d2 100644 GIT binary patch delta 19 ZcmbP}IVY2AIWI340}!~J+{iV_1OPc71#SQU delta 19 ZcmbP}IVY2AIWI340}wbL+Q>D@1OPbp1!e#M diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py index 9c0ef5c..0f31dc9 100644 --- a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py +++ b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py @@ -1,15 +1,15 @@ -from typing import FrozenSet, Iterable, Optional, Tuple, Union +from dataclasses import dataclass +from typing import FrozenSet, Iterable, Optional, Tuple from pip._vendor.packaging.specifiers import SpecifierSet from pip._vendor.packaging.utils import NormalizedName -from pip._vendor.packaging.version import LegacyVersion, Version +from pip._vendor.packaging.version import 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: @@ -19,13 +19,11 @@ def format_name(project: NormalizedName, extras: FrozenSet[NormalizedName]) -> s return f"{project}[{extras_expr}]" +@dataclass(frozen=True) class Constraint: - def __init__( - self, specifier: SpecifierSet, hashes: Hashes, links: FrozenSet[Link] - ) -> None: - self.specifier = specifier - self.hashes = hashes - self.links = links + specifier: SpecifierSet + hashes: Hashes + links: FrozenSet[Link] @classmethod def empty(cls) -> "Constraint": @@ -116,7 +114,7 @@ def name(self) -> str: raise NotImplementedError("Override in subclass") @property - def version(self) -> CandidateVersion: + def version(self) -> Version: raise NotImplementedError("Override in subclass") @property diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py index 4125cda..d30d477 100644 --- a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py +++ b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py @@ -2,6 +2,7 @@ import sys from typing import TYPE_CHECKING, Any, FrozenSet, Iterable, Optional, Tuple, Union, cast +from pip._vendor.packaging.requirements import InvalidRequirement from pip._vendor.packaging.utils import NormalizedName, canonicalize_name from pip._vendor.packaging.version import Version @@ -9,6 +10,7 @@ HashError, InstallationSubprocessError, MetadataInconsistent, + MetadataInvalid, ) from pip._internal.metadata import BaseDistribution from pip._internal.models.link import Link, links_equivalent @@ -21,7 +23,7 @@ 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 +from .base import Candidate, Requirement, format_name if TYPE_CHECKING: from .factory import Factory @@ -145,7 +147,7 @@ def __init__( ireq: InstallRequirement, factory: "Factory", name: Optional[NormalizedName] = None, - version: Optional[CandidateVersion] = None, + version: Optional[Version] = None, ) -> None: self._link = link self._source_link = source_link @@ -154,6 +156,7 @@ def __init__( self._name = name self._version = version self.dist = self._prepare() + self._hash: Optional[int] = None def __str__(self) -> str: return f"{self.name} {self.version}" @@ -162,7 +165,11 @@ def __repr__(self) -> str: return f"{self.__class__.__name__}({str(self._link)!r})" def __hash__(self) -> int: - return hash((self.__class__, self._link)) + if self._hash is not None: + return self._hash + + self._hash = hash((self.__class__, self._link)) + return self._hash def __eq__(self, other: Any) -> bool: if isinstance(other, self.__class__): @@ -185,16 +192,15 @@ def name(self) -> str: return self.project_name @property - def version(self) -> CandidateVersion: + def version(self) -> Version: 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, + return ( + f"{self.name} {self.version} " + f"(from {self._link.file_path if self._link.is_file else self._link})" ) def _prepare_distribution(self) -> BaseDistribution: @@ -216,6 +222,13 @@ def _check_metadata_consistency(self, dist: BaseDistribution) -> None: str(self._version), str(dist.version), ) + # check dependencies are valid + # TODO performance: this means we iterate the dependencies at least twice, + # we may want to cache parsed Requires-Dist + try: + list(dist.iter_dependencies(list(dist.iter_provided_extras()))) + except InvalidRequirement as e: + raise MetadataInvalid(self._ireq, str(e)) def _prepare(self) -> BaseDistribution: try: @@ -253,7 +266,7 @@ def __init__( template: InstallRequirement, factory: "Factory", name: Optional[NormalizedName] = None, - version: Optional[CandidateVersion] = None, + version: Optional[Version] = None, ) -> None: source_link = link cache_entry = factory.get_wheel_cache_entry(source_link, name) @@ -269,9 +282,9 @@ def __init__( # 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 - ) + assert ( + version == wheel_version + ), f"{version!r} != {wheel_version!r} for wheel {name}" if cache_entry is not None: assert ireq.link.is_wheel @@ -310,7 +323,7 @@ def __init__( template: InstallRequirement, factory: "Factory", name: Optional[NormalizedName] = None, - version: Optional[CandidateVersion] = None, + version: Optional[Version] = None, ) -> None: super().__init__( link=link, @@ -353,13 +366,13 @@ def __str__(self) -> str: 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: object) -> bool: + if not isinstance(other, AlreadyInstalledCandidate): + return NotImplemented + return self.name == other.name and self.version == other.version - def __eq__(self, other: Any) -> bool: - if isinstance(other, self.__class__): - return self.name == other.name and self.version == other.version - return False + def __hash__(self) -> int: + return hash((self.name, self.version)) @property def project_name(self) -> NormalizedName: @@ -370,7 +383,7 @@ def name(self) -> str: return self.project_name @property - def version(self) -> CandidateVersion: + def version(self) -> Version: if self._version is None: self._version = self.dist.version return self._version @@ -434,14 +447,6 @@ def __init__( """ 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: @@ -469,7 +474,7 @@ def name(self) -> str: return format_name(self.base.project_name, self.extras) @property - def version(self) -> CandidateVersion: + def version(self) -> Version: return self.base.version def format_for_error(self) -> str: @@ -489,50 +494,6 @@ def is_editable(self) -> bool: 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 @@ -542,7 +503,18 @@ def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requiremen if not with_requires: return - valid_extras = self._calculate_valid_requested_extras() + # The user may have specified extras that the candidate doesn't + # support. We ignore any unsupported extras here. + valid_extras = self.extras.intersection(self.base.dist.iter_provided_extras()) + invalid_extras = self.extras.difference(self.base.dist.iter_provided_extras()) + for extra in sorted(invalid_extras): + logger.warning( + "%s %s does not provide the extra '%s'", + self.base.name, + self.version, + extra, + ) + for r in self.base.dist.iter_dependencies(valid_extras): yield from factory.make_requirements_from_spec( str(r), @@ -584,7 +556,7 @@ def name(self) -> str: return REQUIRES_PYTHON_IDENTIFIER @property - def version(self) -> CandidateVersion: + def version(self) -> Version: return self._version def format_for_error(self) -> str: diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py index 4adeb43..1f31d83 100644 --- a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py +++ b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py @@ -3,6 +3,7 @@ import logging from typing import ( TYPE_CHECKING, + Callable, Dict, FrozenSet, Iterable, @@ -11,6 +12,7 @@ Mapping, NamedTuple, Optional, + Protocol, Sequence, Set, Tuple, @@ -21,6 +23,7 @@ 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.packaging.version import Version from pip._vendor.resolvelib import ResolutionImpossible from pip._internal.cache import CacheEntry, WheelCache @@ -28,6 +31,7 @@ DistributionNotFound, InstallationError, MetadataInconsistent, + MetadataInvalid, UnsupportedPythonVersion, UnsupportedWheel, ) @@ -50,7 +54,7 @@ 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 .base import Candidate, Constraint, Requirement from .candidates import ( AlreadyInstalledCandidate, BaseCandidate, @@ -70,7 +74,6 @@ ) if TYPE_CHECKING: - from typing import Protocol class ConflictCause(Protocol): requirement: RequiresPythonRequirement @@ -177,7 +180,7 @@ def _make_candidate_from_link( extras: FrozenSet[str], template: InstallRequirement, name: Optional[NormalizedName], - version: Optional[CandidateVersion], + version: Optional[Version], ) -> Optional[Candidate]: base: Optional[BaseCandidate] = self._make_base_candidate_from_link( link, template, name, version @@ -191,7 +194,7 @@ def _make_base_candidate_from_link( link: Link, template: InstallRequirement, name: Optional[NormalizedName], - version: Optional[CandidateVersion], + version: Optional[Version], ) -> Optional[BaseCandidate]: # TODO: Check already installed candidate, and use it if the link and # editable flag match. @@ -211,7 +214,7 @@ def _make_base_candidate_from_link( name=name, version=version, ) - except MetadataInconsistent as e: + except (MetadataInconsistent, MetadataInvalid) as e: logger.info( "Discarding [blue underline]%s[/]: [yellow]%s[reset]", link, @@ -391,6 +394,7 @@ def find_candidates( incompatibilities: Mapping[str, Iterator[Candidate]], constraint: Constraint, prefers_installed: bool, + is_satisfied_by: Callable[[Requirement, Candidate], bool], ) -> Iterable[Candidate]: # Collect basic lookup information from the requirements. explicit_candidates: Set[Candidate] = set() @@ -456,7 +460,7 @@ def find_candidates( 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]) + and all(is_satisfied_by(req, c) for req in requirements[identifier]) ) def _make_requirements_from_install_req( @@ -668,8 +672,8 @@ def _report_single_requirement_conflict( 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() + versions_set: Set[Version] = set() + yanked_versions_set: Set[Version] = set() for c in cands: is_yanked = c.link.is_yanked if c.link else False if is_yanked: @@ -799,7 +803,7 @@ def describe_trigger(parent: Candidate) -> str: + "\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 " + + "2. remove package versions to allow pip to attempt to solve " + "the dependency conflict\n" ) diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py index 8663097..a1d57e0 100644 --- a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py +++ b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py @@ -9,13 +9,18 @@ """ import functools +import logging from collections.abc import Sequence from typing import TYPE_CHECKING, Any, Callable, Iterator, Optional, Set, Tuple from pip._vendor.packaging.version import _BaseVersion +from pip._internal.exceptions import MetadataInvalid + from .base import Candidate +logger = logging.getLogger(__name__) + IndexCandidateInfo = Tuple[_BaseVersion, Callable[[], Optional[Candidate]]] if TYPE_CHECKING: @@ -44,11 +49,25 @@ def _iter_built(infos: Iterator[IndexCandidateInfo]) -> Iterator[Candidate]: for version, func in infos: if version in versions_found: continue - candidate = func() - if candidate is None: - continue - yield candidate - versions_found.add(version) + try: + candidate = func() + except MetadataInvalid as e: + logger.warning( + "Ignoring version %s of %s since it has invalid metadata:\n" + "%s\n" + "Please use pip<24.1 if you need to use this version.", + version, + e.ireq.name, + e, + ) + # Mark version as found to avoid trying other candidates with the same + # version, since they most likely have invalid metadata as well. + versions_found.add(version) + else: + if candidate is None: + continue + yield candidate + versions_found.add(version) def _iter_built_with_prepended( diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py index 315fb9c..fb0dd85 100644 --- a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py +++ b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py @@ -1,5 +1,6 @@ import collections import math +from functools import lru_cache from typing import ( TYPE_CHECKING, Dict, @@ -234,8 +235,10 @@ def _eligible_for_upgrade(identifier: str) -> bool: constraint=constraint, prefers_installed=(not _eligible_for_upgrade(identifier)), incompatibilities=incompatibilities, + is_satisfied_by=self.is_satisfied_by, ) + @lru_cache(maxsize=None) def is_satisfied_by(self, requirement: Requirement, candidate: Candidate) -> bool: return requirement.is_satisfied_by(candidate) diff --git a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py index 4af4a9f..b04f41b 100644 --- a/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py +++ b/myenv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py @@ -1,3 +1,5 @@ +from typing import Any, Optional + from pip._vendor.packaging.specifiers import SpecifierSet from pip._vendor.packaging.utils import NormalizedName, canonicalize_name @@ -17,6 +19,14 @@ def __str__(self) -> str: def __repr__(self) -> str: return f"{self.__class__.__name__}({self.candidate!r})" + def __hash__(self) -> int: + return hash(self.candidate) + + def __eq__(self, other: Any) -> bool: + if not isinstance(other, ExplicitRequirement): + return False + return self.candidate == other.candidate + @property def project_name(self) -> NormalizedName: # No need to canonicalize - the candidate did this @@ -41,14 +51,36 @@ 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._equal_cache: Optional[str] = None + self._hash: Optional[int] = None self._extras = frozenset(canonicalize_name(e) for e in self._ireq.extras) + @property + def _equal(self) -> str: + if self._equal_cache is not None: + return self._equal_cache + + self._equal_cache = str(self._ireq) + return self._equal_cache + def __str__(self) -> str: return str(self._ireq.req) def __repr__(self) -> str: return f"{self.__class__.__name__}({str(self._ireq.req)!r})" + def __eq__(self, other: object) -> bool: + if not isinstance(other, SpecifierRequirement): + return NotImplemented + return self._equal == other._equal + + def __hash__(self) -> int: + if self._hash is not None: + return self._hash + + self._hash = hash(self._equal) + return self._hash + @property def project_name(self) -> NormalizedName: assert self._ireq.req, "Specifier-backed ireq is always PEP 508" @@ -96,14 +128,38 @@ class SpecifierWithoutExtrasRequirement(SpecifierRequirement): 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._equal_cache: Optional[str] = None + self._hash: Optional[int] = None self._extras = frozenset(canonicalize_name(e) for e in self._ireq.extras) + @property + def _equal(self) -> str: + if self._equal_cache is not None: + return self._equal_cache + + self._equal_cache = str(self._ireq) + return self._equal_cache + + def __eq__(self, other: object) -> bool: + if not isinstance(other, SpecifierWithoutExtrasRequirement): + return NotImplemented + return self._equal == other._equal + + def __hash__(self) -> int: + if self._hash is not None: + return self._hash + + self._hash = hash(self._equal) + return self._hash + class RequiresPythonRequirement(Requirement): """A requirement representing Requires-Python metadata.""" def __init__(self, specifier: SpecifierSet, match: Candidate) -> None: self.specifier = specifier + self._specifier_string = str(specifier) # for faster __eq__ + self._hash: Optional[int] = None self._candidate = match def __str__(self) -> str: @@ -112,6 +168,21 @@ def __str__(self) -> str: def __repr__(self) -> str: return f"{self.__class__.__name__}({str(self.specifier)!r})" + def __hash__(self) -> int: + if self._hash is not None: + return self._hash + + self._hash = hash((self._specifier_string, self._candidate)) + return self._hash + + def __eq__(self, other: Any) -> bool: + if not isinstance(other, RequiresPythonRequirement): + return False + return ( + self._specifier_string == other._specifier_string + and self._candidate == other._candidate + ) + @property def project_name(self) -> NormalizedName: return self._candidate.project_name @@ -148,6 +219,14 @@ def __str__(self) -> str: def __repr__(self) -> str: return f"{self.__class__.__name__}({str(self._name)!r})" + def __eq__(self, other: object) -> bool: + if not isinstance(other, UnsatisfiableRequirement): + return NotImplemented + return self._name == other._name + + def __hash__(self) -> int: + return hash(self._name) + @property def project_name(self) -> NormalizedName: return self._name diff --git a/myenv/Lib/site-packages/pip/_internal/self_outdated_check.py b/myenv/Lib/site-packages/pip/_internal/self_outdated_check.py index 0f64ae0..2185f2f 100644 --- a/myenv/Lib/site-packages/pip/_internal/self_outdated_check.py +++ b/myenv/Lib/site-packages/pip/_internal/self_outdated_check.py @@ -9,6 +9,7 @@ from dataclasses import dataclass from typing import Any, Callable, Dict, Optional +from pip._vendor.packaging.version import Version from pip._vendor.packaging.version import parse as parse_version from pip._vendor.rich.console import Group from pip._vendor.rich.markup import escape @@ -17,7 +18,6 @@ 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 @@ -191,7 +191,7 @@ def _self_version_check_logic( *, state: SelfCheckState, current_time: datetime.datetime, - local_version: DistributionVersion, + local_version: Version, get_remote_version: Callable[[], Optional[str]], ) -> Optional[UpgradePrompt]: remote_version_str = state.get(current_time) diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-311.pyc index e44f8c7426ac42ee5253bcd0ae1dcd9ae0e4bdb4..b03fb9eca8ad67645c5e9e88b53bf8eca6bbc3be 100644 GIT binary patch delta 18 Ycmcb@c!iN`IWI340}!~JoXB+w04@0h@&Et; delta 18 Ycmcb@c!iN`IWI340}wbLn#gqu04>-A>Hq)$ diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/_jaraco_text.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/_jaraco_text.cpython-311.pyc index ca0e310fdbf5e6116de68bc54bc091b7364e1af5..86302d737a6e585746b15ac0d8209a0fea8e4e41 100644 GIT binary patch delta 34 ocmZ3Xx?GiaIWI340}!~J>`N2d$a{^KF>dn{-f+gvHvBov0I1Xn@&Et; delta 34 ocmZ3kxPr*f$a{^KF@EzC-f+gvR{Xil0H{X^>i_@% diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/_log.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/_log.cpython-311.pyc index 0dfca878726f1c78658c3b3086c3056452ebc5d9..3c3807d36bca3a748c3a6d4e3694cd3f57268a26 100644 GIT binary patch delta 19 Zcmey!|B;_-IWI340}!~J+{pEu9RN9;1&jay delta 19 Zcmey!|B;_-IWI340}wbL+Q{{s9RN9V1%v*5^u=?MTH%jgz$7+D-Angnqab$0eaSADBW}D2uDvRaTa@Vs=&P z)Sw)4=pi(PJ*1a{X~9i#4}~83CzRe~Be0lLpofy1Lefi4d9%uzggj<`@6EjTelzpl z{8##Ww*PBBpFtoO|M}i?421p_i&S#YjmIk(p?ioT8&OP28`~t&k}V}#w&g@CwgOse ztJ|8bVbnxa{u$dkL9WyS?uodWePBC)3DSpYXQ|@mJVMpmvYn@zTYz=Zlc^4C(^Xof zBou%eTZzf?E@_q1-PTlU*_F6yTZ5zfQVyNkA|g7-xN_@Mnnx>>UAs!j2C`;uezp-2mYN{~>m*I8bW$|=mnKdJkDi#!zWhgpE9N-y#j zFK{)CnBM@_?q*|av*~i3xna;_4Y1r!BcOh#$yHYz7&Zi7Dhe2a?J)zmhoW>JbZgRW zu=bKVJ$J>+a<#vUZ^H3=BJ&lYc$e%-zmt9N9-Kr#Eu||QGpN*ANMYvyESVerb~j*A z+y9Ci>6JsSh(d&{lEkoi5r0NNn%PI8cmz~vQX*asx^Bmb+;1W$Wnl{tu>v#v7~mHA zUqz+b(40Ruts~RA|K_2&G&Gm~_~Ov~=(xCgR9qe9ia)+}e|an+^CEtPh?#jJV2p^7 zVXq4^@ffalccOS*J9~|=H(D%;Ui5Bym5^B?Q)>s!CNzSHzt5#` zC**3h(-k{{IlikcUJzdgToL1v--(je^W4`i3;m$u_#H1`Z;J@y@dYfiyR&o*q^ghSlYPJOg8_qjmf_9!rV>g##FsD#>D0pP%US vOB4O+LXtIs8Y;dwD4d6JD+|Qg!kvZV_%D4y7R`7Dx?&tj delta 445 zcmY*VJxc>Y5Z$lb$0nCA4N4@S2to=GtVIR&7ihI8S2&k5XUxeZ7GhzOT9GYmjY34M z#L`XzB8XUDYa!U$S-G2dpbuu=%<$eT=4tGsaD44J94V|kp42u?gx>X%fc*|%uWC3) zfCK^zq=5wk13Uqd_*YT;ybzjjn?IKWV@8R|I^QXhX<7666yrq=#2g0J4s%85!UW*~f2= zr4&^X*@_}dcF9r7QDgRgik?!Omv=@PXXT4gQT@{>=Q3JHlQtno%${7c=PJe6bX^Fy zT{kuxq3_q5epFPln6?gEvTx6pbgbIiQB3R2_ArCVDxaLuFS>*+1uFmm delta 19 Zcmcb~dXtrFIWI340}wbL+Q@aD2>>*T1tS0e diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-311.pyc index 718b41956b3a73db7e9c6aa5e233b2e1ad209cfb..197f0488451948dd33e07c46bcf599a4deb35338 100644 GIT binary patch delta 277 zcmcbma$kjaIWI340}!~J>`SZO$eY87@5;#N$@qZ*nR>v(|A7@Ez{VgXHA8ud><4xTpM!x<3N=pNm0Q tdWP{7-4EOlJ`V$r$OPve+Yh`DJ|6=c*9U$G8^sQojY24*MFPNZ006cxN9q6o delta 272 zcmcbwa!ZAGIWI340}wbL>Pyq!$eY8hh6 zg0>$xSvk2r@G q6x|Qp5IzqBkH`e)9@`JR5I!FR8`lSZ2ph!?n2kaxqD2D0AOHYu0Y`SZJ$m_z$s53c;G0$DShN*@jiwPtJ0$D5&nt@?9LkdWS z6^YM`qLK|EGnaL;B9o#wA54USVHwcG)o@db%)qw5&8p&MV5mj4mjkA^NWO-70q5ji zCPhY$$?KVn8AT>PW>U7s)XNRmAq&z0;~~>2EI=1?Pj+NhW@SxbTfj3pli8S&eezsp zbGBcM+P@ebCf{QgW8|Ium05AK91ABSqx@tIR#){K{E|KOSNN4K@B{+Uf~X~N5Y~pQ zE%{f>{2`o=%$ujM#xiP(0WB;N1rnOfMIc8Ofm~7q3LH(wB1Iro%m^eDisU9svCA^5 zOtxURXH?i+!JfjzC_ecvr<5q%fFdcN!e5NGKz$OEdAPRJO91&rpa{|ADpCcpLBdPCUnf|h;lm7#0FasOEf*#(v?eLL|TS;38xoZ=1d^uH6!G`JTnNBF2hMt zp&l6G9zA=)N;>F`*u+kD(v~H5=^A9k7h1Y%B&LBw$e7BMOrl_3jU`|I-<&C*D6^8T zaed;*)oU{J3A}plwS-E+?8+c z%J)q6*~Wgxo8(> z7&N+m58J*>@dMuM*6Qs5OJd%<0baama(X$dtn(N=>IG3Z;64WZX4DKj6^66jvX5sZ z9l?49&=o(dy)9RXnxu-2=Tu!(bY9Xl-ETyGz1DabbogvTS;^p|O2U7WtFnsJ|0^B? z^WvwSgKBK0`v9JJoOyexpax2krdmA=+gO$5JA$5))eDbO*LFhQYX{eHJ>GI$&{XR$ D;+B3| diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/egg_link.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/egg_link.cpython-311.pyc index 2807dba376cb8d0adfa3601a46521362dd469f75..631b6a4ae56518e1a30076fe78039d6c02b63215 100644 GIT binary patch delta 19 ZcmaDa{a%`DIWI340}!~J+{pEm7XUi$1*8A~ delta 19 ZcmaDa{a%`DIWI340}wbL+Q{{k7XUiN1)Kl? diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-311.pyc index e42238241fb130bf8b271e7f199ba5a3a67fe768..88a1a82c98a87135010f5f0b0db9dcaf6e6024c0 100644 GIT binary patch delta 19 ZcmbO)G+&5oIWI340}!~J+{h)$2>>kE1RekY delta 19 ZcmbO)G+&5oIWI340}wbL+Q=o!2>>jw1Qq}Q diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-311.pyc index 2d2e692b64635883833dadc7a468b86d4f1c2276..efcc9a73b7ca54b7093a1748767be6f47e5cd39f 100644 GIT binary patch delta 19 ZcmZ3exKNR6IWI340}!~J+{iUu001y41jzsZ delta 19 ZcmZ3exKNR6IWI340}wbL+Q>Cs001xm1i=6R diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-311.pyc index ccb96eedbcc8cac8588a0c22073d1d1293e997e4..479558af4a069dfb00f3b91b391d271254334729 100644 GIT binary patch delta 19 Zcmdnwu*rdIIWI340}!~J+{mS&001@J1j+ya delta 19 Zcmdnwu*rdIIWI340}wbL+Q_A$001?#1i}CS diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-311.pyc index 7372854ba0689d20dbca1bf99bc504fadad16aea..3e4b80d0a1ea7676f3b5df4c4e1db0c8b096e7b1 100644 GIT binary patch delta 19 ZcmdnMwSkLkIWI340}!~J+{mTI3IHxj1U&!% delta 19 ZcmdnMwSkLkIWI340}wbL+Q_BG3IHx41T_Ev diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-311.pyc index 4965b9fe1cfc8b1d3ba591dcf46f2beeb7030648..289645205cc7e2c4cfac3b0d3fc9479b453a74fa 100644 GIT binary patch delta 19 ZcmX>gazKP@IWI340}!~J+{k6d1pqPw1cm?r delta 19 ZcmX>gazKP@IWI340}wbL+Q?`M!u$ScXXWTLuuS}sQv2O~oYLke>aXD(M1S1xxHcP>v9 z4_J&Phc}lmijR>Ym8pmgsD?F%A(uajA1KEbC6LaL!oG+xN|1@cogsyzg&~D=850A; zY9NMyC?T*67f^^LBo#>hQc zUEY#$(&R+>ZpN0$Z{;^K6>(0UtstiX3g04b5Wxc^Zb=km7U;!i=9Q!t9ImV(Xx;gPdrWhW@XLPO#5$E97u4A>f&oJpRMQH-7y}( z3BQi__U!!0=HlhnoH~!kCL$$rrh&s;F05l%y(qi|CVAPph6&}nBfyk8;M*cwfYfP z)WXi!z!FdHdW!4(UEemZhbsuxk=>z%Wj<4z_|ssV-_@q!@?bQMdwe>&gWLQm+T{E3 z9?$7b(c68?pu Kzr|ZaH+}-PCWvDI diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/logging.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/logging.cpython-311.pyc index 2f9f4d47b0d790cb389c73e89de380c5c9cf7f7e..695de2b599112a762cd8a3151b6b6cf2bb373f5e 100644 GIT binary patch delta 89 zcmbPUF};F!IWI340}!~J>`M#U$g8i#czd#~RwpCV=Hps!9E=Y)^BGU((Bfd!`oMrm S%uxFX68(aZ5}SP5+6MrENEs#o delta 89 zcmbPUF};F!IWI340}wbL>PrjW$g8i#cxSS$RwpCN=Hps!9E^`P^BGU((Bfp&`oMrm S%uxFX68(aZl9+tj+6MrE4jC-~ diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/misc.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/misc.cpython-311.pyc index 6173a97d4f073c9320a40e68d7f6c7be46cc4853..861840412022b863ac19d13b3506d8c5206c86a8 100644 GIT binary patch delta 8862 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 delta 9312 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 JnNFE6|1a&z@^ zjflh{hp2}(H#l-=lb~F3?5V1H>d{C(pp_y;>ZvzZ^psQI8~=BiUgR-h=REp zZqc1>#4wt7Bij@9Eb7{@>e|;?DeiD;3d})dIgKzoIo}l`)==8DM`&^uE%IO{r!|8` zAfJRF-aZ9nl`JdE#Az-stALaSq$Eu?l$n&ulOW=4Kp>C0V1AzC{o;p!2t3TT?Wb(& z{p>ZtxX7mG-S1pKJI%!PC@f|#U!9(`(=3R*0uXy5aQ%|-M7B_3!OiRyZ#FBuh@CCE zx$Ev66WO9yJnwix#5n9czX-QWoUdJ`b49p84y<{R<1C%nFT&><%bjT3t3X!BR{y{q zy^=h(HEbfs^2(;BH*Bjw}>Ka3|CVKmQpu33m6 z!;+SUPr?LpO4fltJC>EGMQfos-(A=ZhcvLce&^z3SY+IdLLQrr<3sQ_ROul<3V%i5 zL3Yhg{u<1ejvtU2)a-)|+x5Iyy+7Uh;nv!|cvN|>kESeALu9n;^-#qNy(|4dfw{#w;w4E1NBqG$Tk2G|4Y~Ksm z2;^8+cINw+xE{BA!V5&?2014Cd)ze>MwbgkpJA_NwARkFonq(1aCW2T%ho3A=%8j? zZy-acbP))4wPS0;>wT5Mi<{P1#Tu&;rR~(?-obLm;1lb}ott-Q<>;9QM=GfgHm&iB zHC|4R%i4k`6?$mk7T_kt?T!O4!lIA!4#&B%==$}QgyYaK2jVuz5q=m6NE$|j8%VIb z#u~gW{0PqU*)a5F%i>t++(v@;kYidoMpt^bQ7iA7y9tyc!ADVi1wDSH`PtGZ%KF5U zo`Lev^hE0?RfYMfh}suEz2`pRQhDsNwvp#1f>lJ6x+#W=Gz1VJ&*>?NjRT*RY* ztxrp~m;7&b=*FeBT$KQO@ZO{JuS1VM`&}=OPFLReSPK6t0st#H1k(Tj delta 19 ZcmZn`YZl{L&dbZi00hp5Hgf&s0st!z1j_&b diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-311.pyc index c39fce021ea9646335017478ab72e4c95222f86b..70f4cf9def1d3d2f0d08bea1cd2e19bb37d60689 100644 GIT binary patch delta 19 ZcmbQDHbsqVIWI340}!~J+{ncx3;-?Y1TO#p delta 19 ZcmbQDHbsqVIWI340}wbL+Q`Kv3;->^1SbFh diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-311.pyc index dafd7e85beb87d132ec7c7df2a728f4272c27185..33ddc7ac5f82e27ded246b91f97aede3cff48939 100644 GIT binary patch delta 1207 zcmbVKUr1A76yG=R{#@rsXVYD`={7B!1^&aaC^RXBz$8!tjj-#!Pg!ica_+>LqTb|&U=I;VFTM8EIaguRr|8@GaewFh&OP5bzx(pshcW*X zzrWUj=gj)Oxk$;cv2>~PzRN4>gjV{bEw^y{QG`UxT#ZIT`*0Px!fRKQ>9DQv3aygG zoU_7EtD)A1+Q>g>_q=Ht3+u2jsyg=nc#PNME%(UxHEs~CJRp44SL2QRAP-{9Bibrg ztUU21%+(4_xa<++cNSP~w&hjxRmnq`tFPi3^42QevX6&_X73}!BP*`y7?0ZA&8uo~ z<{Z#ZZ!2$`vD9c*-C^GDb28BU+7f2ITePOvcFP^#Y&K zVcvu!W)kwfXNX0m$NQ}bM zHwJp;nwntI@<;WRkM+yj!LzKV{3V!StXmE=cMc3u;i-+tC$Pff~73!*&=kxQgfE(6y8uQ;m?m69dHRL+%w11~&`*#eXq0c-9*&;a z8%!fjI>Ap-s!Y1c=)ur9p2^W<0?t$MBte{DO0Fh0r>KwRJH6xk zFxgJul)XM6uPkNOFmhH+wotUkvAgVeYr9M<`{O;CH~3;s48kf>vfF$t-?euSZ8#=A U|L=dx(Iqc-@bcG=4W>}9zh8&_-2eap delta 1269 zcmcIiO-NKx6n^*3o1f?SNJr=Q>C8B4Hb$f-rXlGxIV#yuWQzvM#<@?Knjg7uq$p^D z+_}*s8Zvqc{Fv-8Zko%pY_c$u%4f659GywBd7X7bq?bRmju1cJw0;S=z-Em| zx9D1mX$95^MkU#%ZIB%00eQfM+1NgWFf#ro;umGFxd$Ahd|3_=f9a|G(oXvMoO6=& zmYz9Ng!J%ccb8=pl_NajZgt>{%aXp3&XuK0$#jA3;S25odkh(Ngl_)at@8KoUXcy+ z-|h%G!XuuuB*yQ1I#r{$U8!UyGovrgF0gz`({*+QbmOJZo+p-uK767d;UGdYUkf~l z4exXgff*K=f?kw{&8$X-40aVjHv~nRQN^wS z7-KyDcO5Ff9aJr>2>$PUz3uXDV|{Wg&U(QWhcg`ux3iNdK8+AUNbvd4r*jUxVzRP5 zy1mT^E)zc#W1|c=P?l!%`ApfA&J~QFj8xkjGj@lA`(+!>=ILTaJIt2B#3kzA_`UZ1 q=`B$v;+F7#!6lHr+}=S|Q^S@Zk-(NsFb6gyfAznV>-b0{toRS{YWrLO diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-311.pyc index 54638b02d60daafaecefae47f1109d4e558af0e6..87e87c437f0e3be0ae98eefea315d886b4dbfbb1 100644 GIT binary patch delta 19 ZcmcbTaV3LmIWI340}!~J+{oo+0sufw1(W~) delta 19 ZcmcbTaV3LmIWI340}wbL+Q{W)0sufH1&jay diff --git a/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-311.pyc index 469eaf33c55703bd66501de46d0e79c7f684ce71..df88dea344ba4e02c3fffb7956c8259575503616 100644 GIT binary patch delta 5376 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 W44;gd{F^lL@_&8suw+(L(tZIDtaOtA delta 888 zcmZ8f&1(}u6rb7MY&O{>)s~931tU_^1+hixp+&q@K|xa_*g|ayYj)a1H`(}hVzEe5 z#Dj=vbr0>ah*YJg(*K|rudNgeb5Zb=TcNjJ^vyQ$>#_5`KYsIeo^~#GXFep8ae_3q z{c84`PRI{wv?yyR7Ew@J~1j_Bl#?A7tfoKR~pv$#YRWhbKWphuSZ^tEaz6w?3#UhX5Z@VJ@fQe zv;T|PziVdp%*>9KIlw|9w5rXEo9|vy+7S#Y*9SV#d4xscOs63svrL(l=bl6WJ?J?W z{8a8LklM1qaL5Nh#1?*vs`CRDyakW&L1Nj()UhvA;^az^ja|o9n zUO$}kiGZ9DqBt}zmp!NEvMX>2efS?$;(rbv7#D9gNbk zhw&L0Y8YoTq%hX7PCm<|%E&qSGt)ap*2#~UttKn7>=%&$suKa?;)y__f#CxWE33=o zFDz!pE{q=-7+GQDT|T)5Di`FPfM`b{guck2Q>c{V{tJPkXBGA5}!PsGn-8j$f=T>oX90QS(a;s zyd;oY!~;^uUR;`#l37%Ii!(DXEk7Q_EE1mlgiD`Me6t8Q7bBzMW_ccFMhUPEeULUW zAW;ko76q{BR=jeICYvL9HJKPqCO7k&af4Nwf>i2HKEkgc2v!dYH=ueTC=%cNmH!x% zi7Zg$7FSqePHC!ZQBi)8CUcPuNQkE_wWv5VKQF!{wW6d*6exsb*?XbgjG~)Y3vXp+ zw40nL?jx)LlrPc*5so0u%*7=|lMjfC$bj^LJqQm5kbn@FnEXL}3!~!Xr4kDm-6p$9 z%9*=^ghBCB#1ABHu_jfPq!t&MfCL0UgcFDm1Q8$uRx%WULKEnZ*^&<#SwL(6&2xmZ delta 620 zcmYk3zl#$=6vyZ7WOK*VkN7Ec;b15h&B@LSQSAqJ{*8bCWP&qo}U0%lCoOp>-HB(0BMLmf6S;7uV={ z=4>5!(%bA!vbVA7yI6G?s{SI4INgxP^nKAB-&|Tv^A~A-HRttpgM%fng}zKL(p!9R z9F5j&7A=Y4^N^FD!`rYR?-*%F$mhm>u)Obv0g&^4M>v!hs2P_Pk_1PMCaW&f>RTx6 zdaZv>h<5FQaP7M7+OV!Z diff --git a/myenv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py b/myenv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py index e06947c..6ccf53b 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py @@ -88,7 +88,7 @@ def join_continuation(lines): ['foobarbaz'] Not sure why, but... - The character preceeding the backslash is also elided. + The character preceding the backslash is also elided. >>> list(join_continuation(['goo\\', 'dly'])) ['godly'] diff --git a/myenv/Lib/site-packages/pip/_internal/utils/compat.py b/myenv/Lib/site-packages/pip/_internal/utils/compat.py index 3f4d300..d8b54e4 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/compat.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/compat.py @@ -1,9 +1,11 @@ """Stuff that differs in different Python versions and platform distributions.""" +import importlib.resources import logging import os import sys +from typing import IO __all__ = ["get_path_uid", "stdlib_pkgs", "WINDOWS"] @@ -51,6 +53,20 @@ def get_path_uid(path: str) -> int: return file_uid +# The importlib.resources.open_text function was deprecated in 3.11 with suggested +# replacement we use below. +if sys.version_info < (3, 11): + open_text_resource = importlib.resources.open_text +else: + + def open_text_resource( + package: str, resource: str, encoding: str = "utf-8", errors: str = "strict" + ) -> IO[str]: + return (importlib.resources.files(package) / resource).open( + "r", encoding=encoding, errors=errors + ) + + # 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']`, diff --git a/myenv/Lib/site-packages/pip/_internal/utils/deprecation.py b/myenv/Lib/site-packages/pip/_internal/utils/deprecation.py index 72bd6f2..0911147 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/deprecation.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/deprecation.py @@ -87,9 +87,11 @@ def deprecated( (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.", + ( + "pip {} will enforce this behaviour change." + if not is_gone + else "Since pip {}, this is no longer supported." + ), ), ( replacement, @@ -97,9 +99,11 @@ def deprecated( ), ( feature_flag, - "You can use the flag --use-feature={} to test the upcoming behaviour." - if not is_gone - else None, + ( + "You can use the flag --use-feature={} to test the upcoming behaviour." + if not is_gone + else None + ), ), ( issue, diff --git a/myenv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py b/myenv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py index 0e8e5e1..66020d3 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py @@ -12,8 +12,8 @@ def direct_url_as_pep440_direct_reference(direct_url: DirectUrl, name: str) -> s requirement = name + " @ " fragments = [] if isinstance(direct_url.info, VcsInfo): - requirement += "{}+{}@{}".format( - direct_url.info.vcs, direct_url.url, direct_url.info.commit_id + requirement += ( + f"{direct_url.info.vcs}+{direct_url.url}@{direct_url.info.commit_id}" ) elif isinstance(direct_url.info, ArchiveInfo): requirement += direct_url.url diff --git a/myenv/Lib/site-packages/pip/_internal/utils/hashes.py b/myenv/Lib/site-packages/pip/_internal/utils/hashes.py index 843cffc..c073b09 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/hashes.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/hashes.py @@ -1,5 +1,5 @@ import hashlib -from typing import TYPE_CHECKING, BinaryIO, Dict, Iterable, List, Optional +from typing import TYPE_CHECKING, BinaryIO, Dict, Iterable, List, NoReturn, Optional from pip._internal.exceptions import HashMismatch, HashMissing, InstallationError from pip._internal.utils.misc import read_chunks @@ -7,10 +7,6 @@ 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. diff --git a/myenv/Lib/site-packages/pip/_internal/utils/logging.py b/myenv/Lib/site-packages/pip/_internal/utils/logging.py index 95982df..90df257 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/logging.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/logging.py @@ -212,7 +212,6 @@ def filter(self, record: logging.LogRecord) -> bool: class ExcludeLoggerFilter(Filter): - """ A logging Filter that excludes records from a logger (or its children). """ diff --git a/myenv/Lib/site-packages/pip/_internal/utils/misc.py b/myenv/Lib/site-packages/pip/_internal/utils/misc.py index 1ad3f61..48771c0 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/misc.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/misc.py @@ -1,4 +1,3 @@ -import contextlib import errno import getpass import hashlib @@ -11,6 +10,7 @@ import sys import sysconfig import urllib.parse +from dataclasses import dataclass from functools import partial from io import StringIO from itertools import filterfalse, tee, zip_longest @@ -20,7 +20,6 @@ Any, BinaryIO, Callable, - ContextManager, Dict, Generator, Iterable, @@ -56,7 +55,6 @@ "normalize_path", "renames", "get_prog", - "captured_stdout", "ensure_dir", "remove_auth_from_url", "check_externally_managed", @@ -399,40 +397,6 @@ 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) @@ -580,10 +544,10 @@ def redact_auth_from_requirement(req: Requirement) -> str: return str(req).replace(req.url, redact_auth_from_url(req.url)) +@dataclass(frozen=True) class HiddenText: - def __init__(self, secret: str, redacted: str) -> None: - self.secret = secret - self.redacted = redacted + secret: str + redacted: str def __repr__(self) -> str: return f"" @@ -781,3 +745,36 @@ def prepare_metadata_for_build_editable( config_settings=cs, _allow_fallback=_allow_fallback, ) + + +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, possibly " + "rendering your system unusable." + "It is recommended to use a virtual environment instead: " + "https://pip.pypa.io/warnings/venv. " + "Use the --root-user-action option if you know what you are doing and " + "want to suppress this warning." + ) diff --git a/myenv/Lib/site-packages/pip/_internal/utils/models.py b/myenv/Lib/site-packages/pip/_internal/utils/models.py deleted file mode 100644 index b6bb21a..0000000 --- a/myenv/Lib/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/myenv/Lib/site-packages/pip/_internal/utils/subprocess.py b/myenv/Lib/site-packages/pip/_internal/utils/subprocess.py index 79580b0..cb2e23f 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/subprocess.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/subprocess.py @@ -2,16 +2,7 @@ import os import shlex import subprocess -from typing import ( - TYPE_CHECKING, - Any, - Callable, - Iterable, - List, - Mapping, - Optional, - Union, -) +from typing import Any, Callable, Iterable, List, Literal, Mapping, Optional, Union from pip._vendor.rich.markup import escape @@ -20,12 +11,6 @@ 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]] diff --git a/myenv/Lib/site-packages/pip/_internal/utils/unpacking.py b/myenv/Lib/site-packages/pip/_internal/utils/unpacking.py index 78b5c13..875e30e 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/unpacking.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/unpacking.py @@ -5,6 +5,7 @@ import os import shutil import stat +import sys import tarfile import zipfile from typing import Iterable, List, Optional @@ -85,12 +86,16 @@ def is_within_directory(directory: str, target: str) -> bool: return prefix == abs_directory +def _get_default_mode_plus_executable() -> int: + return 0o777 & ~current_umask() | 0o111 + + 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)) + os.chmod(path, _get_default_mode_plus_executable()) def zip_item_is_executable(info: ZipInfo) -> bool: @@ -151,8 +156,8 @@ 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 + permissions (user, group, or world) have "chmod +x" applied on top of the + default. Note that for windows, any execute changes using os.chmod are no-ops per the python docs. """ ensure_dir(location) @@ -170,62 +175,137 @@ def untar_file(filename: str, location: str) -> None: 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 + + # PEP 706 added `tarfile.data_filter`, and made some other changes to + # Python's tarfile module (see below). The features were backported to + # security releases. + try: + data_filter = tarfile.data_filter + except AttributeError: + _untar_without_filter(filename, location, tar, leading) + else: + default_mode_plus_executable = _get_default_mode_plus_executable() + 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: + # Strip the leading directory from all files in the archive, + # including hardlink targets (which are relative to the + # unpack location). + for member in tar.getmembers(): + name_lead, name_rest = split_leading_dir(member.name) + member.name = name_rest + if member.islnk(): + lnk_lead, lnk_rest = split_leading_dir(member.linkname) + if lnk_lead == name_lead: + member.linkname = lnk_rest + + def pip_filter(member: tarfile.TarInfo, path: str) -> tarfile.TarInfo: + orig_mode = member.mode 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, + try: + member = data_filter(member, location) + except tarfile.LinkOutsideDestinationError: + if sys.version_info[:3] in { + (3, 8, 17), + (3, 9, 17), + (3, 10, 12), + (3, 11, 4), + }: + # The tarfile filter in specific Python versions + # raises LinkOutsideDestinationError on valid input + # (https://github.com/python/cpython/issues/107845) + # Ignore the error there, but do use the + # more lax `tar_filter` + member = tarfile.tar_filter(member, location) + else: + raise + except tarfile.TarError as exc: + message = "Invalid member in the tar file {}: {}" + # Filter error messages mention the member name. + # No need to add it here. + raise InstallationError( + message.format( + filename, + 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) + if member.isfile() and orig_mode & 0o111: + member.mode = default_mode_plus_executable + else: + # See PEP 706 note above. + # The PEP changed this from `int` to `Optional[int]`, + # where None means "use the default". Mypy doesn't + # know this yet. + member.mode = None # type: ignore [assignment] + return member + + tar.extractall(location, filter=pip_filter) + finally: tar.close() +def _untar_without_filter( + filename: str, + location: str, + tar: tarfile.TarFile, + leading: bool, +) -> None: + """Fallback for Python without tarfile.data_filter""" + 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) + + def unpack_file( filename: str, location: str, diff --git a/myenv/Lib/site-packages/pip/_internal/utils/urls.py b/myenv/Lib/site-packages/pip/_internal/utils/urls.py index 6ba2e04..9f34f88 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/urls.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/urls.py @@ -2,17 +2,10 @@ 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 diff --git a/myenv/Lib/site-packages/pip/_internal/utils/wheel.py b/myenv/Lib/site-packages/pip/_internal/utils/wheel.py index 3551f8f..f85aee8 100644 --- a/myenv/Lib/site-packages/pip/_internal/utils/wheel.py +++ b/myenv/Lib/site-packages/pip/_internal/utils/wheel.py @@ -28,7 +28,7 @@ def parse_wheel(wheel_zip: ZipFile, name: str) -> Tuple[str, Message]: 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)}") + raise UnsupportedWheel(f"{name} has an invalid wheel, {e}") check_compatibility(version, name) diff --git a/myenv/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-311.pyc index 0023516357b54983d0c465465a064c35dae25179..0b5dcbb377f4d5b7ae39212e395fda31ea49429d 100644 GIT binary patch delta 19 ZcmZo?ZD-|L&dbZi00b^4H*(c70RSk61T_Ev delta 19 ZcmZo?ZD-|L&dbZi00hp5HgeT60RSjo1T6pn diff --git a/myenv/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-311.pyc index 99d8c6cfb8e327dd8469d0766f55913ab4d554dd..116beed9a5c9ae23b12f27c092f6bd63d7ccd70b 100644 GIT binary patch delta 610 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 H1rz>XozB@N delta 3078 zcmZuzeQZesP@m+2+1y zHY^zJiquH`*x2b-p{XsCI#{%7h+5m&q;1l)Pa#cAnzZU^)jHH}g{kejN&6%GvvaQV z+3_U*eDAsE-gD0HoO|B;=sJ7xI&)pGsi`vIbM%+5%>I7#va6Y0yS!s?Os$Glsm_>_ znNp^dC0ni5#A;Mm%q8YhwpMk=+-hB{POXpC3z;?Bpf<)D#aPaI)TUUIx+Qk`re}tk z6nValY|t~`UimkfV(pvcTi4`U%_hY(?_ZrO+paN_>HGMrJhAP#F3oqW&QmsUGY{*4 z-8Ickv98Z8I#4wLKi}RIi|t5NDLYe6B{(aksxL{gkl8e5O4VF4rCdtOH4ECn--?ZH zJf?Mi*Xms9-s}U0$xfMqwf9Kjc==PdY-SB`U%FuRpxTdWM_GhHizJ}b2n>&MdtuJ0l#rBvexp6>YI!O zfVp~^7xuV1ntMp|5dtrQM$!BIb9Y=?z$c}4^P%Ti`)KE_lbGuIB8bYab(n>r(DsCJeSO;lx0@6%xadI zpC5#OH%`j^r2Ht1djjsqXc!_O()e-sisyi@0f(9s0exJ3cnhsZ;Ex_Jd%pZnPr%Z9 zj3kr=qiQa(N?y>yH=ns7*dcEhy9sIUlm1rPx*H)WA*?=>A)@9#AHZGjB-;)*eBC~o zo6k!*mSX2E@wKWsZ#iYs9kA_i3tVsMvY-Z>@ioBRmMNbnKkT8Ez=MpH;NQD;<*j!YjNkB^TG4f7o+2v!@m1W!}md4v?~ zYGOf&=aerQ&KaJ_CFkO~gsO<}`2Z^L!vrY;L9Y{zw6*P9r$W>UMO-18C^j5ea+Sk0 z8_rj##;Sm}Zuxg8(c0iwZ4-6xhWFhG9J!jjn!Gi;^b{9LMqTVLb z3$$^q!f?XF2&Ja6j2`*_8vid0`uE~lntxD|`$#(gw>r0W9>n3jI-2_tO7-FJY$mHK zd|)P}_)f!W zl$l~$ILNcKJV`(y@pKe;;b~dnyG}$Z?P(VRxgWtlj5=xh>{9*oFz$ML!AQFh_ zi-fkYVHgd)ywS?XA)Q?$g6|PGn6X*>6UIt%IIJhq8W%pSi47}PG)1S?xdcxIkW`t5bSJb?&MDje7&g3FRp7rz7v`PU4?Ytkty{%uUA&KY$kK@Q_il?!8R(8hq ze7uk;#BnEol=j#vZ6OL5db{f>m!B*7pZ4xxUo7A4U6Qb6zVyiOu#0w?MUOQcTCxyV z6MAw^BloCt;vatzq0~a5J=}5$8uz`%TH)<|_q~+Wl06(gtMJV1xsrr^{OM6Ve;jV? z-!dSIl4^;Rs}3)&GD1QXH< z6Qth>{e3O1A{Z+AlADg+_`X?!GksGSLeH?b{9d2SJWUo#j&K;M4yQ64vv!pv=17Fn zfHyevw^rt8c9-@~@;!rpHA-sI(EwuMw z#9N*i*ebC;SQv`33HZTK$YI#HQphHf3cNS8$0znuCJk9j&MB&5$T>yN=9BzY2u1r@ zC(K57;js|i&VF0|QS{49#PJz>0k(~JpP+<@iVs@Xz2)B|>01O83-VU+5XYM`PX%A{ z5LuN1k88ylHJ>VG747c;BWWz}2P4lh_Bvb`^LsYG9Qi3a{tb9%?94$ym`ro(UHlvY zmBG44hCP?(s^IJiTtH`6ID2Z`hryj2-^M;Ie|!8aYY5OXOg&=~##r;Je4BFH*baI|=BMgYPAvj=~2CsE-=XWHzB`s-n;3Q(Pjk z=#}(xs=RjWG^!;K-GQ1uzew;r!3zXmC!kxysgNsu_Io(0=G8R+2|)=iO@wMiNzw-- zC+IK#Y$7iuh1)a_h7DUbpT^dZHf(tGQQA|xw(XR=)u39;d@p{b~6vRXvVXh|;ObI|!!@X2H+b3(((fJBbN zfs^eQ4Qs{H4bu2AnRDPpdJMf(IR66)DaD2jzwrv0tilhGs9A_kk4!~RoEqU*Nc3j{ zkp&-(C|twNm2^hKw;!h@SJFoeE!z)Os_rna`UvOr&8gjo4^ECkbgBtXOv&ZPr(R+b G5%)hiw9v2s diff --git a/myenv/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-311.pyc index d34453374293b681c0d82f4e82a79f6397f1d8c9..9e7e41b9131508a2649050ee134e91a5cecbba7f 100644 GIT binary patch delta 19 ZcmZ4Dvc!dJIWI340}!~J+{h)R1OPNs1gZc4 delta 19 ZcmZ4Dvc!dJIWI340}wbL+Q=oP1OPND1fl={ diff --git a/myenv/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-311.pyc index 4fe34bbbacc107f50a22182565d4939c0664b165..bf22b6e9ee30bb28ed1bb43d977bd7d13e5214c0 100644 GIT binary patch delta 275 zcmbPUw7-aVIWI340}!~J>`S}8kylcO(~OaUVLC$%^Mc76l|&{7=<`nw(n(ZeNnuWB ztYyn%N@u8LE8zrbfq)d2bjBLCMT|9*1jQ$xGvH&J$OzQS2Gp#?3uH0@G2=wWAcnrl z+PX%Jtdrw(H7EDzCb6-miAUoikJc3)tq<%VQ4R)PiR(P_mw4na@+e;6QT)IO y66Ipx75KmnV(|cVec%PL7+^#P#|HrhPTuPr5|=n6W=LG*P`bjQwE4E44Hp1IsY}HG delta 180 zcmdmAG`)y-IWI340}wbL>Px%0kylcO(}hl_f1FF@5r9T_?uXlg;$}M1*BJTsmAH2#a>O+!dC;!6SBqM_}?qLj^8= RAmbx1y9n2p&9C%Axc~w|FKPe) diff --git a/myenv/Lib/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-311.pyc b/myenv/Lib/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-311.pyc index ccf9e4607c2898356dd3fea58cfab8d9dd3bcc6f..439b7d227e86bc68d32f4a52b064625a460810de 100644 GIT binary patch delta 6390 zcmZ`-32>Xob^aF@aS#9r0whS0APABoL5Zg*OOz;z)M;HLb-ISdKoI_)Bq&_k|L38@ zC6lTiIdL4yt46AiiS4AaR6D6;*dDo6VkMnS)0=cTD(8>gYSK8F)Qtnxvd7Idb>G{c zr|p2i$G7jjefxIzy|?@S-~NRB*(b#DlHG0<;Ir*-pX|T-&;^H=bX=&}oI?bWh=%xu zSVcjiAXJcWhujHI$ivyj_=Oid+c=pMUy&#cl_ttUWeH!%mnaXFC;TCQq9Rn02!sNO z%1|ZOGsmkE)uHOd%FxP0O{gYO8>$7qg_%foL4o9w>Wk3_{=wE$^@Zc12GJ_ji#DmT z-yr6mGlZHff>9Jfllz#KD^5c=uvt_2YemNUs0GF zdVsUbfbC-rU2sJ?P<~BezGJ9O)EyLp0d_#w;?b!VF``7G@rW#|#{QTT7lSr-QCE|* zH>OB563@J;vl4b!A0%T;J=Vg)W@r1*g6EHtvqaX3^{ z&$mw7YiID=II&~amY)@f(UTc5UL|>rpiP?)nh{!9L(a;o)j+D=MC61N9*N3fDxDmT zQE(%vguyeq0mSWWEGJAFGP5~nc_Jn8|GBBa;@ zj(y{Ncx)aD64lgCQ>Ue56q*Yk!yNVDJ3w3#Bq2mZA*4GD86DC~22r;p*NmdR9kfJ4 z$Ry=R=4BEiN+8@VlJynSLb#7}>mi$zD;dR{xz6^_bvAQ}MKbs6L@OkmLvo6i0W%_C85^}Bhb z!HPOXsXsCtSHk^~sFI?mRI4fI?8OMK<zS= z8xl$(3<)FND-4hqnY*ZtM{m&m*=)!Ohs9Jh9HtI*+8GW~ zbLoK^ZcRteLLb!}4 WOS^Q-(b{?F>?Loor%TJ{;>}`kvtO2OuAU3qG1THlOe2x_ zup}=t!S&aUz>8teObV2YnG`G|VcFh+c z-)H~etKj3O_s@;X75^BuAH$wnd~=$90~m|pjVh}EP8S}D$_Izj=@eBOmK;w%WPee< z366(fmmepsU8s%6k`|GEr1<2FqI7(CV1A7m@a2VQ{-cTj`3bvH@n!I^Hqhhe9unT~ z+T5m~p~ViD0xQWB`$3>d+vJVxnW5s0z49f}iDS{P0;mO;$W%(FiAJdpNNd9`nZ&Y^MvpHMs~ky4=ihE^?EYHPF26C4N%7_R=yEju)S=>@KmNR04%Q9 zQ#BpreYUx#8|G87vY5S8BUNKrhLg=0PmM}cTM|8ZNdFXjF04dzZLRLUz#ge>)Dl}q zD?r{I^nND6xdCbdnU=w$NZ~&6NTzs8q301!Ay^RjeqTTeHW4K!4%tVF0HkH(Ziz9A4E7#Z|?0E>(A_2vhOh23dhKfl|~Xff+<%VljX ze^QJiL6Goncq>`#_RE$B-1!7JIDM!*xk8@%yh0mT^O{>OuK&g|{ZH5IfZNTE)(UNy z=1ijXVckFr=)kSbp+!?7rAYi<^eV8q%k)j8UPr*YQZPqz1x;($tVWq z(KY}%2LR3w{6IyoU)N6jY-rurwb7g4bo*I;8uefb0%!ozA(mZVU9uiHA6lUeSHC>L z8JIFxX!W-@)7bU|Dd#0(E}wg`+g}4LMkiA@Jm}l9WMK-0JkR-I&BQTKjq2HLqq`IX z`;wsG@N=KDa1TDKOT%55#W%jTN(MGmoTKPRt?8fsd&(!dGR;Q+JVKfx}$>}Wn#xp2Np-wl$4ZsDoX1zZ+4v5RbA6{ zck@70MB!|AsvlYRsSSY;s>-vi%Mr z&vo7cllfrhAChstsV4dkdSsHND1{p3MI(0+6oevxpj9iF=pk$g*W-!7BjBf~hC{2) zIZ+y(z(!M45WHXZ?7qR^gI??|__>_J3k?k91fK*B3SD(U% z^H1BhNpVSuB?tV~GW`_9rwg`3q9>3soCcm>NulI_+3KU^Wxqg6i)n0<#^Amw)Bi^H zNj7-2Z2T6Izd`sJLKgy_)v5(+0e?nNjY>?3OSBMWzeT`!Qw_0Xe~NyB?JWp?1UCQ_ zhg0zU4Pz;^1eqRWn&iP@B^Fl=i4+u(kAQ{YjQYG(YCDaaOy6VPzTHqsqJ07KpP9${ z+VpVIxqa-LWCunZ4}@+Al7(qe9c~35DGw+pNQY4m52i({OSkXY;{mdjy>+|?V$~V_ zNzrZ8d<|eBUy*T(eGm=UdLV`AkFbrpO>B>N==bQ~WN(Om&%>ZUACcDiEoSeFKPH3h zhV(2PcHRAc-E(?2(O=H?_4|8_XN4i~TKhbs6HU(<7amhN^D9Kjo0khhl|YM$px75V zV$MO(kRabXP>DmUbE%*Z_FS9fs1^GMR#R~{`q=u6s=d*i* zZXFX?ZmhA0mcwwe4HS7EYXDieFSgor4A*WQ8;`9a0hWnvX$ioK6w7|H6yJ4~PL=gs z-}>5v@K5_ryLx9_y;Hfp?>hbL?7-0nh-XpXF=AV#y8$dO84J(7YFuCzSq6G+d z5qLGh!p;kZs*l0z2VP1ro3%>7%L8U1J?ui{<>e-d@hqo!{i3+}6e~H!xTg5DO8Ig= zhs}Kmcy-WjUwud+V5yUPGW*k$WP2Bcgw@zZW?dzh*Ica6>UpEJ{pKSxt-G|=T}wgM zh-^($!+Uzclz;A#tPTYkA3dxeUuSe=1%SJD*JSHu{l&J+C#DL5GxoZy5k)4Uuq2y< z6uj>%oQyuvm$hKaDtOzoHl%We@|x$zuIs<^=!|b|){ZQPP*i?dzL>~5v6Uxy{mGo+)a{<|E%FxJsrvOX_CwS7i&3;TDR^vL2)ganvHDyn@x9Ek+8R^#aHS8tWt0T9f5ypPCPX*0Ox`h?-pEUcq0x`p}h=k;O|2Dtx2^lys?Ex zVLYU@*Aph?R2mGh4@T;9w1*cb^N#vS9%~!*nK0X_i}j8As(6g>TJAw6KPm9WqTOPO zkt$)|8m+SMpu-};M1& delta 6374 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 IFW=_>14qaMoB#j- diff --git a/myenv/Lib/site-packages/pip/_internal/vcs/bazaar.py b/myenv/Lib/site-packages/pip/_internal/vcs/bazaar.py index 20a17ed..c754b7c 100644 --- a/myenv/Lib/site-packages/pip/_internal/vcs/bazaar.py +++ b/myenv/Lib/site-packages/pip/_internal/vcs/bazaar.py @@ -44,13 +44,13 @@ def fetch_new( display_path(dest), ) if verbosity <= 0: - flag = "--quiet" + flags = ["--quiet"] elif verbosity == 1: - flag = "" + flags = [] else: - flag = f"-{'v'*verbosity}" + flags = [f"-{'v'*verbosity}"] cmd_args = make_command( - "checkout", "--lightweight", flag, rev_options.to_args(), url, dest + "checkout", "--lightweight", *flags, rev_options.to_args(), url, dest ) self.run_command(cmd_args) diff --git a/myenv/Lib/site-packages/pip/_internal/vcs/git.py b/myenv/Lib/site-packages/pip/_internal/vcs/git.py index 8c242cf..0425deb 100644 --- a/myenv/Lib/site-packages/pip/_internal/vcs/git.py +++ b/myenv/Lib/site-packages/pip/_internal/vcs/git.py @@ -4,6 +4,7 @@ import re import urllib.parse import urllib.request +from dataclasses import replace from typing import List, Optional, Tuple from pip._internal.exceptions import BadCommand, InstallationError @@ -217,7 +218,7 @@ def resolve_revision( if sha is not None: rev_options = rev_options.make_new(sha) - rev_options.branch_name = rev if is_branch else None + rev_options = replace(rev_options, branch_name=(rev if is_branch else None)) return rev_options diff --git a/myenv/Lib/site-packages/pip/_internal/vcs/subversion.py b/myenv/Lib/site-packages/pip/_internal/vcs/subversion.py index 16d93a6..f359266 100644 --- a/myenv/Lib/site-packages/pip/_internal/vcs/subversion.py +++ b/myenv/Lib/site-packages/pip/_internal/vcs/subversion.py @@ -288,12 +288,12 @@ def fetch_new( display_path(dest), ) if verbosity <= 0: - flag = "--quiet" + flags = ["--quiet"] else: - flag = "" + flags = [] cmd_args = make_command( "checkout", - flag, + *flags, self.get_remote_call_options(), rev_options.to_args(), url, diff --git a/myenv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py b/myenv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py index 46ca279..a413316 100644 --- a/myenv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py +++ b/myenv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py @@ -5,13 +5,14 @@ import shutil import sys import urllib.parse +from dataclasses import dataclass, field from typing import ( - TYPE_CHECKING, Any, Dict, Iterable, Iterator, List, + Literal, Mapping, Optional, Tuple, @@ -37,14 +38,6 @@ 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"] @@ -58,8 +51,8 @@ def is_url(name: str) -> bool: """ Return true if the name looks like a URL. """ - scheme = get_url_scheme(name) - if scheme is None: + scheme = urllib.parse.urlsplit(name).scheme + if not scheme: return False return scheme in ["http", "https", "file", "ftp"] + vcs.all_schemes @@ -121,34 +114,22 @@ def __init__(self, url: str): self.url = url +@dataclass(frozen=True) 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. + Args: + vc_class: a VersionControl subclass. + rev: the name of the revision to install. + extra_args: a list of extra options. """ - 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 + vc_class: Type["VersionControl"] + rev: Optional[str] = None + extra_args: CommandArgs = field(default_factory=list) + branch_name: Optional[str] = None def __repr__(self) -> str: return f"" @@ -362,7 +343,7 @@ def make_rev_options( rev: the name of a revision to install. extra_args: a list of extra options. """ - return RevOptions(cls, rev, extra_args=extra_args) + return RevOptions(cls, rev, extra_args=extra_args or []) @classmethod def _is_local_repository(cls, repo: str) -> bool: @@ -660,6 +641,8 @@ def run_command( log_failed_cmd=log_failed_cmd, stdout_only=stdout_only, ) + except NotADirectoryError: + raise BadCommand(f"Cannot find command {cls.name!r} - invalid PATH") except FileNotFoundError: # errno.ENOENT = no such file or directory # In other words, the VCS executable isn't available diff --git a/myenv/Lib/site-packages/pip/_internal/wheel_builder.py b/myenv/Lib/site-packages/pip/_internal/wheel_builder.py index b1debe3..93f8e1f 100644 --- a/myenv/Lib/site-packages/pip/_internal/wheel_builder.py +++ b/myenv/Lib/site-packages/pip/_internal/wheel_builder.py @@ -70,7 +70,7 @@ def _should_build( if req.editable: # we only build PEP 660 editable requirements - return req.supports_pyproject_editable() + return req.supports_pyproject_editable return True diff --git a/myenv/Lib/site-packages/pip/_vendor/__init__.py b/myenv/Lib/site-packages/pip/_vendor/__init__.py index c1884ba..50537ab 100644 --- a/myenv/Lib/site-packages/pip/_vendor/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/__init__.py @@ -60,13 +60,8 @@ def vendored(modulename): # 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") diff --git a/myenv/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-311.pyc index 05aa29172b09fa0a2de4ade4c9d1e9a3bf15994b..82b82d575b152af570fed538506fc6b02787c16e 100644 GIT binary patch delta 118 zcmZ3jvs{aBIWI340}!~J>`VJ3G?7n&=^E=qjrokTHl8qGsbWY zQ!Pu@Bp2#P`jVBCPCpR#%GTKcpU=(Gv2a^t9 z(h)>TJ1t{mU|0>r5WvWg!W<07n$DY<*w(Xza3tsF0-*YGai6zyKnP%z=gh0Il6nSO5S3 diff --git a/myenv/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-311.pyc deleted file mode 100644 index 589ab58e1906bb150884c55fa7c662bdb9082244..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 46427 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/__pycache__/typing_extensions.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/__pycache__/typing_extensions.cpython-311.pyc index 40f2141c116b216de643456da1975619ed7123ce..8ec008af2ed0af5d25f2d34b6079b6d2c0966590 100644 GIT binary patch delta 46786 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py index 4d20bc9..b34b0fc 100644 --- a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py @@ -8,7 +8,7 @@ """ __author__ = "Eric Larson" __email__ = "eric@ionrock.org" -__version__ = "0.13.1" +__version__ = "0.14.0" from pip._vendor.cachecontrol.adapter import CacheControlAdapter from pip._vendor.cachecontrol.controller import CacheController diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-311.pyc index 9ca37e31f3b61c2b4d44820f5da162aa63f694b8..d0a5721ed3e1cb551447989ecbc2d579ade01060 100644 GIT binary patch delta 28 icmcc5exIFdIWI340}!~J+{hKe$ZVo#usM;jjtKy1um delta 28 icmcc5exIFdIWI340}wbL+Q=2c$ZV`1#18R diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-311.pyc index 9a6f67b59db86bc84b65ec68800e98f5ae85edbc..0619548da30383744f5b1d6a2e838f5531bd63ff 100644 GIT binary patch delta 22 ccmZoOYcu0r&dbZi00b^4`_e9NCi5CAZd1k3;c diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-311.pyc index 6148374523f43f6d19c66514bec63dda8baf2655..92480660a54b46baacfe3bc8d43e94310908dded 100644 GIT binary patch delta 973 zcmZ{iUr19?9LLYOZg+G4Ty1x*<)&NKy7MK-CKaSjC8;QM^pFpk_-84)n`c-1x8V$< zh}79H5TR%WBE1xL=^=WEdWi}l=_OVV712vQEbyhb&TlePu*2oU@89?L`*F_wJV`TC z)V5%?ng~BlZzg-ES{7|fj&Pb1GDEs)lJ;Y!a7G9dx`im=F`ivLDIqDOg`?yuO_F{A zmc2fx^w>?Ql4MD`LNyWsUfBnGrL8_xs@9^85UekHstv}RUh|rtHGmD0ue z(3Fmsmln&jCZ2Y|ALlkJpHMtmGb~#qNV>O(Nqv;adN?Mv8glx!&UmZ`?n);`3v1-X z@Jo8-eaVe9$y0bo zFI~`H2Tti|0=&WFJl!Ak&=gz?o}rTVJvb1<5LXa0h!KvQ*sHL? zPF1$EJs9gktWJiNaMk`a`ivtdc6D{Io*|aR2zJjI<4Q+DRag(pU<|is;~WV)2aE+O zps!A*5e@3B209CKhrZDtFkatg{GiSWO4l#U~llyhfvcHrSG)ShIU$h z9&2=~OX3f~oQNBcKkOSVENw%-aA#9!75185E4yQ9dQd$xa9|EJwnXGN?ZfP?O}qcgz_Elvu1U9?J>* uaxZGLO-5?R*J4$O9f)~YY1LZWX)qsJwM`SnW>cg+SOaQ5XcR%DT0=dEG{j^RQ<|im-T0Z> zqM!#gZF!%Y_Bm¨AS|6lgE%#u^j~!mx0FT%-kp(WM3NB@Z;Z)|ZKd zKx0d7Q$l#igA>aMlq6_`Xx2XlLRQq+?#=oa&oc{6!aZLN z&BBcD4jq8w{t#8+hCfLk=s*13Cd#0z{vZ$Et=~usFkRn69r}hqMyODEp-$P%Qcw); zvR>mSb{#PS^TFNJt5-G5SMY+Lc6=5Y>MFcxo*U9|+l@GikPu;n32_E-mZM}&tBG_f zt+B&+D(h3S>;wjrhz`V7L>J-|VjJQd;wB=`Q4*6mmWgSygEgTRCqyD_sZ$7q>UIvH zI$&hR<58vzu=A*3`I3~)MO7`w6gGkyPRlNFs1BI&J7Fx;Ok4C*r=9$(H|k zg2c=78`he{)h3we=L Xb6%KKIWI340}!~J+{iUk2mmnu1la%p delta 19 ZcmZ3ix>%KKIWI340}wbL+Q>Ci2mmnF1knHh diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-311.pyc index e6e8b67f7f1b18ab1833f7b85c9881cbfcdb36be..766458cea0d94b6dbfaf89f55d7bcfb220c936bf 100644 GIT binary patch delta 22 ccmbPcJ`QyJk+)M807rlZ!TPx$`k+)M807oGPv;Y7A diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-311.pyc index 9ecab38df2d08f14e9302a8b6a5731c250699df2..3f96af186ca5b7c55c5f3aa8eae0fe6d199b696c 100644 GIT binary patch delta 886 zcmaJj$kyg3E^=UQju(c4cN6l&T zM(#ttXIu9pui~tqn0t#W^oL4+7T-FbGujR#TA}GAUSTp3$3?UwSPUT&5lvEPgBI6} z&w*4SgnnH@vOu!TVw}J^z0pUrWR#+4kEevQXG)$yRQ1A~uEPb7-Y8xBF@!6eJYdEj zUviIS;l3vT>(%}~Q|%Q8&?5FBe3rMFYT0FFhDFA@eLZtc#H8^ULRlLe8z1J@;H{Xc zR&w@8n@n6J5G)k|3N`!bD7>%nUm_mw{M78!YWPHcpwt}4wK6}16YJr`TDYqe?pkvv zOYYy*LVIX?!^%aQG~KGF+L$=GewJpR;g(NcPBM^`dZep-gy?|p zbwjkjn5ut8q3l~so{)T0=vPUhQ!=lFE(Ehm*mbUvf}N-QnY(&w5DGSj?2gH=CE6s& z{DsU}bi<8cl)Wa93l10_$MG$)3mk-BK@*k@KP(#c@XlzWE%3=$qL*PI^s*eF))D#f-QF!oUfV2Sc`?(JlVePK^o<{*uB!q4~PqF^2kQNvjBP!A2 z7SAMQ!k6IlHTvn}G)OrqCrsHpNM=_{$U}t7lrS+Tjgu*9hP)|`lNp+o7-7;of@jB_ zF!^=J2H6c+DJ$TbC006u^*#0yDq2Bb4QjT_+iYnRNO`QJf&n^YQ!)mb4_b+0>`=Ry^usJ5)Ty`Pyr zF%?5gwl#NG$=&t-iNesFbIw`)rOAV~EqhqEdkRDNtB9blR;v{gu{0I<94+tmuA*%k&-P^ zP%4Uob%n1)7DB6Sp`~X4@LzL;OOEi(v$rz0$JZPqCCA9BWu*FRQ)`8Ys{0-&#Oa<3 z!B-hT54EMS72oyvNzu~XEPg|~#UCQAgD$e-G7WZ!EA14x{IG?K(9w%cqe>5$^Pslb zfYM(7g0Na=+pYFuTZwUXuU!6WodYNDw)7u*csRX z`f3CnBCEJ)+)8ei-_pDyuvFa(LD`mgK4UWNJ3agS*-V@Y_-W zu+MorY;+;R{qXv4MesNn>1FUUAnlj6r*77sFVLly)w-KB|9@pYQa9_78(1!J%&3?PmpoQOd{z{vIN7F6gxc@m`o!~vH3#*Beu zpaJfv*i`&nG8QYFw3O2m?8SI^_46=d6oD(i6Nm}KtBBVS=d`QNHX%&4@13Vw+GIGZ zbudh|M_qxuD#N{02R_o-RZ)#NTL)f!wvL+~YTNhVS+jhcR)|?U?Rt_1w5zV0bVhsO W&{rpN0>z2_ADi2Ae;i<<_vT-%?8$Wi diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-311.pyc index c68433e7acc9271a3ea0bcb2bb2557e856bfa3e9..cba6d53d1818865bd73ba2dc53d8928cf235551b 100644 GIT binary patch delta 19 Zcmcc3cbkuEIWI340}!~J+{hKk4gfVa1jqmY delta 19 Zcmcc3cbkuEIWI340}wbL+Q=2i4gfU`1i%0Q diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py index 3e83e30..fbb4ecc 100644 --- a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py +++ b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py @@ -125,21 +125,21 @@ def build_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] + response._fp = CallbackFileWrapper( # type: ignore[assignment] + response._fp, # type: ignore[arg-type] functools.partial( self.controller.cache_response, request, response ), ) if response.chunked: - super_update_chunk_length = response._update_chunk_length # type: ignore[attr-defined] + super_update_chunk_length = response._update_chunk_length def _update_chunk_length(self: HTTPResponse) -> None: super_update_chunk_length() if self.chunk_left == 0: - self._fp._close() # type: ignore[attr-defined] + self._fp._close() # type: ignore[union-attr] - response._update_chunk_length = types.MethodType( # type: ignore[attr-defined] + response._update_chunk_length = types.MethodType( # type: ignore[method-assign] _update_chunk_length, response ) diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-311.pyc index 3aaa0c750caf93a54b82b317e8b8f038cda2a261..0cfe443d3ae58e23c682f70e7c08b97152647eff 100644 GIT binary patch delta 19 ZcmaFE{DzrpIWI340}!~J+{pEa5db$p1z!LF delta 19 ZcmaFE{DzrpIWI340}wbL+Q{{Y5db$A1y=w7 diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-311.pyc index 2efe141b20327dc27bca933ece2bda62d1d238da..e454f9c9d856347f35b1e64c9fe2ceae647d7562 100644 GIT binary patch delta 2285 zcmZ`)U2GIp6rS16&d&aJx9u)n+U<|DmZ7v%QmsG%X{8m=S}mX~%F^zgO}EVK;GHcX zV%9{W4<<%(qcIwdMr~8^fn*aSFZk?F3_hvz!ix_|cp`l;#0SqgQ`kjdvh&TE^PPMC z?zyu|6YosMmZQ;-1lN;4yj$olP?ng){AS1sXTv0`X2gnSqgE^% zqxXQ>XvMQ}Su!*p0b9*XScz^j!Q(%`<8`DP@&U1)OGh6dNS?^!o`@W}Mu z-1t*_#}DkAnsoh#N=3V*%dRp#Tb{3u%AfeuB!u88ajjvq8bdKI63Q3;UJ#Sj%gTs6 z)5CfpWq(#N{On=Ya$Z>i?jqdYl~q|EOF{Gi+elexL5b;X6YGFALDtW@feW$CYy&*Q z%nun3h;j9$zFQ%u%)8EYVJdE*U~}V?!Chs}woO+n6ivgjnZXm{dv#cD607Q}d|CV* zcz`PVF*CiT*WcW z0)LPJ9|kK|E!pK_-f%Q{xgCi2h)A$c-Xn&CU-@|>FyfEkcLUo&aAdUOJ%D^Sz}Zx8 z0#Y5v+@C3)DV7F}QXc9%Ca#43(b2+H%px?TmBf?S6J^0JmMAS<;Unm2Ok4}M%RS=X za7LaJ>m!HdJ=Iqts;uruwo|+w?aYwj0kTF{zQVkNlY%)zzL%pJxmf)z`mwxy6tpWo zj!RuNcbXT=hVJ*`(DE4|_#uQb0LKr2PSDFYjTxDX9~&Q2_aHw}RpZy?3Z<@DvnLEz z6nzanC-yLX;P3JgYv=Oe~i@a7LF5*WKo&%`M992gE?ro%(`WdNeH;wzA zz^b4OY6$H%X2mlI(@3qwp$d-vlvP)R5qfW4lt!hyfNuV z4Y?mci6$z65{(r}ROTb7YeLux0KsuKXi_{a&J1WVhkLb@BUn_{Ts)0dRG-Fga}uX* zI*1hQ)nSxs5mnj-&o{M|EbIB2r{lO3Gpbu3akZTIFx5Y~4fJlrDbKvIw|Ed=6km;xrp{0{T#kuuFv2x!%z9iR6R~wRL8aobqQkCRfB6B09~!qQU-U=4nK)Tf%~@d6gqho;eJi!NFaP9 ze(A`2P32;w^UwWZP`W|-pyw93N!^5|zJ?3VAz+@)ogSif9PDysJBR-SIs9(&3aBp$ zqif4CtPaYE!NVKuI7)OpX&9P4p4`*mQw-X3;!&rk-B2!9SS&AcBbVbCo9{$u6*s$j z;yeJd8^FM3agJ-Exw}UVA|DbvyY*?Th({0}MTjEM$B)hgg`##~(*GO2TiPi61umM# kF8&sHm z6Ou|iXj9XC>A@J&gAt`1G}(hD-aP8Xcxon16BA90XAi`K@x3>YT_{d=e*5PA-h1DB z?|bvj$K#vlgI@&#UJ0(ukN4*PjNK15%TMn246Vx&lbGA|6unt*(UI4Y#8J?3vDRbh)WumSa?HXkxiE*ZNu$c*#=@7fQcFnhIdl| z7Vcd(N^DOI=tiJ@2k00}ux1F~$Xqj0Iw_jv_L$3dOY{l`q_#AjT?>mDBP}C+lL74R=;C+^m~LHg#WKwK z|25zgP+cyS3wguRz@>fn;wka6r$-(Y1<#iv>is@)8c0h<3!Vbx!{UiIDPI>m-ktO? zC~U9YMcLWi!Ot;*L8 z=Uk&$7SutVq7lI5c@kj~soj87;&s$gb=B61zQ%6(LvgwB&iYZLdjO`=erIHGE}g+T zjuK5*2qhXZlBkS+)P)fS0ANj=7Mf~Di*Z1UOFyfn)WBkWH^c;5QCS+_<0MYo^BPjL zM>8l@S5&FZPHbu$S=RE^NYn+YtjhasO&7m5^^Tu{xVGOa=irSf!t9h7$LV(ZdkLkh z2(t(}z?Q^m@9CZBMlHfi;@oq#GZfvTtNBs5y1KKbc-nk5PX4ay2wHgR;lPQhc&q$C znDOpu3_i7`)HI@+w41*JEYBg#A>^e~h*aWdUrl0SC-Lpz zMKDU&IpwyZ*QBG^|N2>Vprv<1JWigF9}2als8Y)Z#9GS-gB(3yN6*^vE2H+n_<_pS zEb%ni7KE2cpDVF7JXEbg;cJNt-kOw0#J$$_jsp5p*c&Jl8v<6K8@u*8T*d7;Ox{1*aIwTzO=E=L0T#a>)}p9Oz0%b6i*(4ZVx?lTf+hY3 D9Ehu~ diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-311.pyc index c669359c337d6d95e2cb2bc8f6f82f49b5a991e0..636f04cf21555bc93a108554b4c4d8d9daf5fc46 100644 GIT binary patch delta 19 ZcmbO&F HTTPResponse | None: """ Load a cached response, or return None if it's not available. """ + # We do not support caching of partial content: so if the request contains a + # Range header then we don't want to load anything from the cache. + if "Range" in request.headers: + return None + cache_url = request.url assert cache_url is not None cache_data = self.cache.get(cache_url) @@ -480,7 +485,7 @@ def update_cached_response( cached_response.headers.update( { k: v - for k, v in response.headers.items() # type: ignore[no-untyped-call] + for k, v in response.headers.items() if k.lower() not in excluded_headers } ) diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py index b9d72ca..f6e5634 100644 --- a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py +++ b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py @@ -68,7 +68,7 @@ def update_headers(self, response: HTTPResponse) -> dict[str, str]: 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] + expires = expire_after(timedelta(days=1), date=datetime(*date[:6], tzinfo=timezone.utc)) # type: ignore[index,misc] headers["expires"] = datetime_to_header(expires) headers["cache-control"] = "public" return headers diff --git a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py index f9e967c..a49487a 100644 --- a/myenv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py +++ b/myenv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py @@ -32,13 +32,13 @@ def dumps( # 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._fp = io.BytesIO(body) # type: ignore[assignment] 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] + "headers": {str(k): str(v) for k, v in response.headers.items()}, "status": response.status, "version": response.version, "reason": str(response.reason), @@ -72,31 +72,14 @@ def loads( 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 + # Previous versions of this library supported other serialization + # formats, but these have all been removed. + if not data.startswith(f"cc={self.serde_version},".encode()): return None + data = data[5:] + return self._loads_v4(request, data, body_file) + def prepare_response( self, request: PreparedRequest, @@ -149,49 +132,6 @@ def prepare_response( 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, diff --git a/myenv/Lib/site-packages/pip/_vendor/certifi/__init__.py b/myenv/Lib/site-packages/pip/_vendor/certifi/__init__.py index 8ce89ce..1c91f3e 100644 --- a/myenv/Lib/site-packages/pip/_vendor/certifi/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/certifi/__init__.py @@ -1,4 +1,4 @@ from .core import contents, where __all__ = ["contents", "where"] -__version__ = "2023.07.22" +__version__ = "2024.02.02" diff --git a/myenv/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-311.pyc index 27ebc065a6aeca4d19b65b4a8d3cec94f6bc3eac..e1223c3e163532624aba2250247d49b3b2a29f2d 100644 GIT binary patch delta 28 icmaFF^oWUTIWI340}!~JoXC~UW};_cq-QX(`Z)k;vIoon delta 28 icmaFF^oWUTIWI340}wbLn#h&SW~^smu4go{`Z)k;UI)qm diff --git a/myenv/Lib/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-311.pyc index 7bba1150dfc686401988668915f2292d1896095d..6382e989b179ad44524dfea4335abc252fdd1552 100644 GIT binary patch delta 19 Zcmey&`k9q$IWI340}!~J+{pEk2>>{c1$h7f delta 19 Zcmey&`k9q$IWI340}wbL+Q{{i2>>`|1#tiX diff --git a/myenv/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-311.pyc index 0d1b5880ef6c9f6b74894cbe7ed58082ca33c5b1..a2fb5b43b2caec5fabfe7475cb7379211a9a1fcc 100644 GIT binary patch delta 1585 zcmZ`&O>7%Q6rNe{u6NgKJ9ZMsNt!qBkt#^kLfnE-FS*e7#@;ju@a*~C+kNxi zeDBTMZ-;&z$$gd0It1jxkDp%oxbRu7yg5e+xlI`H38PGFP@gKT`5G%T{f6$RLR!}` z289_P7^wLW>@pih)AY?|+D}u$w5kQmW~tD*qOmkYX1cZow#&3-awLhWV|8a)8>RUc^F^it=hq9U|_pa zu>PI{xJ_a}@rquVhL$sO7d+eORRWchW#Z9yJxykUh53ayF0BL$E0?7e1mU&ySe#3> z7xHKYwQ4QopyF#B?-N%v2CzkT_59Cz`6s=6r|(Yu<;o*{^07X-ll-{_o5X!OI{Duu z_rcvE35JrbmKe~sU&<%Xgw!#IlDL>ygxrNW+J@B;Dt^#rHXZ3EWh~9Fyv?)VjcUBcu|F~u#a!A@Wh)MO5J?^KmMjq!Low=v52Xf5O+$II=9 z6$JoW4%R8CMlajcXdab3AB?fcg{p!QJVqunIhg->g#K z_h20B>7rOOnwuEYmAaW&F%s#@v7V~oNqozM_kitLycd+TR>L?rXeh^i@DjoRLKy*v zVkor@zSB| zyca{-$fO}HFF%!kG{5LQom!mcs5p-TNVC!?*VhWcicB4-Uo4joh%{Nf*r4V5vJ(mG zaT~)i&I;5E*z15}E{@9b3`Wdi11i=7pLfI35vl0C97Y|Lhe8;kFEwP$yI>)f;zR1z znAnZh=3v>h1%=1JcXV#SB+X?Oc;T5OEO`o{1>th}u)7dOA?V*1JI3Af7JnNL2ioEL z0SPN#J&S}x*0W;T>?N(DVos1wv2T8U+yNmcBDKaEtB2{Oh6(_?K|FK|0Us0}0+1Rl z1O*?j=muIS%t=LT`1#?-*bK447okhF;q#oZ5<@AJ@0@>0 zS21`K;Z*B>^alW(HfeYsZ4^BZ-o%D4x~%@uv)98zHBsRcN%3)n67U>)*Ab929~LjI z4CxbZtiJxsB>tKcwFX_UvPu2`cEYbh@sEi3ZuO|gQDN94z3qC>?&z@s(^a@lbdT&7 W#S8no*s#aNxSc!vVMmFEUHk)L(CW|t diff --git a/myenv/Lib/site-packages/pip/_vendor/certifi/cacert.pem b/myenv/Lib/site-packages/pip/_vendor/certifi/cacert.pem index 0212369..fac3c31 100644 --- a/myenv/Lib/site-packages/pip/_vendor/certifi/cacert.pem +++ b/myenv/Lib/site-packages/pip/_vendor/certifi/cacert.pem @@ -245,34 +245,6 @@ mJlglFwjz1onl14LBQaTNx47aTbrqZ5hHY8y2o4M1nQ+ewkk2gF3R8Q7zTSMmfXK 4SVhM7JZG+Ju1zdXtg2pEto= -----END CERTIFICATE----- -# Issuer: O=SECOM Trust.net OU=Security Communication RootCA1 -# Subject: O=SECOM Trust.net OU=Security Communication RootCA1 -# Label: "Security Communication Root CA" -# Serial: 0 -# MD5 Fingerprint: f1:bc:63:6a:54:e0:b5:27:f5:cd:e7:1a:e3:4d:6e:4a -# SHA1 Fingerprint: 36:b1:2b:49:f9:81:9e:d7:4c:9e:bc:38:0f:c6:56:8f:5d:ac:b2:f7 -# SHA256 Fingerprint: e7:5e:72:ed:9f:56:0e:ec:6e:b4:80:00:73:a4:3f:c3:ad:19:19:5a:39:22:82:01:78:95:97:4a:99:02:6b:6c ------BEGIN CERTIFICATE----- -MIIDWjCCAkKgAwIBAgIBADANBgkqhkiG9w0BAQUFADBQMQswCQYDVQQGEwJKUDEY -MBYGA1UEChMPU0VDT00gVHJ1c3QubmV0MScwJQYDVQQLEx5TZWN1cml0eSBDb21t -dW5pY2F0aW9uIFJvb3RDQTEwHhcNMDMwOTMwMDQyMDQ5WhcNMjMwOTMwMDQyMDQ5 -WjBQMQswCQYDVQQGEwJKUDEYMBYGA1UEChMPU0VDT00gVHJ1c3QubmV0MScwJQYD -VQQLEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTEwggEiMA0GCSqGSIb3 -DQEBAQUAA4IBDwAwggEKAoIBAQCzs/5/022x7xZ8V6UMbXaKL0u/ZPtM7orw8yl8 -9f/uKuDp6bpbZCKamm8sOiZpUQWZJtzVHGpxxpp9Hp3dfGzGjGdnSj74cbAZJ6kJ -DKaVv0uMDPpVmDvY6CKhS3E4eayXkmmziX7qIWgGmBSWh9JhNrxtJ1aeV+7AwFb9 -Ms+k2Y7CI9eNqPPYJayX5HA49LY6tJ07lyZDo6G8SVlyTCMwhwFY9k6+HGhWZq/N -QV3Is00qVUarH9oe4kA92819uZKAnDfdDJZkndwi92SL32HeFZRSFaB9UslLqCHJ -xrHty8OVYNEP8Ktw+N/LTX7s1vqr2b1/VPKl6Xn62dZ2JChzAgMBAAGjPzA9MB0G -A1UdDgQWBBSgc0mZaNyFW2XjmygvV5+9M7wHSDALBgNVHQ8EBAMCAQYwDwYDVR0T -AQH/BAUwAwEB/zANBgkqhkiG9w0BAQUFAAOCAQEAaECpqLvkT115swW1F7NgE+vG -kl3g0dNq/vu+m22/xwVtWSDEHPC32oRYAmP6SBbvT6UL90qY8j+eG61Ha2POCEfr -Uj94nK9NrvjVT8+amCoQQTlSxN3Zmw7vkwGusi7KaEIkQmywszo+zenaSMQVy+n5 -Bw+SUEmK3TGXX8npN6o7WWWXlDLJs58+OmJYxUmtYg5xpTKqL8aJdkNAExNnPaJU -JRDL8Try2frbSVa7pv6nQTXD4IhhyYjH3zYQIphZ6rBK+1YWc26sTfcioU+tHXot -RSflMMFe8toTyyVCUZVHA4xsIcx0Qu1T/zOLjw9XARYvz6buyXAiFL39vmwLAw== ------END CERTIFICATE----- - # Issuer: CN=XRamp Global Certification Authority O=XRamp Security Services Inc OU=www.xrampsecurity.com # Subject: CN=XRamp Global Certification Authority O=XRamp Security Services Inc OU=www.xrampsecurity.com # Label: "XRamp Global CA Root" @@ -881,49 +853,6 @@ Mx86OyXShkDOOyyGeMlhLxS67ttVb9+E7gUJTb0o2HLO02JQZR7rkpeDMdmztcpH WD9f -----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: 6047274297262753887 -# MD5 Fingerprint: 73:3a:74:7a:ec:bb:a3:96:a6:c2:e4:e2:c8:9b:c0:c3 -# SHA1 Fingerprint: ae:c5:fb:3f:c8:e1:bf:c4:e5:4f:03:07:5a:9a:e8:00:b7:f7:b6:fa -# SHA256 Fingerprint: 04:04:80:28:bf:1f:28:64:d4:8f:9a:d4:d8:32:94:36:6a:82:88:56:55:3f:3b:14:30:3f:90:14:7f:5d:40:ef ------BEGIN CERTIFICATE----- -MIIGFDCCA/ygAwIBAgIIU+w77vuySF8wDQYJKoZIhvcNAQEFBQAwUTELMAkGA1UE -BhMCRVMxQjBABgNVBAMMOUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1h -cHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2ODAeFw0wOTA1MjAwODM4MTVaFw0zMDEy -MzEwODM4MTVaMFExCzAJBgNVBAYTAkVTMUIwQAYDVQQDDDlBdXRvcmlkYWQgZGUg -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+JIwuwIDAQABo4HvMIHsMBIGA1UdEwEB/wQIMAYBAf8CAQEwDgYD -VR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRlzeurNR4APn7VdMActHNHDhpkLzCBpgYD -VR0gBIGeMIGbMIGYBgRVHSAAMIGPMC8GCCsGAQUFBwIBFiNodHRwOi8vd3d3LmZp -cm1hcHJvZmVzaW9uYWwuY29tL2NwczBcBggrBgEFBQcCAjBQHk4AUABhAHMAZQBv -ACAAZABlACAAbABhACAAQgBvAG4AYQBuAG8AdgBhACAANAA3ACAAQgBhAHIAYwBl -AGwAbwBuAGEAIAAwADgAMAAxADcwDQYJKoZIhvcNAQEFBQADggIBABd9oPm03cXF -661LJLWhAqvdpYhKsg9VSytXjDvlMd3+xDLx51tkljYyGOylMnfX40S2wBEqgLk9 -am58m9Ot/MPWo+ZkKXzR4Tgegiv/J2Wv+xYVxC5xhOW1//qkR71kMrv2JYSiJ0L1 -ILDCExARzRAVukKQKtJE4ZYm6zFIEv0q2skGz3QeqUvVhyj5eTSSPi5E6PaPT481 -PyWzOdxjKpBrIF/EUhJOlywqrJ2X3kjyo2bbwtKDlaZmp54lD+kLM5FlClrD2VQS -3a/DTg4fJl4N3LON7NWBcN7STyQF82xO9UxJZo3R/9ILJUFI/lGExkKvgATP0H5k -SeTy36LssUzAKh3ntLFlosS88Zj0qnAHY7S42jtM+kAiMFsRpvAFDsYCA0irhpuF -3dvd6qJ2gHN99ZwExEWN57kci57q13XRcrHedUTnQn3iV2t93Jm8PYMo6oCTjcVM -ZcFwgbg4/EMxsvYDNEeyrPsiBsse3RdHHF9mudMaotoRsaS8I8nkvof/uZS2+F0g -StRf571oe2XyFR7SOqkt6dhrJKyXWERHrVkY8SFlcN7ONGCoQPHzPKTDKCOM/icz -Q0CgFzzr6juwcqajuUpLXhZI9LK8yIySxZ2frHI2vDSANGupi5LAuBft7HZT9SQB -jLMi6Et8Vcad+qMUu2WFbm5PEn4KPJ2V ------END CERTIFICATE----- - # Issuer: CN=Izenpe.com O=IZENPE S.A. # Subject: CN=Izenpe.com O=IZENPE S.A. # Label: "Izenpe.com" @@ -4633,3 +4562,253 @@ 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=CommScope Public Trust ECC Root-01 O=CommScope +# Subject: CN=CommScope Public Trust ECC Root-01 O=CommScope +# Label: "CommScope Public Trust ECC Root-01" +# Serial: 385011430473757362783587124273108818652468453534 +# MD5 Fingerprint: 3a:40:a7:fc:03:8c:9c:38:79:2f:3a:a2:6c:b6:0a:16 +# SHA1 Fingerprint: 07:86:c0:d8:dd:8e:c0:80:98:06:98:d0:58:7a:ef:de:a6:cc:a2:5d +# SHA256 Fingerprint: 11:43:7c:da:7b:b4:5e:41:36:5f:45:b3:9a:38:98:6b:0d:e0:0d:ef:34:8e:0c:7b:b0:87:36:33:80:0b:c3:8b +-----BEGIN CERTIFICATE----- +MIICHTCCAaOgAwIBAgIUQ3CCd89NXTTxyq4yLzf39H91oJ4wCgYIKoZIzj0EAwMw +TjELMAkGA1UEBhMCVVMxEjAQBgNVBAoMCUNvbW1TY29wZTErMCkGA1UEAwwiQ29t +bVNjb3BlIFB1YmxpYyBUcnVzdCBFQ0MgUm9vdC0wMTAeFw0yMTA0MjgxNzM1NDNa +Fw00NjA0MjgxNzM1NDJaME4xCzAJBgNVBAYTAlVTMRIwEAYDVQQKDAlDb21tU2Nv +cGUxKzApBgNVBAMMIkNvbW1TY29wZSBQdWJsaWMgVHJ1c3QgRUNDIFJvb3QtMDEw +djAQBgcqhkjOPQIBBgUrgQQAIgNiAARLNumuV16ocNfQj3Rid8NeeqrltqLxeP0C +flfdkXmcbLlSiFS8LwS+uM32ENEp7LXQoMPwiXAZu1FlxUOcw5tjnSCDPgYLpkJE +hRGnSjot6dZoL0hOUysHP029uax3OVejQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYD +VR0PAQH/BAQDAgEGMB0GA1UdDgQWBBSOB2LAUN3GGQYARnQE9/OufXVNMDAKBggq +hkjOPQQDAwNoADBlAjEAnDPfQeMjqEI2Jpc1XHvr20v4qotzVRVcrHgpD7oh2MSg +2NED3W3ROT3Ek2DS43KyAjB8xX6I01D1HiXo+k515liWpDVfG2XqYZpwI7UNo5uS +Um9poIyNStDuiw7LR47QjRE= +-----END CERTIFICATE----- + +# Issuer: CN=CommScope Public Trust ECC Root-02 O=CommScope +# Subject: CN=CommScope Public Trust ECC Root-02 O=CommScope +# Label: "CommScope Public Trust ECC Root-02" +# Serial: 234015080301808452132356021271193974922492992893 +# MD5 Fingerprint: 59:b0:44:d5:65:4d:b8:5c:55:19:92:02:b6:d1:94:b2 +# SHA1 Fingerprint: 3c:3f:ef:57:0f:fe:65:93:86:9e:a0:fe:b0:f6:ed:8e:d1:13:c7:e5 +# SHA256 Fingerprint: 2f:fb:7f:81:3b:bb:b3:c8:9a:b4:e8:16:2d:0f:16:d7:15:09:a8:30:cc:9d:73:c2:62:e5:14:08:75:d1:ad:4a +-----BEGIN CERTIFICATE----- +MIICHDCCAaOgAwIBAgIUKP2ZYEFHpgE6yhR7H+/5aAiDXX0wCgYIKoZIzj0EAwMw +TjELMAkGA1UEBhMCVVMxEjAQBgNVBAoMCUNvbW1TY29wZTErMCkGA1UEAwwiQ29t +bVNjb3BlIFB1YmxpYyBUcnVzdCBFQ0MgUm9vdC0wMjAeFw0yMTA0MjgxNzQ0NTRa +Fw00NjA0MjgxNzQ0NTNaME4xCzAJBgNVBAYTAlVTMRIwEAYDVQQKDAlDb21tU2Nv +cGUxKzApBgNVBAMMIkNvbW1TY29wZSBQdWJsaWMgVHJ1c3QgRUNDIFJvb3QtMDIw +djAQBgcqhkjOPQIBBgUrgQQAIgNiAAR4MIHoYx7l63FRD/cHB8o5mXxO1Q/MMDAL +j2aTPs+9xYa9+bG3tD60B8jzljHz7aRP+KNOjSkVWLjVb3/ubCK1sK9IRQq9qEmU +v4RDsNuESgMjGWdqb8FuvAY5N9GIIvejQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYD +VR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTmGHX/72DehKT1RsfeSlXjMjZ59TAKBggq +hkjOPQQDAwNnADBkAjAmc0l6tqvmSfR9Uj/UQQSugEODZXW5hYA4O9Zv5JOGq4/n +ich/m35rChJVYaoR4HkCMHfoMXGsPHED1oQmHhS48zs73u1Z/GtMMH9ZzkXpc2AV +mkzw5l4lIhVtwodZ0LKOag== +-----END CERTIFICATE----- + +# Issuer: CN=CommScope Public Trust RSA Root-01 O=CommScope +# Subject: CN=CommScope Public Trust RSA Root-01 O=CommScope +# Label: "CommScope Public Trust RSA Root-01" +# Serial: 354030733275608256394402989253558293562031411421 +# MD5 Fingerprint: 0e:b4:15:bc:87:63:5d:5d:02:73:d4:26:38:68:73:d8 +# SHA1 Fingerprint: 6d:0a:5f:f7:b4:23:06:b4:85:b3:b7:97:64:fc:ac:75:f5:33:f2:93 +# SHA256 Fingerprint: 02:bd:f9:6e:2a:45:dd:9b:f1:8f:c7:e1:db:df:21:a0:37:9b:a3:c9:c2:61:03:44:cf:d8:d6:06:fe:c1:ed:81 +-----BEGIN CERTIFICATE----- +MIIFbDCCA1SgAwIBAgIUPgNJgXUWdDGOTKvVxZAplsU5EN0wDQYJKoZIhvcNAQEL +BQAwTjELMAkGA1UEBhMCVVMxEjAQBgNVBAoMCUNvbW1TY29wZTErMCkGA1UEAwwi +Q29tbVNjb3BlIFB1YmxpYyBUcnVzdCBSU0EgUm9vdC0wMTAeFw0yMTA0MjgxNjQ1 +NTRaFw00NjA0MjgxNjQ1NTNaME4xCzAJBgNVBAYTAlVTMRIwEAYDVQQKDAlDb21t +U2NvcGUxKzApBgNVBAMMIkNvbW1TY29wZSBQdWJsaWMgVHJ1c3QgUlNBIFJvb3Qt +MDEwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCwSGWjDR1C45FtnYSk +YZYSwu3D2iM0GXb26v1VWvZVAVMP8syMl0+5UMuzAURWlv2bKOx7dAvnQmtVzslh +suitQDy6uUEKBU8bJoWPQ7VAtYXR1HHcg0Hz9kXHgKKEUJdGzqAMxGBWBB0HW0al +DrJLpA6lfO741GIDuZNqihS4cPgugkY4Iw50x2tBt9Apo52AsH53k2NC+zSDO3Oj +WiE260f6GBfZumbCk6SP/F2krfxQapWsvCQz0b2If4b19bJzKo98rwjyGpg/qYFl +P8GMicWWMJoKz/TUyDTtnS+8jTiGU+6Xn6myY5QXjQ/cZip8UlF1y5mO6D1cv547 +KI2DAg+pn3LiLCuz3GaXAEDQpFSOm117RTYm1nJD68/A6g3czhLmfTifBSeolz7p +UcZsBSjBAg/pGG3svZwG1KdJ9FQFa2ww8esD1eo9anbCyxooSU1/ZOD6K9pzg4H/ +kQO9lLvkuI6cMmPNn7togbGEW682v3fuHX/3SZtS7NJ3Wn2RnU3COS3kuoL4b/JO +Hg9O5j9ZpSPcPYeoKFgo0fEbNttPxP/hjFtyjMcmAyejOQoBqsCyMWCDIqFPEgkB +Ea801M/XrmLTBQe0MXXgDW1XT2mH+VepuhX2yFJtocucH+X8eKg1mp9BFM6ltM6U +CBwJrVbl2rZJmkrqYxhTnCwuwwIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4G +A1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUN12mmnQywsL5x6YVEFm45P3luG0wDQYJ +KoZIhvcNAQELBQADggIBAK+nz97/4L1CjU3lIpbfaOp9TSp90K09FlxD533Ahuh6 +NWPxzIHIxgvoLlI1pKZJkGNRrDSsBTtXAOnTYtPZKdVUvhwQkZyybf5Z/Xn36lbQ +nmhUQo8mUuJM3y+Xpi/SB5io82BdS5pYV4jvguX6r2yBS5KPQJqTRlnLX3gWsWc+ +QgvfKNmwrZggvkN80V4aCRckjXtdlemrwWCrWxhkgPut4AZ9HcpZuPN4KWfGVh2v +trV0KnahP/t1MJ+UXjulYPPLXAziDslg+MkfFoom3ecnf+slpoq9uC02EJqxWE2a +aE9gVOX2RhOOiKy8IUISrcZKiX2bwdgt6ZYD9KJ0DLwAHb/WNyVntHKLr4W96ioD +j8z7PEQkguIBpQtZtjSNMgsSDesnwv1B10A8ckYpwIzqug/xBpMu95yo9GA+o/E4 +Xo4TwbM6l4c/ksp4qRyv0LAbJh6+cOx69TOY6lz/KwsETkPdY34Op054A5U+1C0w +lREQKC6/oAI+/15Z0wUOlV9TRe9rh9VIzRamloPh37MG88EU26fsHItdkJANclHn +YfkUyq+Dj7+vsQpZXdxc1+SWrVtgHdqul7I52Qb1dgAT+GhMIbA1xNxVssnBQVoc +icCMb3SgazNNtQEo/a2tiRc7ppqEvOuM6sRxJKi6KfkIsidWNTJf6jn7MZrVGczw +-----END CERTIFICATE----- + +# Issuer: CN=CommScope Public Trust RSA Root-02 O=CommScope +# Subject: CN=CommScope Public Trust RSA Root-02 O=CommScope +# Label: "CommScope Public Trust RSA Root-02" +# Serial: 480062499834624527752716769107743131258796508494 +# MD5 Fingerprint: e1:29:f9:62:7b:76:e2:96:6d:f3:d4:d7:0f:ae:1f:aa +# SHA1 Fingerprint: ea:b0:e2:52:1b:89:93:4c:11:68:f2:d8:9a:ac:22:4c:a3:8a:57:ae +# SHA256 Fingerprint: ff:e9:43:d7:93:42:4b:4f:7c:44:0c:1c:3d:64:8d:53:63:f3:4b:82:dc:87:aa:7a:9f:11:8f:c5:de:e1:01:f1 +-----BEGIN CERTIFICATE----- +MIIFbDCCA1SgAwIBAgIUVBa/O345lXGN0aoApYYNK496BU4wDQYJKoZIhvcNAQEL +BQAwTjELMAkGA1UEBhMCVVMxEjAQBgNVBAoMCUNvbW1TY29wZTErMCkGA1UEAwwi +Q29tbVNjb3BlIFB1YmxpYyBUcnVzdCBSU0EgUm9vdC0wMjAeFw0yMTA0MjgxNzE2 +NDNaFw00NjA0MjgxNzE2NDJaME4xCzAJBgNVBAYTAlVTMRIwEAYDVQQKDAlDb21t +U2NvcGUxKzApBgNVBAMMIkNvbW1TY29wZSBQdWJsaWMgVHJ1c3QgUlNBIFJvb3Qt +MDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDh+g77aAASyE3VrCLE +NQE7xVTlWXZjpX/rwcRqmL0yjReA61260WI9JSMZNRTpf4mnG2I81lDnNJUDMrG0 +kyI9p+Kx7eZ7Ti6Hmw0zdQreqjXnfuU2mKKuJZ6VszKWpCtYHu8//mI0SFHRtI1C +rWDaSWqVcN3SAOLMV2MCe5bdSZdbkk6V0/nLKR8YSvgBKtJjCW4k6YnS5cciTNxz +hkcAqg2Ijq6FfUrpuzNPDlJwnZXjfG2WWy09X6GDRl224yW4fKcZgBzqZUPckXk2 +LHR88mcGyYnJ27/aaL8j7dxrrSiDeS/sOKUNNwFnJ5rpM9kzXzehxfCrPfp4sOcs +n/Y+n2Dg70jpkEUeBVF4GiwSLFworA2iI540jwXmojPOEXcT1A6kHkIfhs1w/tku +FT0du7jyU1fbzMZ0KZwYszZ1OC4PVKH4kh+Jlk+71O6d6Ts2QrUKOyrUZHk2EOH5 +kQMreyBUzQ0ZGshBMjTRsJnhkB4BQDa1t/qp5Xd1pCKBXbCL5CcSD1SIxtuFdOa3 +wNemKfrb3vOTlycEVS8KbzfFPROvCgCpLIscgSjX74Yxqa7ybrjKaixUR9gqiC6v +wQcQeKwRoi9C8DfF8rhW3Q5iLc4tVn5V8qdE9isy9COoR+jUKgF4z2rDN6ieZdIs +5fq6M8EGRPbmz6UNp2YINIos8wIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4G +A1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUR9DnsSL/nSz12Vdgs7GxcJXvYXowDQYJ +KoZIhvcNAQELBQADggIBAIZpsU0v6Z9PIpNojuQhmaPORVMbc0RTAIFhzTHjCLqB +KCh6krm2qMhDnscTJk3C2OVVnJJdUNjCK9v+5qiXz1I6JMNlZFxHMaNlNRPDk7n3 ++VGXu6TwYofF1gbTl4MgqX67tiHCpQ2EAOHyJxCDut0DgdXdaMNmEMjRdrSzbyme +APnCKfWxkxlSaRosTKCL4BWaMS/TiJVZbuXEs1DIFAhKm4sTg7GkcrI7djNB3Nyq +pgdvHSQSn8h2vS/ZjvQs7rfSOBAkNlEv41xdgSGn2rtO/+YHqP65DSdsu3BaVXoT +6fEqSWnHX4dXTEN5bTpl6TBcQe7rd6VzEojov32u5cSoHw2OHG1QAk8mGEPej1WF +sQs3BWDJVTkSBKEqz3EWnzZRSb9wO55nnPt7eck5HHisd5FUmrh1CoFSl+NmYWvt +PjgelmFV4ZFUjO2MJB+ByRCac5krFk5yAD9UG/iNuovnFNa2RU9g7Jauwy8CTl2d +lklyALKrdVwPaFsdZcJfMw8eD/A7hvWwTruc9+olBdytoptLFwG+Qt81IR2tq670 +v64fG9PiO/yzcnMcmyiQiRM9HcEARwmWmjgb3bHPDcK0RPOWlc4yOo80nOAXx17O +rg3bhzjlP1v9mxnhMUF6cKojawHhRUzNlM47ni3niAIi9G7oyOzWPPO5std3eqx7 +-----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----- diff --git a/myenv/Lib/site-packages/pip/_vendor/certifi/core.py b/myenv/Lib/site-packages/pip/_vendor/certifi/core.py index c3e5466..70e0c3b 100644 --- a/myenv/Lib/site-packages/pip/_vendor/certifi/core.py +++ b/myenv/Lib/site-packages/pip/_vendor/certifi/core.py @@ -5,6 +5,10 @@ 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): @@ -35,6 +39,7 @@ def where() -> str: # 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__()) + atexit.register(exit_cacert_ctx) return _CACERT_PATH @@ -70,6 +75,7 @@ def where() -> str: # 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__()) + atexit.register(exit_cacert_ctx) return _CACERT_PATH diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__init__.py b/myenv/Lib/site-packages/pip/_vendor/chardet/__init__.py deleted file mode 100644 index fe58162..0000000 --- a/myenv/Lib/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/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-311.pyc deleted file mode 100644 index 3085f80d7de8d1773ee8181bd6830ed9939d6ebd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5086 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-311.pyc deleted file mode 100644 index ed1246fb3b33584d9b23f25281575a378dad1972..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1691 zcma)6&1)M+6rWk`uGXrQ4+lGvdvOz-AWC9rNn1?Yw3dqrL~f}lgheo{v}1e8?n<2* zxs}Pm2SJtAw5O6Bb8-o$|3ptc%EeH#U?}9&n}T~NIrY7j*IFelbawXb+xL4j?{ns- zLLo{h3L~GyF-0amt*04$LFs5|{cUpf;t*YrYm_>`csOd_6F1Bj$DA46=5X z5{;}9*XR+~GOJ z%0@X1XXH?13a&aLTx(*e$v{W&J^2;LkMt2yDRk24lN6FHCuCBG5|xw+R1}mk8GEpL z|7?c`gy{*QUQ4)_cLS}n9UhP;*|FZ3d)dBAAaJ@?wjx7z+FV2yV_xVf#spdvxM4Ka zj4R1xATao7#!Xe6Iau;-SZW9^xhiXsF1f!RO)=K=9Vr=;8myY%dEr%->R(7MWWBcO zeC7D{6)x|qR=a+uy0Sc9q_1$yF3m+UT+&)~m-PaGTD@RuThupWhhxy%nKYmVND>Bg| zShcuEFn4hHC}db$i*$76DS1l81&~YBnitbRqdbNHnPZ_7@a@Yfr_(?gS7A+e$RFot z`di`>@c+kfwt`0w(mo3d#AVzjW!& znz1OySkQ7iKJt0SzU(;u2#HG(Sx_2iFV&4Qa9M~Vy7D@ZsBqdPP44@Qm8rOhCegu< z;_L_uRgqjl;5#5tx#SsYx-l~(|3&h|JU7&+G5feVB=8xN=NW){_hN8po~o4|Uqy}5 zn55KF(lH+ABlZrnaUt%-)Y%vvm+8^*k$4dXql+*;T+#WUaa!R~;|jbCA`_$%jvBVl zDEhc?SnfC@FRb@Rnf_2*0~w}D_J9mCl+xjQguXi<@1*Aud228^kI37D$$3QH7);Kg WS)dT}t7LHT`g0Wj^)FbQkADDPAdc(+ diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-311.pyc deleted file mode 100644 index 2dc96d944913541e5fefd6c153f3ea558df5ae57..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11283 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-311.pyc deleted file mode 100644 index 7e86e8181c08d91f618cb828ddb5958f00f26ff8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4313 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-311.pyc deleted file mode 100644 index a65641a056390cbc9deda29228603309fa68a7c2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5559 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-311.pyc deleted file mode 100644 index 4d0077fe2a328b8102606335b1526208241ea9b3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4010 zcmb_e&2Jn@6|e63@MLCeLxKlyhOA4DHqMY_BJ;Tzw2-yKYQ@GNJ1eb>rB=JU#%`yl zds5xw#Kw_)$ibihmleqYBp*=NC?MreSRwv^37Uh|(n^sy?QK@!v?qSAdV0QWIMMc0 zzk2oRyc5PS=NX>GzyGfG@dRW4qDk_kyTt3CfOyPoW@|26W43OmT&=FJ=^D{# zH&susr8TCr_n4h|$n5M>ow4Wm#m`#C)>c_%>~oqff39JyXi;g=w;gYDH8ewU%e1x} zPb@iBh?Qb@s+O!+M?Cfbd6++Df~{#bThncAEoJK>ZKv#XEe!~1m@L{^ytDS07_(Di z4E!ACIYsOC8PI1y=WDv12VD@w?yT@I{S?}t_w25X+iAcbkItS%Z2kd|@*K|%9?(g6 zJw6H#eZC{4Q`_Yx-`K@MAnrDWX9-^OC3p=}hK|*AP07JkuBh^#`cf$qP!jJ7w*q_BjuBZ8~k3Hd$8b$Lw)n}=Iw*p>FVfK}MELI^5d!?4U9({arWS6t=3C*ob$ zZSv5miz>ejbHf{~Ez{c+0W1as>Nd;(hJBCNydlMo<2QruPSYbuUEKhhpjO(Y;3j_G z?(2eT5B7(xsw0u0U&C@JqzFQCsR_|$=wC}*vXEDbR&U=}xgD!mz!@Cq3>1b~D>j0V z(CN7&UE*{z!itS&Ckb}Zxx!Gqt)Ps1ngYk=LM#2JOB6yTgeLs&3rk$*@Z!3so3 zIf7MN1kR?1V5ziIp)tdgs^DRg_I&O`hr}_1z(Jbyl9S)ta*&i3B4GJmXd-AKIhr7j zs!LLxA`TIisQ~8+6Pclc=+x`NcBo!p$e~QJ!|I8=;RRa+xHs7F~T!lv|=tzI)mTT69+um1t!G27SnnbGTZ zHqEF-t4Gaxd&6wPXKXv^#SHS9gm3GZ^`yedgb(>#LWgG)im|7#^t@*cd(~w`>-+4e z(3k5|!@U_75JPWHElUD~J-oQlJ6g(nGelu?Z%D#Ws? z5Tk6|JEJkz-`vCn6`k1>;Rm3FjBUMKvhh3oN+p%8a(oN8m2@Hw6n8pdAvmoXf$ z%^YIus40mDOEt;CFye*4%on1TDfWb%QwJ}H0$)5coQ~I6Koqo@ndVWA%6A; z=m*I4{xQN{Js{WV(CWFPjwWYRUGyY|w5JBN>jU&aRSnu1+MDjn?;)Z0^*va9kQ$Q7 z^kw!3Z4FfUKD)2=>)FokjU$k{F^IPpF8YvLjtZ7*27wXMmxL<4XdCsgi5jZO zmr+4wYFD1TQ^`syZx!8vU>Au8>#UMi5tkQ0M|oAnN@0{&Wv$c&1d#4(l@U?i6Zb)?xm*Fxf7Y|Fqwpng3^DzEzk% zp1pXu)Gp2(&tCfTl~(ng_Uw;8&9`TNrkJm$-e^y~^-21#g%`{1%Zo3k7C+s7IrR&u zDbM`zher?Ece_9c@D4^+LM=Bxl78S6@0Y)i&jLNrYI;W;VDCHHRat-M>gba5T#Ai&| zi#z8SiPJEPU(m*I(EID?U(4h=jE1XYnWvOa<9==Fn>ETCevCoYUOvgm4 z`6^yf$x>-EcxU2UJX9`?GQw-tgSZnZ2Ym-y`cC^Y_oFy6@5t|CfeJIIVd$hZP3yeP kw8?`B`g_F|TEqXxY^F8*-^sqM0r|<{3*!Czlm&(3KOf!sN&o-= diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachinedict.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachinedict.cpython-311.pyc deleted file mode 100644 index e6a2e6b0091a9c716a01de2ef051436abbf8da69..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 966 zcmZ`%&rcIU6rR~%-2w$9(ohl!5)J7=IdCzCm}o&HN@G$u*laQxb_Tk#zns}(ns_kA zL%Db|p$89~G)52p4gLk?*38MoleZc?adKw25EAR`o44Qh-kY5_-_EB(VFbug`TlNq zP6OblBIm;zfYYi3M}PnVeGtGp479oi0flTv#xxnz>pBD)SO-LZ3y48=Vt%zg8UTEe zGaGe-bfwunz2vIP~^8-F(s>>o4A87q%VCy zPG3oI1SqIO0_xf}pgJ`O+|^1K)zl=~ie%J~NKetQ8soniGtF3XwRM4V3K6>o%6U<& zM8pgCY6(v0CUzTMNL9bL#i;9J&QXGQd@9B=vWwj$Vq%o5>OpGUZD59c8VGCv1dN5Fs&wP!N%(ukaW`FPhlTGE8YKbT3TA1VT6rBe{hag-RnzFZ+f<~ ze5`lwyhmO8hO`s=Mz2`v+R9Gs($M_OwT^qd+-ZE6=-P|YPVB|r_?33Poj=U?rl#A4 zcHvOYc7aWwZ~jnTDKnAE_|>u{tfUpoKgZNFT0HXZA{_{XI4- zDU_4Hk*=>p2zy|$JIsFQlYKA=7y2W>yxukDFI(TR%wiw>>yAs`Zl>|yD*0zfMSlv+ MEp(09%+enJ0?%{+SpWb4 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-311.pyc deleted file mode 100644 index 515fbad16c408bb0ce4a277effb2ec12fd639789..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1700 zcma)6&1>976rYh+TG?5D#7*qAdod0PT|#1L3r(8Ry4ejSB)bh+0zoVcvNX2UNZQTJ zY?3uO_^{ATYuZyujya_S(|@9;9@oWCBM1a~>TQEtC^_}b$g;I@0~w8;p5E`xyw91R z$HqnxjPkEPtW@#{{V9LaVeB(|H-UMKJmld3h1kYe@>-yUx~(f-4|1Vl8;Z{bW|+70 z7-{G$+P@etePCtEBpM<;rz8 zH7dWU2Ya{S=Ua%0A{%?i);zO^RjB+YUTAbrFScyjnaRY~QLbwL2<~Lq{Q~tDZi&MrM z^)=_d6ErH6-x1AL<7%~XdA?2~;fFxx(>7{^9U9$hT=$n7+!yp*%W>~GtCTlderu83 zqmkESi!L;hN5!Jsg8pf#b~@kcumYG|KanZu`82Rofbgq8{@p+?tg%P=&HNu$@pr4Z zZO!dibA4;>#q8N%YTL7yc4ja2a+~A-nCQ$G+ozXyPA~OxJJ!OkRrqoAyU|C5%|cH- zd$1WA>JwQx)h9B4a0W4CS*yi{^5;2vj@cvtT&m5pDWGvd#sTRgkrUGOV%G62a#k*r zmEAxuC#HM%*?Yjhi)r&(lTjyP)1c30H|$CIEV(}53{7IBnuMw9tcz~eFmCooE)IHkx68Z4>WAdJaGpIK8NI$4p8^D0te>4 zTJgy#sZl&68MTb`5Lfw7-pOoCs*cQ@kmS%zC5MR13o%SCM0LdCiEw$p!b$fsc_qXq zNI4uh*+5D3s&ca2DkHD0&yq}k&dz{Lriyog40Md~-~z%I`skDF+(jSuhvzQ(s6RY+ b(L#TC4$KJ*F&`!UsSjRB@!$W0seJqg0N0Lp diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-311.pyc deleted file mode 100644 index b9441a72f17cded4f7c912b3260c82d72c7a7dfd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3401 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-311.pyc deleted file mode 100644 index e6c71a7079d81aaf5fcbc124ec8f9567577f96f1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4743 zcmb_gO>7&-6`m!z)Ka3fl)Mi0_%?OqoCG z>@t-Ix-|+Hr2`=m3K!NP0eEt4xCL_PK{*sqdNO(`Nh}~@0ii;R9DFJ0ItAKX+BdT# zwQJd^8+0^!J2P+Io40S?eDjvSZfvYaP=@~S@%#^Yg#Jo8)xuU9&(qMjk7Oh>F%)OQ z41;8c?2I|$&ajiVT`^aj4YRb(#@z9`a9x}WbF}Y{dE)iqdfKjwHN?GPFKu(N#&}b> zi9rr@3CW&2NUm4B51a@+hJUk!dAVT<1-(y6H^><5Od^_0JY~#Y+sMq&m21OMRm0J_ zlm?u^gcMs*qbf{o8A{60#KM#&Y08)sxe-k$L5Jb3H0iM6y@r!>)kz>DP=!Ougr+QO z7F}IsVp_qNENJ*5W=PeB4Hhe^qCIjLE>(%m8y-=N#3WS}Mb!ZUf!p6K4h_uCs0vnR zr*23;mSVHRih5H^F3paP4POjQDG4na2NI}8>1=#ONqjhaH99w|Mm6R5k`%cqEhy^j zQgo?D{7^~AN!$~G=#>?%M@dB%mzHP@cQ38r7FaTE#=aR1-PQN~4sg^NApg9Lwz;v%e<63kuM83B7-$s6o zS>;~C1_s{4nT8CBKEb@7TkhCzW!3+v5$v4JFtTg+X1Dr9c2s;>ixt~`6V#%mvJ;nV zZ%lw~PqFVK?uI*)z}}u>p9gvg4$*Rx#xQQSS@P1z1F4$b0Bme1eYi^vKsB$Xz>TOD zfGaeK1CkaX5CJ?)VgQpRp8gw3unm*o!9JyN`0ir+~lapw$Ba@Tk zlZHE%Tv&h`ot2fj)B+9=*-k>pp)}l~@o8~v#BiIEhI@2+iuAen#%Dsq;^?%&PE8L^ zP8<6c0AM32jNu9v39QDHgi$ZT6>fIvePOuf6-9;|f>>dAhDWAHhNeeDmkfR(sfkJ= znOe9Z%917-O;lYnF&~wcL_{%KrY?_9P7lpYi_@1UN1$_cIOwKGkKZPCGEu`t`~hHJ zNkZrn9I-?MQ&a*&0b0z9su%icpY<*vrVYTT`e!&sw^51TxB8PjA2ciUbkcs;tY7&9 zxz>XJnC?GTMt;u^m}ivUy_6lyYC9c=K0UY9(O2x~`+U04F`#!0WUrR^j?Xgsp%X>^ zM4mrU@(K4EwtR<+zQZNqR7q&ng)X4?#!ABeXCAh>12^VndeV#A3UZX?0u10UB}?Gx6SU-qx{mx9OFhVPB% z1`EOwYCv#H=q?J~54GR?bdxIxqq;Df7e*pKYG6CJD>NR|ElJr9oW=#o@?8Cx0CZjuhw;F{I{z$ zSA$)cTq||}xJ53u8t=6v9Gc~d%m6IfA-2~V@upc=I`06MSdK9d|zvJ)F{omd4pDy}O7yM^+|Jkg! zM8-~R`7adx7YhE1y8mLY$J43->z)$ovqgt4?j;R};fZm{#Q zq@-c$s>aG^MMR0kL@~%G%6+o96iH~y=0_kOpQ|L`=Jkfj?=FTLMpgKRBnck1!c42lmjK$*AhCJx7QLno_|>_p`&?wEur4L fy_V2hd3!CpFE9+a`sFm=a`YKxef^3FbOZha`^yjX diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-311.pyc deleted file mode 100644 index 777bde9f8b34d180e2016fb4c639b2de251671bc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12099 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

rhLtyIkbS5&?+M2@niI% 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 W&ZcjZvOvn63Hko_XJ3EU{r>u(yJ4FL9KgwP z!w=$(ns5cJxZY+EQ&_!NX@w%V)fTk8>9QIXpR>jqWq?d5Wu#UimCu%M-}O?X@|$`v zxDP*HLrfGo*hh}$TV1q{eZ7-+bZYpRn(LZxbc{Wa+m}1laI90zd;`mM(L?Om5LYfa zr+gT?lvs?47K^K%j5Zz86ZsB)1@Z%af&X})Ug&a82-jfO?9R(C${*G5amskTw&{N5 zhV^C2w?v~^|Fp7vYqmyX5kx>{(>AI{Z5ltQ-woF4JP>rD>3Uo42Ici;&|D-BXzVxG zq6dxSQ?W=}-WF@BcDmARvpksGekW7VD`{Yt0pWLmyx2jcRAl!|5AcV|U_s{^r5_(&7A4*EqE2j_myRKTA4G}0xq zZmLUU_TU6!$gx)4w!oW(mDOkH8Ds+8+-yeUrThYqEuS2S{JX827Iue7%Q0%+4cpwKqDC(6!#^JVJB5(b=~O U7!vj-=}o@>TrU6fFPO^5E9q5^!vFvP diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-311.pyc deleted file mode 100644 index 6592e5ad3ff673a0551fccfa07a630b8446d3e7b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 27221 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/johabfreq.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/johabfreq.cpython-311.pyc deleted file mode 100644 index 61f4ee4696cc1d8da0cb8e8cc211b18f7b60bd83..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 84676 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 gz}>PB`S*gSExAZA}Wdc*Qhk=-=NB< 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 C&zSZA diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-311.pyc deleted file mode 100644 index 82fd4d51d1d729dbfbf92ae355960af1b81fccd5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 80034 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 Q(g%MbHyGMbQI^a7FP((S+yDRo diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-311.pyc deleted file mode 100644 index 0c889b6fcdc0ecf7484aa5dfdb03f910977ac90e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 108751 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-311.pyc deleted file mode 100644 index 819ef4475ad2e9d6ae7fe21025c8783ee9dc4b89..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 80212 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%0A2U*o8caUPffaD7Z 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 LU(aZgFSP#wP`;}o diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/macromanprober.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/macromanprober.cpython-311.pyc deleted file mode 100644 index 1d248c8de07b5d32698fea0acba8712e27967559..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7514 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 SJ6nD08>;>HBbww_?SBDusn0P0 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-311.pyc deleted file mode 100644 index b396b50e886b10a3f65f80b863fd6f98424217fc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4135 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/resultdict.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/resultdict.cpython-311.pyc deleted file mode 100644 index e0b9574fba124f1a76c76818ea2d6745be0bac51..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 784 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 Jids6({|`QcAiMwo diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf1632prober.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf1632prober.cpython-311.pyc deleted file mode 100644 index 0bb123cfcb26a85ef8ed985e0b2cdc685b1d2783..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10596 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-311.pyc deleted file mode 100644 index 7645d9a8f02dabfb56910f0e770928831ec13de7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3483 zcmb^z-D?|1es-mmR$pFQ@|WU|*lkFw_H1J}xunK8=i1H(#ByuNa0nlZtQ|RurL}K% z)z(4*KNzYMb4?*7fxB{k$|Z!BKK8kPfg}W876LAP%2QQx2c_J@{bp7ltHgyo+-UWi z-^}l0W`18Y{|W@W2-@Nge@p)tu%GCl*@Oo2ViS-DNI?phML90PaY*46N0!ey5)Ott zv(B855Ew3GT{(Bcof8ux8@sZeoHya+5Ra}Q#eIMj5j!3^5PAxKt0jDjCx#;4=X4n1 zOkrKk?5NKg3^& z-V6g^(Oot^kbc_IP(*Umju0j=YDpE*kxj}b4`|zJ5Gp8!p72q^!+gYT3R->_6H}Ds zjGED9nNTIf1Hkm8nEz!hX9i?7pObT&atdNZGX;V*tUuvRr-rj>(<95NY*N!?S)*FV z_J7MP&Tg!0m}ncZTggw7*^MQvZR) z{oH%kf9Nl<-wRNJI=oMh$-G|zjz3BocHaL_rS) zK?-^SG@L^Q=mez~x@~4-E}fuke+1CB*%yJ&19zoEsU(424!e%U;i@=X5l3s{XjvR> z+6=4-9~lJE4nxtvWrm_*1+|TXG~=TM0em=d`3ZW$kv<@3lx>V{%=EJm!@8^{bGR^I z+o7E>L#5mR_R)#dU;5;AS2htD0x2>~(0=ZQPIHV?D(n5{K+NoMv8lkkFLmWsuk?JfGBoEpHnvwDj(@)sb+dr{HYER0T(8rb~c6OwYAkXLiL%h=xSVESvFl3 zgXy{vkI}Jsb#* zX^fSEWJ@|aF$+AJ0bm~)J>fd?dj7ybX~7se`;YnKp$pZa3*UWI8M;&(x>UMpNJC#2 zYiFmc(sWsxem43}ZFKsc^S;mM?z<;6h%;4brYy}c;(IR>88gbRrO7keN%=MI+ot3N^ex8 zb2aJQkzRXizADX^rTO-vCsOFJP!_|lRu7tMEQ_On(7JU8F57knEBrRhgHZ>Hbe)bMR zpmBj(Zzn>_uNkz80jn!H>y6J|fTn=q#iy|<)+k@O&6K9)*wc{dw=Pn8<1+{RCeB&$ zFi)0Yj;4h6cK~$<$8q(`hzpm|p#3{RZKLbsaPx}lsUhe$ru1OB;^D4ME O@(Z2)_bDW1tN#H25%oX- diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-311.pyc deleted file mode 100644 index ff1d866c19f75300d91206442aef7717bdb5aa62..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 519 zcmYjO%}yIJ5VrH9AS2+^UbxJ$Ik0IDNGL+6CE3p8hm0@dV_iTb(ByMdqb5p$$5R<`{I3`Veg<> zn>2!esbLUI7K5N1%_Vi?X19~Z@y=0i_we8sdMTvO!cN=&VVnTJ7tvE1`(18MtV;de z{q8pOxU?d10N*5yb0dtO1TGrI(F^XyKZ2{A+yDRo diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/big5freq.py b/myenv/Lib/site-packages/pip/_vendor/chardet/big5freq.py deleted file mode 100644 index 87d9f97..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/big5freq.py +++ /dev/null @@ -1,386 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Communicator client code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 ######################### - -# Big5 frequency table -# by Taiwan's Mandarin Promotion Council -# -# -# 128 --> 0.42261 -# 256 --> 0.57851 -# 512 --> 0.74851 -# 1024 --> 0.89384 -# 2048 --> 0.97583 -# -# Ideal Distribution Ratio = 0.74851/(1-0.74851) =2.98 -# Random Distribution Ration = 512/(5401-512)=0.105 -# -# Typical Distribution Ratio about 25% of Ideal one, still much higher than RDR - -BIG5_TYPICAL_DISTRIBUTION_RATIO = 0.75 - -# Char to FreqOrder table -BIG5_TABLE_SIZE = 5376 -# fmt: off -BIG5_CHAR_TO_FREQ_ORDER = ( - 1,1801,1506, 255,1431, 198, 9, 82, 6,5008, 177, 202,3681,1256,2821, 110, # 16 -3814, 33,3274, 261, 76, 44,2114, 16,2946,2187,1176, 659,3971, 26,3451,2653, # 32 -1198,3972,3350,4202, 410,2215, 302, 590, 361,1964, 8, 204, 58,4510,5009,1932, # 48 - 63,5010,5011, 317,1614, 75, 222, 159,4203,2417,1480,5012,3555,3091, 224,2822, # 64 -3682, 3, 10,3973,1471, 29,2787,1135,2866,1940, 873, 130,3275,1123, 312,5013, # 80 -4511,2052, 507, 252, 682,5014, 142,1915, 124, 206,2947, 34,3556,3204, 64, 604, # 96 -5015,2501,1977,1978, 155,1991, 645, 641,1606,5016,3452, 337, 72, 406,5017, 80, # 112 - 630, 238,3205,1509, 263, 939,1092,2654, 756,1440,1094,3453, 449, 69,2987, 591, # 128 - 179,2096, 471, 115,2035,1844, 60, 50,2988, 134, 806,1869, 734,2036,3454, 180, # 144 - 995,1607, 156, 537,2907, 688,5018, 319,1305, 779,2145, 514,2379, 298,4512, 359, # 160 -2502, 90,2716,1338, 663, 11, 906,1099,2553, 20,2441, 182, 532,1716,5019, 732, # 176 -1376,4204,1311,1420,3206, 25,2317,1056, 113, 399, 382,1950, 242,3455,2474, 529, # 192 -3276, 475,1447,3683,5020, 117, 21, 656, 810,1297,2300,2334,3557,5021, 126,4205, # 208 - 706, 456, 150, 613,4513, 71,1118,2037,4206, 145,3092, 85, 835, 486,2115,1246, # 224 -1426, 428, 727,1285,1015, 800, 106, 623, 303,1281,5022,2128,2359, 347,3815, 221, # 240 -3558,3135,5023,1956,1153,4207, 83, 296,1199,3093, 192, 624, 93,5024, 822,1898, # 256 -2823,3136, 795,2065, 991,1554,1542,1592, 27, 43,2867, 859, 139,1456, 860,4514, # 272 - 437, 712,3974, 164,2397,3137, 695, 211,3037,2097, 195,3975,1608,3559,3560,3684, # 288 -3976, 234, 811,2989,2098,3977,2233,1441,3561,1615,2380, 668,2077,1638, 305, 228, # 304 -1664,4515, 467, 415,5025, 262,2099,1593, 239, 108, 300, 200,1033, 512,1247,2078, # 320 -5026,5027,2176,3207,3685,2682, 593, 845,1062,3277, 88,1723,2038,3978,1951, 212, # 336 - 266, 152, 149, 468,1899,4208,4516, 77, 187,5028,3038, 37, 5,2990,5029,3979, # 352 -5030,5031, 39,2524,4517,2908,3208,2079, 55, 148, 74,4518, 545, 483,1474,1029, # 368 -1665, 217,1870,1531,3138,1104,2655,4209, 24, 172,3562, 900,3980,3563,3564,4519, # 384 - 32,1408,2824,1312, 329, 487,2360,2251,2717, 784,2683, 4,3039,3351,1427,1789, # 400 - 188, 109, 499,5032,3686,1717,1790, 888,1217,3040,4520,5033,3565,5034,3352,1520, # 416 -3687,3981, 196,1034, 775,5035,5036, 929,1816, 249, 439, 38,5037,1063,5038, 794, # 432 -3982,1435,2301, 46, 178,3278,2066,5039,2381,5040, 214,1709,4521, 804, 35, 707, # 448 - 324,3688,1601,2554, 140, 459,4210,5041,5042,1365, 839, 272, 978,2262,2580,3456, # 464 -2129,1363,3689,1423, 697, 100,3094, 48, 70,1231, 495,3139,2196,5043,1294,5044, # 480 -2080, 462, 586,1042,3279, 853, 256, 988, 185,2382,3457,1698, 434,1084,5045,3458, # 496 - 314,2625,2788,4522,2335,2336, 569,2285, 637,1817,2525, 757,1162,1879,1616,3459, # 512 - 287,1577,2116, 768,4523,1671,2868,3566,2526,1321,3816, 909,2418,5046,4211, 933, # 528 -3817,4212,2053,2361,1222,4524, 765,2419,1322, 786,4525,5047,1920,1462,1677,2909, # 544 -1699,5048,4526,1424,2442,3140,3690,2600,3353,1775,1941,3460,3983,4213, 309,1369, # 560 -1130,2825, 364,2234,1653,1299,3984,3567,3985,3986,2656, 525,1085,3041, 902,2001, # 576 -1475, 964,4527, 421,1845,1415,1057,2286, 940,1364,3141, 376,4528,4529,1381, 7, # 592 -2527, 983,2383, 336,1710,2684,1846, 321,3461, 559,1131,3042,2752,1809,1132,1313, # 608 - 265,1481,1858,5049, 352,1203,2826,3280, 167,1089, 420,2827, 776, 792,1724,3568, # 624 -4214,2443,3281,5050,4215,5051, 446, 229, 333,2753, 901,3818,1200,1557,4530,2657, # 640 -1921, 395,2754,2685,3819,4216,1836, 125, 916,3209,2626,4531,5052,5053,3820,5054, # 656 -5055,5056,4532,3142,3691,1133,2555,1757,3462,1510,2318,1409,3569,5057,2146, 438, # 672 -2601,2910,2384,3354,1068, 958,3043, 461, 311,2869,2686,4217,1916,3210,4218,1979, # 688 - 383, 750,2755,2627,4219, 274, 539, 385,1278,1442,5058,1154,1965, 384, 561, 210, # 704 - 98,1295,2556,3570,5059,1711,2420,1482,3463,3987,2911,1257, 129,5060,3821, 642, # 720 - 523,2789,2790,2658,5061, 141,2235,1333, 68, 176, 441, 876, 907,4220, 603,2602, # 736 - 710, 171,3464, 404, 549, 18,3143,2398,1410,3692,1666,5062,3571,4533,2912,4534, # 752 -5063,2991, 368,5064, 146, 366, 99, 871,3693,1543, 748, 807,1586,1185, 22,2263, # 768 - 379,3822,3211,5065,3212, 505,1942,2628,1992,1382,2319,5066, 380,2362, 218, 702, # 784 -1818,1248,3465,3044,3572,3355,3282,5067,2992,3694, 930,3283,3823,5068, 59,5069, # 800 - 585, 601,4221, 497,3466,1112,1314,4535,1802,5070,1223,1472,2177,5071, 749,1837, # 816 - 690,1900,3824,1773,3988,1476, 429,1043,1791,2236,2117, 917,4222, 447,1086,1629, # 832 -5072, 556,5073,5074,2021,1654, 844,1090, 105, 550, 966,1758,2828,1008,1783, 686, # 848 -1095,5075,2287, 793,1602,5076,3573,2603,4536,4223,2948,2302,4537,3825, 980,2503, # 864 - 544, 353, 527,4538, 908,2687,2913,5077, 381,2629,1943,1348,5078,1341,1252, 560, # 880 -3095,5079,3467,2870,5080,2054, 973, 886,2081, 143,4539,5081,5082, 157,3989, 496, # 896 -4224, 57, 840, 540,2039,4540,4541,3468,2118,1445, 970,2264,1748,1966,2082,4225, # 912 -3144,1234,1776,3284,2829,3695, 773,1206,2130,1066,2040,1326,3990,1738,1725,4226, # 928 - 279,3145, 51,1544,2604, 423,1578,2131,2067, 173,4542,1880,5083,5084,1583, 264, # 944 - 610,3696,4543,2444, 280, 154,5085,5086,5087,1739, 338,1282,3096, 693,2871,1411, # 960 -1074,3826,2445,5088,4544,5089,5090,1240, 952,2399,5091,2914,1538,2688, 685,1483, # 976 -4227,2475,1436, 953,4228,2055,4545, 671,2400, 79,4229,2446,3285, 608, 567,2689, # 992 -3469,4230,4231,1691, 393,1261,1792,2401,5092,4546,5093,5094,5095,5096,1383,1672, # 1008 -3827,3213,1464, 522,1119, 661,1150, 216, 675,4547,3991,1432,3574, 609,4548,2690, # 1024 -2402,5097,5098,5099,4232,3045, 0,5100,2476, 315, 231,2447, 301,3356,4549,2385, # 1040 -5101, 233,4233,3697,1819,4550,4551,5102, 96,1777,1315,2083,5103, 257,5104,1810, # 1056 -3698,2718,1139,1820,4234,2022,1124,2164,2791,1778,2659,5105,3097, 363,1655,3214, # 1072 -5106,2993,5107,5108,5109,3992,1567,3993, 718, 103,3215, 849,1443, 341,3357,2949, # 1088 -1484,5110,1712, 127, 67, 339,4235,2403, 679,1412, 821,5111,5112, 834, 738, 351, # 1104 -2994,2147, 846, 235,1497,1881, 418,1993,3828,2719, 186,1100,2148,2756,3575,1545, # 1120 -1355,2950,2872,1377, 583,3994,4236,2581,2995,5113,1298,3699,1078,2557,3700,2363, # 1136 - 78,3829,3830, 267,1289,2100,2002,1594,4237, 348, 369,1274,2197,2178,1838,4552, # 1152 -1821,2830,3701,2757,2288,2003,4553,2951,2758, 144,3358, 882,4554,3995,2759,3470, # 1168 -4555,2915,5114,4238,1726, 320,5115,3996,3046, 788,2996,5116,2831,1774,1327,2873, # 1184 -3997,2832,5117,1306,4556,2004,1700,3831,3576,2364,2660, 787,2023, 506, 824,3702, # 1200 - 534, 323,4557,1044,3359,2024,1901, 946,3471,5118,1779,1500,1678,5119,1882,4558, # 1216 - 165, 243,4559,3703,2528, 123, 683,4239, 764,4560, 36,3998,1793, 589,2916, 816, # 1232 - 626,1667,3047,2237,1639,1555,1622,3832,3999,5120,4000,2874,1370,1228,1933, 891, # 1248 -2084,2917, 304,4240,5121, 292,2997,2720,3577, 691,2101,4241,1115,4561, 118, 662, # 1264 -5122, 611,1156, 854,2386,1316,2875, 2, 386, 515,2918,5123,5124,3286, 868,2238, # 1280 -1486, 855,2661, 785,2216,3048,5125,1040,3216,3578,5126,3146, 448,5127,1525,5128, # 1296 -2165,4562,5129,3833,5130,4242,2833,3579,3147, 503, 818,4001,3148,1568, 814, 676, # 1312 -1444, 306,1749,5131,3834,1416,1030, 197,1428, 805,2834,1501,4563,5132,5133,5134, # 1328 -1994,5135,4564,5136,5137,2198, 13,2792,3704,2998,3149,1229,1917,5138,3835,2132, # 1344 -5139,4243,4565,2404,3580,5140,2217,1511,1727,1120,5141,5142, 646,3836,2448, 307, # 1360 -5143,5144,1595,3217,5145,5146,5147,3705,1113,1356,4002,1465,2529,2530,5148, 519, # 1376 -5149, 128,2133, 92,2289,1980,5150,4003,1512, 342,3150,2199,5151,2793,2218,1981, # 1392 -3360,4244, 290,1656,1317, 789, 827,2365,5152,3837,4566, 562, 581,4004,5153, 401, # 1408 -4567,2252, 94,4568,5154,1399,2794,5155,1463,2025,4569,3218,1944,5156, 828,1105, # 1424 -4245,1262,1394,5157,4246, 605,4570,5158,1784,2876,5159,2835, 819,2102, 578,2200, # 1440 -2952,5160,1502, 436,3287,4247,3288,2836,4005,2919,3472,3473,5161,2721,2320,5162, # 1456 -5163,2337,2068, 23,4571, 193, 826,3838,2103, 699,1630,4248,3098, 390,1794,1064, # 1472 -3581,5164,1579,3099,3100,1400,5165,4249,1839,1640,2877,5166,4572,4573, 137,4250, # 1488 - 598,3101,1967, 780, 104, 974,2953,5167, 278, 899, 253, 402, 572, 504, 493,1339, # 1504 -5168,4006,1275,4574,2582,2558,5169,3706,3049,3102,2253, 565,1334,2722, 863, 41, # 1520 -5170,5171,4575,5172,1657,2338, 19, 463,2760,4251, 606,5173,2999,3289,1087,2085, # 1536 -1323,2662,3000,5174,1631,1623,1750,4252,2691,5175,2878, 791,2723,2663,2339, 232, # 1552 -2421,5176,3001,1498,5177,2664,2630, 755,1366,3707,3290,3151,2026,1609, 119,1918, # 1568 -3474, 862,1026,4253,5178,4007,3839,4576,4008,4577,2265,1952,2477,5179,1125, 817, # 1584 -4254,4255,4009,1513,1766,2041,1487,4256,3050,3291,2837,3840,3152,5180,5181,1507, # 1600 -5182,2692, 733, 40,1632,1106,2879, 345,4257, 841,2531, 230,4578,3002,1847,3292, # 1616 -3475,5183,1263, 986,3476,5184, 735, 879, 254,1137, 857, 622,1300,1180,1388,1562, # 1632 -4010,4011,2954, 967,2761,2665,1349, 592,2134,1692,3361,3003,1995,4258,1679,4012, # 1648 -1902,2188,5185, 739,3708,2724,1296,1290,5186,4259,2201,2202,1922,1563,2605,2559, # 1664 -1871,2762,3004,5187, 435,5188, 343,1108, 596, 17,1751,4579,2239,3477,3709,5189, # 1680 -4580, 294,3582,2955,1693, 477, 979, 281,2042,3583, 643,2043,3710,2631,2795,2266, # 1696 -1031,2340,2135,2303,3584,4581, 367,1249,2560,5190,3585,5191,4582,1283,3362,2005, # 1712 - 240,1762,3363,4583,4584, 836,1069,3153, 474,5192,2149,2532, 268,3586,5193,3219, # 1728 -1521,1284,5194,1658,1546,4260,5195,3587,3588,5196,4261,3364,2693,1685,4262, 961, # 1744 -1673,2632, 190,2006,2203,3841,4585,4586,5197, 570,2504,3711,1490,5198,4587,2633, # 1760 -3293,1957,4588, 584,1514, 396,1045,1945,5199,4589,1968,2449,5200,5201,4590,4013, # 1776 - 619,5202,3154,3294, 215,2007,2796,2561,3220,4591,3221,4592, 763,4263,3842,4593, # 1792 -5203,5204,1958,1767,2956,3365,3712,1174, 452,1477,4594,3366,3155,5205,2838,1253, # 1808 -2387,2189,1091,2290,4264, 492,5206, 638,1169,1825,2136,1752,4014, 648, 926,1021, # 1824 -1324,4595, 520,4596, 997, 847,1007, 892,4597,3843,2267,1872,3713,2405,1785,4598, # 1840 -1953,2957,3103,3222,1728,4265,2044,3714,4599,2008,1701,3156,1551, 30,2268,4266, # 1856 -5207,2027,4600,3589,5208, 501,5209,4267, 594,3478,2166,1822,3590,3479,3591,3223, # 1872 - 829,2839,4268,5210,1680,3157,1225,4269,5211,3295,4601,4270,3158,2341,5212,4602, # 1888 -4271,5213,4015,4016,5214,1848,2388,2606,3367,5215,4603, 374,4017, 652,4272,4273, # 1904 - 375,1140, 798,5216,5217,5218,2366,4604,2269, 546,1659, 138,3051,2450,4605,5219, # 1920 -2254, 612,1849, 910, 796,3844,1740,1371, 825,3845,3846,5220,2920,2562,5221, 692, # 1936 - 444,3052,2634, 801,4606,4274,5222,1491, 244,1053,3053,4275,4276, 340,5223,4018, # 1952 -1041,3005, 293,1168, 87,1357,5224,1539, 959,5225,2240, 721, 694,4277,3847, 219, # 1968 -1478, 644,1417,3368,2666,1413,1401,1335,1389,4019,5226,5227,3006,2367,3159,1826, # 1984 - 730,1515, 184,2840, 66,4607,5228,1660,2958, 246,3369, 378,1457, 226,3480, 975, # 2000 -4020,2959,1264,3592, 674, 696,5229, 163,5230,1141,2422,2167, 713,3593,3370,4608, # 2016 -4021,5231,5232,1186, 15,5233,1079,1070,5234,1522,3224,3594, 276,1050,2725, 758, # 2032 -1126, 653,2960,3296,5235,2342, 889,3595,4022,3104,3007, 903,1250,4609,4023,3481, # 2048 -3596,1342,1681,1718, 766,3297, 286, 89,2961,3715,5236,1713,5237,2607,3371,3008, # 2064 -5238,2962,2219,3225,2880,5239,4610,2505,2533, 181, 387,1075,4024, 731,2190,3372, # 2080 -5240,3298, 310, 313,3482,2304, 770,4278, 54,3054, 189,4611,3105,3848,4025,5241, # 2096 -1230,1617,1850, 355,3597,4279,4612,3373, 111,4280,3716,1350,3160,3483,3055,4281, # 2112 -2150,3299,3598,5242,2797,4026,4027,3009, 722,2009,5243,1071, 247,1207,2343,2478, # 2128 -1378,4613,2010, 864,1437,1214,4614, 373,3849,1142,2220, 667,4615, 442,2763,2563, # 2144 -3850,4028,1969,4282,3300,1840, 837, 170,1107, 934,1336,1883,5244,5245,2119,4283, # 2160 -2841, 743,1569,5246,4616,4284, 582,2389,1418,3484,5247,1803,5248, 357,1395,1729, # 2176 -3717,3301,2423,1564,2241,5249,3106,3851,1633,4617,1114,2086,4285,1532,5250, 482, # 2192 -2451,4618,5251,5252,1492, 833,1466,5253,2726,3599,1641,2842,5254,1526,1272,3718, # 2208 -4286,1686,1795, 416,2564,1903,1954,1804,5255,3852,2798,3853,1159,2321,5256,2881, # 2224 -4619,1610,1584,3056,2424,2764, 443,3302,1163,3161,5257,5258,4029,5259,4287,2506, # 2240 -3057,4620,4030,3162,2104,1647,3600,2011,1873,4288,5260,4289, 431,3485,5261, 250, # 2256 - 97, 81,4290,5262,1648,1851,1558, 160, 848,5263, 866, 740,1694,5264,2204,2843, # 2272 -3226,4291,4621,3719,1687, 950,2479, 426, 469,3227,3720,3721,4031,5265,5266,1188, # 2288 - 424,1996, 861,3601,4292,3854,2205,2694, 168,1235,3602,4293,5267,2087,1674,4622, # 2304 -3374,3303, 220,2565,1009,5268,3855, 670,3010, 332,1208, 717,5269,5270,3603,2452, # 2320 -4032,3375,5271, 513,5272,1209,2882,3376,3163,4623,1080,5273,5274,5275,5276,2534, # 2336 -3722,3604, 815,1587,4033,4034,5277,3605,3486,3856,1254,4624,1328,3058,1390,4035, # 2352 -1741,4036,3857,4037,5278, 236,3858,2453,3304,5279,5280,3723,3859,1273,3860,4625, # 2368 -5281, 308,5282,4626, 245,4627,1852,2480,1307,2583, 430, 715,2137,2454,5283, 270, # 2384 - 199,2883,4038,5284,3606,2727,1753, 761,1754, 725,1661,1841,4628,3487,3724,5285, # 2400 -5286, 587, 14,3305, 227,2608, 326, 480,2270, 943,2765,3607, 291, 650,1884,5287, # 2416 -1702,1226, 102,1547, 62,3488, 904,4629,3489,1164,4294,5288,5289,1224,1548,2766, # 2432 - 391, 498,1493,5290,1386,1419,5291,2056,1177,4630, 813, 880,1081,2368, 566,1145, # 2448 -4631,2291,1001,1035,2566,2609,2242, 394,1286,5292,5293,2069,5294, 86,1494,1730, # 2464 -4039, 491,1588, 745, 897,2963, 843,3377,4040,2767,2884,3306,1768, 998,2221,2070, # 2480 - 397,1827,1195,1970,3725,3011,3378, 284,5295,3861,2507,2138,2120,1904,5296,4041, # 2496 -2151,4042,4295,1036,3490,1905, 114,2567,4296, 209,1527,5297,5298,2964,2844,2635, # 2512 -2390,2728,3164, 812,2568,5299,3307,5300,1559, 737,1885,3726,1210, 885, 28,2695, # 2528 -3608,3862,5301,4297,1004,1780,4632,5302, 346,1982,2222,2696,4633,3863,1742, 797, # 2544 -1642,4043,1934,1072,1384,2152, 896,4044,3308,3727,3228,2885,3609,5303,2569,1959, # 2560 -4634,2455,1786,5304,5305,5306,4045,4298,1005,1308,3728,4299,2729,4635,4636,1528, # 2576 -2610, 161,1178,4300,1983, 987,4637,1101,4301, 631,4046,1157,3229,2425,1343,1241, # 2592 -1016,2243,2570, 372, 877,2344,2508,1160, 555,1935, 911,4047,5307, 466,1170, 169, # 2608 -1051,2921,2697,3729,2481,3012,1182,2012,2571,1251,2636,5308, 992,2345,3491,1540, # 2624 -2730,1201,2071,2406,1997,2482,5309,4638, 528,1923,2191,1503,1874,1570,2369,3379, # 2640 -3309,5310, 557,1073,5311,1828,3492,2088,2271,3165,3059,3107, 767,3108,2799,4639, # 2656 -1006,4302,4640,2346,1267,2179,3730,3230, 778,4048,3231,2731,1597,2667,5312,4641, # 2672 -5313,3493,5314,5315,5316,3310,2698,1433,3311, 131, 95,1504,4049, 723,4303,3166, # 2688 -1842,3610,2768,2192,4050,2028,2105,3731,5317,3013,4051,1218,5318,3380,3232,4052, # 2704 -4304,2584, 248,1634,3864, 912,5319,2845,3732,3060,3865, 654, 53,5320,3014,5321, # 2720 -1688,4642, 777,3494,1032,4053,1425,5322, 191, 820,2121,2846, 971,4643, 931,3233, # 2736 - 135, 664, 783,3866,1998, 772,2922,1936,4054,3867,4644,2923,3234, 282,2732, 640, # 2752 -1372,3495,1127, 922, 325,3381,5323,5324, 711,2045,5325,5326,4055,2223,2800,1937, # 2768 -4056,3382,2224,2255,3868,2305,5327,4645,3869,1258,3312,4057,3235,2139,2965,4058, # 2784 -4059,5328,2225, 258,3236,4646, 101,1227,5329,3313,1755,5330,1391,3314,5331,2924, # 2800 -2057, 893,5332,5333,5334,1402,4305,2347,5335,5336,3237,3611,5337,5338, 878,1325, # 2816 -1781,2801,4647, 259,1385,2585, 744,1183,2272,4648,5339,4060,2509,5340, 684,1024, # 2832 -4306,5341, 472,3612,3496,1165,3315,4061,4062, 322,2153, 881, 455,1695,1152,1340, # 2848 - 660, 554,2154,4649,1058,4650,4307, 830,1065,3383,4063,4651,1924,5342,1703,1919, # 2864 -5343, 932,2273, 122,5344,4652, 947, 677,5345,3870,2637, 297,1906,1925,2274,4653, # 2880 -2322,3316,5346,5347,4308,5348,4309, 84,4310, 112, 989,5349, 547,1059,4064, 701, # 2896 -3613,1019,5350,4311,5351,3497, 942, 639, 457,2306,2456, 993,2966, 407, 851, 494, # 2912 -4654,3384, 927,5352,1237,5353,2426,3385, 573,4312, 680, 921,2925,1279,1875, 285, # 2928 - 790,1448,1984, 719,2168,5354,5355,4655,4065,4066,1649,5356,1541, 563,5357,1077, # 2944 -5358,3386,3061,3498, 511,3015,4067,4068,3733,4069,1268,2572,3387,3238,4656,4657, # 2960 -5359, 535,1048,1276,1189,2926,2029,3167,1438,1373,2847,2967,1134,2013,5360,4313, # 2976 -1238,2586,3109,1259,5361, 700,5362,2968,3168,3734,4314,5363,4315,1146,1876,1907, # 2992 -4658,2611,4070, 781,2427, 132,1589, 203, 147, 273,2802,2407, 898,1787,2155,4071, # 3008 -4072,5364,3871,2803,5365,5366,4659,4660,5367,3239,5368,1635,3872, 965,5369,1805, # 3024 -2699,1516,3614,1121,1082,1329,3317,4073,1449,3873, 65,1128,2848,2927,2769,1590, # 3040 -3874,5370,5371, 12,2668, 45, 976,2587,3169,4661, 517,2535,1013,1037,3240,5372, # 3056 -3875,2849,5373,3876,5374,3499,5375,2612, 614,1999,2323,3877,3110,2733,2638,5376, # 3072 -2588,4316, 599,1269,5377,1811,3735,5378,2700,3111, 759,1060, 489,1806,3388,3318, # 3088 -1358,5379,5380,2391,1387,1215,2639,2256, 490,5381,5382,4317,1759,2392,2348,5383, # 3104 -4662,3878,1908,4074,2640,1807,3241,4663,3500,3319,2770,2349, 874,5384,5385,3501, # 3120 -3736,1859, 91,2928,3737,3062,3879,4664,5386,3170,4075,2669,5387,3502,1202,1403, # 3136 -3880,2969,2536,1517,2510,4665,3503,2511,5388,4666,5389,2701,1886,1495,1731,4076, # 3152 -2370,4667,5390,2030,5391,5392,4077,2702,1216, 237,2589,4318,2324,4078,3881,4668, # 3168 -4669,2703,3615,3504, 445,4670,5393,5394,5395,5396,2771, 61,4079,3738,1823,4080, # 3184 -5397, 687,2046, 935, 925, 405,2670, 703,1096,1860,2734,4671,4081,1877,1367,2704, # 3200 -3389, 918,2106,1782,2483, 334,3320,1611,1093,4672, 564,3171,3505,3739,3390, 945, # 3216 -2641,2058,4673,5398,1926, 872,4319,5399,3506,2705,3112, 349,4320,3740,4082,4674, # 3232 -3882,4321,3741,2156,4083,4675,4676,4322,4677,2408,2047, 782,4084, 400, 251,4323, # 3248 -1624,5400,5401, 277,3742, 299,1265, 476,1191,3883,2122,4324,4325,1109, 205,5402, # 3264 -2590,1000,2157,3616,1861,5403,5404,5405,4678,5406,4679,2573, 107,2484,2158,4085, # 3280 -3507,3172,5407,1533, 541,1301, 158, 753,4326,2886,3617,5408,1696, 370,1088,4327, # 3296 -4680,3618, 579, 327, 440, 162,2244, 269,1938,1374,3508, 968,3063, 56,1396,3113, # 3312 -2107,3321,3391,5409,1927,2159,4681,3016,5410,3619,5411,5412,3743,4682,2485,5413, # 3328 -2804,5414,1650,4683,5415,2613,5416,5417,4086,2671,3392,1149,3393,4087,3884,4088, # 3344 -5418,1076, 49,5419, 951,3242,3322,3323, 450,2850, 920,5420,1812,2805,2371,4328, # 3360 -1909,1138,2372,3885,3509,5421,3243,4684,1910,1147,1518,2428,4685,3886,5422,4686, # 3376 -2393,2614, 260,1796,3244,5423,5424,3887,3324, 708,5425,3620,1704,5426,3621,1351, # 3392 -1618,3394,3017,1887, 944,4329,3395,4330,3064,3396,4331,5427,3744, 422, 413,1714, # 3408 -3325, 500,2059,2350,4332,2486,5428,1344,1911, 954,5429,1668,5430,5431,4089,2409, # 3424 -4333,3622,3888,4334,5432,2307,1318,2512,3114, 133,3115,2887,4687, 629, 31,2851, # 3440 -2706,3889,4688, 850, 949,4689,4090,2970,1732,2089,4335,1496,1853,5433,4091, 620, # 3456 -3245, 981,1242,3745,3397,1619,3746,1643,3326,2140,2457,1971,1719,3510,2169,5434, # 3472 -3246,5435,5436,3398,1829,5437,1277,4690,1565,2048,5438,1636,3623,3116,5439, 869, # 3488 -2852, 655,3890,3891,3117,4092,3018,3892,1310,3624,4691,5440,5441,5442,1733, 558, # 3504 -4692,3747, 335,1549,3065,1756,4336,3748,1946,3511,1830,1291,1192, 470,2735,2108, # 3520 -2806, 913,1054,4093,5443,1027,5444,3066,4094,4693, 982,2672,3399,3173,3512,3247, # 3536 -3248,1947,2807,5445, 571,4694,5446,1831,5447,3625,2591,1523,2429,5448,2090, 984, # 3552 -4695,3749,1960,5449,3750, 852, 923,2808,3513,3751, 969,1519, 999,2049,2325,1705, # 3568 -5450,3118, 615,1662, 151, 597,4095,2410,2326,1049, 275,4696,3752,4337, 568,3753, # 3584 -3626,2487,4338,3754,5451,2430,2275, 409,3249,5452,1566,2888,3514,1002, 769,2853, # 3600 - 194,2091,3174,3755,2226,3327,4339, 628,1505,5453,5454,1763,2180,3019,4096, 521, # 3616 -1161,2592,1788,2206,2411,4697,4097,1625,4340,4341, 412, 42,3119, 464,5455,2642, # 3632 -4698,3400,1760,1571,2889,3515,2537,1219,2207,3893,2643,2141,2373,4699,4700,3328, # 3648 -1651,3401,3627,5456,5457,3628,2488,3516,5458,3756,5459,5460,2276,2092, 460,5461, # 3664 -4701,5462,3020, 962, 588,3629, 289,3250,2644,1116, 52,5463,3067,1797,5464,5465, # 3680 -5466,1467,5467,1598,1143,3757,4342,1985,1734,1067,4702,1280,3402, 465,4703,1572, # 3696 - 510,5468,1928,2245,1813,1644,3630,5469,4704,3758,5470,5471,2673,1573,1534,5472, # 3712 -5473, 536,1808,1761,3517,3894,3175,2645,5474,5475,5476,4705,3518,2929,1912,2809, # 3728 -5477,3329,1122, 377,3251,5478, 360,5479,5480,4343,1529, 551,5481,2060,3759,1769, # 3744 -2431,5482,2930,4344,3330,3120,2327,2109,2031,4706,1404, 136,1468,1479, 672,1171, # 3760 -3252,2308, 271,3176,5483,2772,5484,2050, 678,2736, 865,1948,4707,5485,2014,4098, # 3776 -2971,5486,2737,2227,1397,3068,3760,4708,4709,1735,2931,3403,3631,5487,3895, 509, # 3792 -2854,2458,2890,3896,5488,5489,3177,3178,4710,4345,2538,4711,2309,1166,1010, 552, # 3808 - 681,1888,5490,5491,2972,2973,4099,1287,1596,1862,3179, 358, 453, 736, 175, 478, # 3824 -1117, 905,1167,1097,5492,1854,1530,5493,1706,5494,2181,3519,2292,3761,3520,3632, # 3840 -4346,2093,4347,5495,3404,1193,2489,4348,1458,2193,2208,1863,1889,1421,3331,2932, # 3856 -3069,2182,3521, 595,2123,5496,4100,5497,5498,4349,1707,2646, 223,3762,1359, 751, # 3872 -3121, 183,3522,5499,2810,3021, 419,2374, 633, 704,3897,2394, 241,5500,5501,5502, # 3888 - 838,3022,3763,2277,2773,2459,3898,1939,2051,4101,1309,3122,2246,1181,5503,1136, # 3904 -2209,3899,2375,1446,4350,2310,4712,5504,5505,4351,1055,2615, 484,3764,5506,4102, # 3920 - 625,4352,2278,3405,1499,4353,4103,5507,4104,4354,3253,2279,2280,3523,5508,5509, # 3936 -2774, 808,2616,3765,3406,4105,4355,3123,2539, 526,3407,3900,4356, 955,5510,1620, # 3952 -4357,2647,2432,5511,1429,3766,1669,1832, 994, 928,5512,3633,1260,5513,5514,5515, # 3968 -1949,2293, 741,2933,1626,4358,2738,2460, 867,1184, 362,3408,1392,5516,5517,4106, # 3984 -4359,1770,1736,3254,2934,4713,4714,1929,2707,1459,1158,5518,3070,3409,2891,1292, # 4000 -1930,2513,2855,3767,1986,1187,2072,2015,2617,4360,5519,2574,2514,2170,3768,2490, # 4016 -3332,5520,3769,4715,5521,5522, 666,1003,3023,1022,3634,4361,5523,4716,1814,2257, # 4032 - 574,3901,1603, 295,1535, 705,3902,4362, 283, 858, 417,5524,5525,3255,4717,4718, # 4048 -3071,1220,1890,1046,2281,2461,4107,1393,1599, 689,2575, 388,4363,5526,2491, 802, # 4064 -5527,2811,3903,2061,1405,2258,5528,4719,3904,2110,1052,1345,3256,1585,5529, 809, # 4080 -5530,5531,5532, 575,2739,3524, 956,1552,1469,1144,2328,5533,2329,1560,2462,3635, # 4096 -3257,4108, 616,2210,4364,3180,2183,2294,5534,1833,5535,3525,4720,5536,1319,3770, # 4112 -3771,1211,3636,1023,3258,1293,2812,5537,5538,5539,3905, 607,2311,3906, 762,2892, # 4128 -1439,4365,1360,4721,1485,3072,5540,4722,1038,4366,1450,2062,2648,4367,1379,4723, # 4144 -2593,5541,5542,4368,1352,1414,2330,2935,1172,5543,5544,3907,3908,4724,1798,1451, # 4160 -5545,5546,5547,5548,2936,4109,4110,2492,2351, 411,4111,4112,3637,3333,3124,4725, # 4176 -1561,2674,1452,4113,1375,5549,5550, 47,2974, 316,5551,1406,1591,2937,3181,5552, # 4192 -1025,2142,3125,3182, 354,2740, 884,2228,4369,2412, 508,3772, 726,3638, 996,2433, # 4208 -3639, 729,5553, 392,2194,1453,4114,4726,3773,5554,5555,2463,3640,2618,1675,2813, # 4224 - 919,2352,2975,2353,1270,4727,4115, 73,5556,5557, 647,5558,3259,2856,2259,1550, # 4240 -1346,3024,5559,1332, 883,3526,5560,5561,5562,5563,3334,2775,5564,1212, 831,1347, # 4256 -4370,4728,2331,3909,1864,3073, 720,3910,4729,4730,3911,5565,4371,5566,5567,4731, # 4272 -5568,5569,1799,4732,3774,2619,4733,3641,1645,2376,4734,5570,2938, 669,2211,2675, # 4288 -2434,5571,2893,5572,5573,1028,3260,5574,4372,2413,5575,2260,1353,5576,5577,4735, # 4304 -3183, 518,5578,4116,5579,4373,1961,5580,2143,4374,5581,5582,3025,2354,2355,3912, # 4320 - 516,1834,1454,4117,2708,4375,4736,2229,2620,1972,1129,3642,5583,2776,5584,2976, # 4336 -1422, 577,1470,3026,1524,3410,5585,5586, 432,4376,3074,3527,5587,2594,1455,2515, # 4352 -2230,1973,1175,5588,1020,2741,4118,3528,4737,5589,2742,5590,1743,1361,3075,3529, # 4368 -2649,4119,4377,4738,2295, 895, 924,4378,2171, 331,2247,3076, 166,1627,3077,1098, # 4384 -5591,1232,2894,2231,3411,4739, 657, 403,1196,2377, 542,3775,3412,1600,4379,3530, # 4400 -5592,4740,2777,3261, 576, 530,1362,4741,4742,2540,2676,3776,4120,5593, 842,3913, # 4416 -5594,2814,2032,1014,4121, 213,2709,3413, 665, 621,4380,5595,3777,2939,2435,5596, # 4432 -2436,3335,3643,3414,4743,4381,2541,4382,4744,3644,1682,4383,3531,1380,5597, 724, # 4448 -2282, 600,1670,5598,1337,1233,4745,3126,2248,5599,1621,4746,5600, 651,4384,5601, # 4464 -1612,4385,2621,5602,2857,5603,2743,2312,3078,5604, 716,2464,3079, 174,1255,2710, # 4480 -4122,3645, 548,1320,1398, 728,4123,1574,5605,1891,1197,3080,4124,5606,3081,3082, # 4496 -3778,3646,3779, 747,5607, 635,4386,4747,5608,5609,5610,4387,5611,5612,4748,5613, # 4512 -3415,4749,2437, 451,5614,3780,2542,2073,4388,2744,4389,4125,5615,1764,4750,5616, # 4528 -4390, 350,4751,2283,2395,2493,5617,4391,4126,2249,1434,4127, 488,4752, 458,4392, # 4544 -4128,3781, 771,1330,2396,3914,2576,3184,2160,2414,1553,2677,3185,4393,5618,2494, # 4560 -2895,2622,1720,2711,4394,3416,4753,5619,2543,4395,5620,3262,4396,2778,5621,2016, # 4576 -2745,5622,1155,1017,3782,3915,5623,3336,2313, 201,1865,4397,1430,5624,4129,5625, # 4592 -5626,5627,5628,5629,4398,1604,5630, 414,1866, 371,2595,4754,4755,3532,2017,3127, # 4608 -4756,1708, 960,4399, 887, 389,2172,1536,1663,1721,5631,2232,4130,2356,2940,1580, # 4624 -5632,5633,1744,4757,2544,4758,4759,5634,4760,5635,2074,5636,4761,3647,3417,2896, # 4640 -4400,5637,4401,2650,3418,2815, 673,2712,2465, 709,3533,4131,3648,4402,5638,1148, # 4656 - 502, 634,5639,5640,1204,4762,3649,1575,4763,2623,3783,5641,3784,3128, 948,3263, # 4672 - 121,1745,3916,1110,5642,4403,3083,2516,3027,4132,3785,1151,1771,3917,1488,4133, # 4688 -1987,5643,2438,3534,5644,5645,2094,5646,4404,3918,1213,1407,2816, 531,2746,2545, # 4704 -3264,1011,1537,4764,2779,4405,3129,1061,5647,3786,3787,1867,2897,5648,2018, 120, # 4720 -4406,4407,2063,3650,3265,2314,3919,2678,3419,1955,4765,4134,5649,3535,1047,2713, # 4736 -1266,5650,1368,4766,2858, 649,3420,3920,2546,2747,1102,2859,2679,5651,5652,2000, # 4752 -5653,1111,3651,2977,5654,2495,3921,3652,2817,1855,3421,3788,5655,5656,3422,2415, # 4768 -2898,3337,3266,3653,5657,2577,5658,3654,2818,4135,1460, 856,5659,3655,5660,2899, # 4784 -2978,5661,2900,3922,5662,4408, 632,2517, 875,3923,1697,3924,2296,5663,5664,4767, # 4800 -3028,1239, 580,4768,4409,5665, 914, 936,2075,1190,4136,1039,2124,5666,5667,5668, # 4816 -5669,3423,1473,5670,1354,4410,3925,4769,2173,3084,4137, 915,3338,4411,4412,3339, # 4832 -1605,1835,5671,2748, 398,3656,4413,3926,4138, 328,1913,2860,4139,3927,1331,4414, # 4848 -3029, 937,4415,5672,3657,4140,4141,3424,2161,4770,3425, 524, 742, 538,3085,1012, # 4864 -5673,5674,3928,2466,5675, 658,1103, 225,3929,5676,5677,4771,5678,4772,5679,3267, # 4880 -1243,5680,4142, 963,2250,4773,5681,2714,3658,3186,5682,5683,2596,2332,5684,4774, # 4896 -5685,5686,5687,3536, 957,3426,2547,2033,1931,2941,2467, 870,2019,3659,1746,2780, # 4912 -2781,2439,2468,5688,3930,5689,3789,3130,3790,3537,3427,3791,5690,1179,3086,5691, # 4928 -3187,2378,4416,3792,2548,3188,3131,2749,4143,5692,3428,1556,2549,2297, 977,2901, # 4944 -2034,4144,1205,3429,5693,1765,3430,3189,2125,1271, 714,1689,4775,3538,5694,2333, # 4960 -3931, 533,4417,3660,2184, 617,5695,2469,3340,3539,2315,5696,5697,3190,5698,5699, # 4976 -3932,1988, 618, 427,2651,3540,3431,5700,5701,1244,1690,5702,2819,4418,4776,5703, # 4992 -3541,4777,5704,2284,1576, 473,3661,4419,3432, 972,5705,3662,5706,3087,5707,5708, # 5008 -4778,4779,5709,3793,4145,4146,5710, 153,4780, 356,5711,1892,2902,4420,2144, 408, # 5024 - 803,2357,5712,3933,5713,4421,1646,2578,2518,4781,4782,3934,5714,3935,4422,5715, # 5040 -2416,3433, 752,5716,5717,1962,3341,2979,5718, 746,3030,2470,4783,4423,3794, 698, # 5056 -4784,1893,4424,3663,2550,4785,3664,3936,5719,3191,3434,5720,1824,1302,4147,2715, # 5072 -3937,1974,4425,5721,4426,3192, 823,1303,1288,1236,2861,3542,4148,3435, 774,3938, # 5088 -5722,1581,4786,1304,2862,3939,4787,5723,2440,2162,1083,3268,4427,4149,4428, 344, # 5104 -1173, 288,2316, 454,1683,5724,5725,1461,4788,4150,2597,5726,5727,4789, 985, 894, # 5120 -5728,3436,3193,5729,1914,2942,3795,1989,5730,2111,1975,5731,4151,5732,2579,1194, # 5136 - 425,5733,4790,3194,1245,3796,4429,5734,5735,2863,5736, 636,4791,1856,3940, 760, # 5152 -1800,5737,4430,2212,1508,4792,4152,1894,1684,2298,5738,5739,4793,4431,4432,2213, # 5168 - 479,5740,5741, 832,5742,4153,2496,5743,2980,2497,3797, 990,3132, 627,1815,2652, # 5184 -4433,1582,4434,2126,2112,3543,4794,5744, 799,4435,3195,5745,4795,2113,1737,3031, # 5200 -1018, 543, 754,4436,3342,1676,4796,4797,4154,4798,1489,5746,3544,5747,2624,2903, # 5216 -4155,5748,5749,2981,5750,5751,5752,5753,3196,4799,4800,2185,1722,5754,3269,3270, # 5232 -1843,3665,1715, 481, 365,1976,1857,5755,5756,1963,2498,4801,5757,2127,3666,3271, # 5248 - 433,1895,2064,2076,5758, 602,2750,5759,5760,5761,5762,5763,3032,1628,3437,5764, # 5264 -3197,4802,4156,2904,4803,2519,5765,2551,2782,5766,5767,5768,3343,4804,2905,5769, # 5280 -4805,5770,2864,4806,4807,1221,2982,4157,2520,5771,5772,5773,1868,1990,5774,5775, # 5296 -5776,1896,5777,5778,4808,1897,4158, 318,5779,2095,4159,4437,5780,5781, 485,5782, # 5312 - 938,3941, 553,2680, 116,5783,3942,3667,5784,3545,2681,2783,3438,3344,2820,5785, # 5328 -3668,2943,4160,1747,2944,2983,5786,5787, 207,5788,4809,5789,4810,2521,5790,3033, # 5344 - 890,3669,3943,5791,1878,3798,3439,5792,2186,2358,3440,1652,5793,5794,5795, 941, # 5360 -2299, 208,3546,4161,2020, 330,4438,3944,2906,2499,3799,4439,4811,5796,5797,5798, # 5376 -) -# fmt: on diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/big5prober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/big5prober.py deleted file mode 100644 index ef09c60..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/big5prober.py +++ /dev/null @@ -1,47 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Communicator client code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 .chardistribution import Big5DistributionAnalysis -from .codingstatemachine import CodingStateMachine -from .mbcharsetprober import MultiByteCharSetProber -from .mbcssm import BIG5_SM_MODEL - - -class Big5Prober(MultiByteCharSetProber): - def __init__(self) -> None: - super().__init__() - self.coding_sm = CodingStateMachine(BIG5_SM_MODEL) - self.distribution_analyzer = Big5DistributionAnalysis() - self.reset() - - @property - def charset_name(self) -> str: - return "Big5" - - @property - def language(self) -> str: - return "Chinese" diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/chardistribution.py b/myenv/Lib/site-packages/pip/_vendor/chardet/chardistribution.py deleted file mode 100644 index 176cb99..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/chardistribution.py +++ /dev/null @@ -1,261 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Communicator client code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 Tuple, Union - -from .big5freq import ( - BIG5_CHAR_TO_FREQ_ORDER, - BIG5_TABLE_SIZE, - BIG5_TYPICAL_DISTRIBUTION_RATIO, -) -from .euckrfreq import ( - EUCKR_CHAR_TO_FREQ_ORDER, - EUCKR_TABLE_SIZE, - EUCKR_TYPICAL_DISTRIBUTION_RATIO, -) -from .euctwfreq import ( - EUCTW_CHAR_TO_FREQ_ORDER, - EUCTW_TABLE_SIZE, - EUCTW_TYPICAL_DISTRIBUTION_RATIO, -) -from .gb2312freq import ( - GB2312_CHAR_TO_FREQ_ORDER, - GB2312_TABLE_SIZE, - GB2312_TYPICAL_DISTRIBUTION_RATIO, -) -from .jisfreq import ( - JIS_CHAR_TO_FREQ_ORDER, - JIS_TABLE_SIZE, - JIS_TYPICAL_DISTRIBUTION_RATIO, -) -from .johabfreq import JOHAB_TO_EUCKR_ORDER_TABLE - - -class CharDistributionAnalysis: - ENOUGH_DATA_THRESHOLD = 1024 - SURE_YES = 0.99 - SURE_NO = 0.01 - MINIMUM_DATA_THRESHOLD = 3 - - def __init__(self) -> None: - # Mapping table to get frequency order from char order (get from - # GetOrder()) - self._char_to_freq_order: Tuple[int, ...] = tuple() - self._table_size = 0 # Size of above table - # This is a constant value which varies from language to language, - # used in calculating confidence. See - # http://www.mozilla.org/projects/intl/UniversalCharsetDetection.html - # for further detail. - self.typical_distribution_ratio = 0.0 - self._done = False - self._total_chars = 0 - self._freq_chars = 0 - self.reset() - - def reset(self) -> None: - """reset analyser, clear any state""" - # If this flag is set to True, detection is done and conclusion has - # been made - self._done = False - self._total_chars = 0 # Total characters encountered - # The number of characters whose frequency order is less than 512 - self._freq_chars = 0 - - def feed(self, char: Union[bytes, bytearray], char_len: int) -> None: - """feed a character with known length""" - if char_len == 2: - # we only care about 2-bytes character in our distribution analysis - order = self.get_order(char) - else: - order = -1 - if order >= 0: - self._total_chars += 1 - # order is valid - if order < self._table_size: - if 512 > self._char_to_freq_order[order]: - self._freq_chars += 1 - - def get_confidence(self) -> float: - """return confidence based on existing data""" - # if we didn't receive any character in our consideration range, - # return negative answer - if self._total_chars <= 0 or self._freq_chars <= self.MINIMUM_DATA_THRESHOLD: - return self.SURE_NO - - if self._total_chars != self._freq_chars: - r = self._freq_chars / ( - (self._total_chars - self._freq_chars) * self.typical_distribution_ratio - ) - if r < self.SURE_YES: - return r - - # normalize confidence (we don't want to be 100% sure) - return self.SURE_YES - - def got_enough_data(self) -> bool: - # It is not necessary to receive all data to draw conclusion. - # For charset detection, certain amount of data is enough - return self._total_chars > self.ENOUGH_DATA_THRESHOLD - - def get_order(self, _: Union[bytes, bytearray]) -> int: - # We do not handle characters based on the original encoding string, - # but convert this encoding string to a number, here called order. - # This allows multiple encodings of a language to share one frequency - # table. - return -1 - - -class EUCTWDistributionAnalysis(CharDistributionAnalysis): - def __init__(self) -> None: - super().__init__() - self._char_to_freq_order = EUCTW_CHAR_TO_FREQ_ORDER - self._table_size = EUCTW_TABLE_SIZE - self.typical_distribution_ratio = EUCTW_TYPICAL_DISTRIBUTION_RATIO - - def get_order(self, byte_str: Union[bytes, bytearray]) -> int: - # for euc-TW encoding, we are interested - # first byte range: 0xc4 -- 0xfe - # second byte range: 0xa1 -- 0xfe - # no validation needed here. State machine has done that - first_char = byte_str[0] - if first_char >= 0xC4: - return 94 * (first_char - 0xC4) + byte_str[1] - 0xA1 - return -1 - - -class EUCKRDistributionAnalysis(CharDistributionAnalysis): - def __init__(self) -> None: - super().__init__() - self._char_to_freq_order = EUCKR_CHAR_TO_FREQ_ORDER - self._table_size = EUCKR_TABLE_SIZE - self.typical_distribution_ratio = EUCKR_TYPICAL_DISTRIBUTION_RATIO - - def get_order(self, byte_str: Union[bytes, bytearray]) -> int: - # for euc-KR encoding, we are interested - # first byte range: 0xb0 -- 0xfe - # second byte range: 0xa1 -- 0xfe - # no validation needed here. State machine has done that - first_char = byte_str[0] - if first_char >= 0xB0: - return 94 * (first_char - 0xB0) + byte_str[1] - 0xA1 - return -1 - - -class JOHABDistributionAnalysis(CharDistributionAnalysis): - def __init__(self) -> None: - super().__init__() - self._char_to_freq_order = EUCKR_CHAR_TO_FREQ_ORDER - self._table_size = EUCKR_TABLE_SIZE - self.typical_distribution_ratio = EUCKR_TYPICAL_DISTRIBUTION_RATIO - - def get_order(self, byte_str: Union[bytes, bytearray]) -> int: - first_char = byte_str[0] - if 0x88 <= first_char < 0xD4: - code = first_char * 256 + byte_str[1] - return JOHAB_TO_EUCKR_ORDER_TABLE.get(code, -1) - return -1 - - -class GB2312DistributionAnalysis(CharDistributionAnalysis): - def __init__(self) -> None: - super().__init__() - self._char_to_freq_order = GB2312_CHAR_TO_FREQ_ORDER - self._table_size = GB2312_TABLE_SIZE - self.typical_distribution_ratio = GB2312_TYPICAL_DISTRIBUTION_RATIO - - def get_order(self, byte_str: Union[bytes, bytearray]) -> int: - # for GB2312 encoding, we are interested - # first byte range: 0xb0 -- 0xfe - # second byte range: 0xa1 -- 0xfe - # no validation needed here. State machine has done that - first_char, second_char = byte_str[0], byte_str[1] - if (first_char >= 0xB0) and (second_char >= 0xA1): - return 94 * (first_char - 0xB0) + second_char - 0xA1 - return -1 - - -class Big5DistributionAnalysis(CharDistributionAnalysis): - def __init__(self) -> None: - super().__init__() - self._char_to_freq_order = BIG5_CHAR_TO_FREQ_ORDER - self._table_size = BIG5_TABLE_SIZE - self.typical_distribution_ratio = BIG5_TYPICAL_DISTRIBUTION_RATIO - - def get_order(self, byte_str: Union[bytes, bytearray]) -> int: - # for big5 encoding, we are interested - # first byte range: 0xa4 -- 0xfe - # second byte range: 0x40 -- 0x7e , 0xa1 -- 0xfe - # no validation needed here. State machine has done that - first_char, second_char = byte_str[0], byte_str[1] - if first_char >= 0xA4: - if second_char >= 0xA1: - return 157 * (first_char - 0xA4) + second_char - 0xA1 + 63 - return 157 * (first_char - 0xA4) + second_char - 0x40 - return -1 - - -class SJISDistributionAnalysis(CharDistributionAnalysis): - def __init__(self) -> None: - super().__init__() - self._char_to_freq_order = JIS_CHAR_TO_FREQ_ORDER - self._table_size = JIS_TABLE_SIZE - self.typical_distribution_ratio = JIS_TYPICAL_DISTRIBUTION_RATIO - - def get_order(self, byte_str: Union[bytes, bytearray]) -> int: - # for sjis encoding, we are interested - # first byte range: 0x81 -- 0x9f , 0xe0 -- 0xfe - # second byte range: 0x40 -- 0x7e, 0x81 -- oxfe - # no validation needed here. State machine has done that - first_char, second_char = byte_str[0], byte_str[1] - if 0x81 <= first_char <= 0x9F: - order = 188 * (first_char - 0x81) - elif 0xE0 <= first_char <= 0xEF: - order = 188 * (first_char - 0xE0 + 31) - else: - return -1 - order = order + second_char - 0x40 - if second_char > 0x7F: - order = -1 - return order - - -class EUCJPDistributionAnalysis(CharDistributionAnalysis): - def __init__(self) -> None: - super().__init__() - self._char_to_freq_order = JIS_CHAR_TO_FREQ_ORDER - self._table_size = JIS_TABLE_SIZE - self.typical_distribution_ratio = JIS_TYPICAL_DISTRIBUTION_RATIO - - def get_order(self, byte_str: Union[bytes, bytearray]) -> int: - # for euc-JP encoding, we are interested - # first byte range: 0xa0 -- 0xfe - # second byte range: 0xa1 -- 0xfe - # no validation needed here. State machine has done that - char = byte_str[0] - if char >= 0xA0: - return 94 * (char - 0xA1) + byte_str[1] - 0xA1 - return -1 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py deleted file mode 100644 index 6def56b..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py +++ /dev/null @@ -1,106 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Communicator client code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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, Optional, Union - -from .charsetprober import CharSetProber -from .enums import LanguageFilter, ProbingState - - -class CharSetGroupProber(CharSetProber): - def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None: - super().__init__(lang_filter=lang_filter) - self._active_num = 0 - self.probers: List[CharSetProber] = [] - self._best_guess_prober: Optional[CharSetProber] = None - - def reset(self) -> None: - super().reset() - self._active_num = 0 - for prober in self.probers: - prober.reset() - prober.active = True - self._active_num += 1 - self._best_guess_prober = None - - @property - def charset_name(self) -> Optional[str]: - if not self._best_guess_prober: - self.get_confidence() - if not self._best_guess_prober: - return None - return self._best_guess_prober.charset_name - - @property - def language(self) -> Optional[str]: - if not self._best_guess_prober: - self.get_confidence() - if not self._best_guess_prober: - return None - return self._best_guess_prober.language - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - for prober in self.probers: - if not prober.active: - continue - state = prober.feed(byte_str) - if not state: - continue - if state == ProbingState.FOUND_IT: - self._best_guess_prober = prober - self._state = ProbingState.FOUND_IT - return self.state - if state == ProbingState.NOT_ME: - prober.active = False - self._active_num -= 1 - if self._active_num <= 0: - self._state = ProbingState.NOT_ME - return self.state - return self.state - - def get_confidence(self) -> float: - state = self.state - if state == ProbingState.FOUND_IT: - return 0.99 - if state == ProbingState.NOT_ME: - return 0.01 - best_conf = 0.0 - self._best_guess_prober = None - for prober in self.probers: - if not prober.active: - self.logger.debug("%s not active", prober.charset_name) - continue - conf = prober.get_confidence() - self.logger.debug( - "%s %s confidence = %s", prober.charset_name, prober.language, conf - ) - if best_conf < conf: - best_conf = conf - self._best_guess_prober = prober - if not self._best_guess_prober: - return 0.0 - return best_conf diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/charsetprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/charsetprober.py deleted file mode 100644 index a103ca1..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/charsetprober.py +++ /dev/null @@ -1,147 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Universal charset detector code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 2001 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# Shy Shalom - original C code -# -# This library is free software; you can redistribute it and/or -# modify it under the terms of the GNU Lesser General Public -# License as published by the Free Software Foundation; either -# version 2.1 of the License, or (at your option) any later version. -# -# This library is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -# Lesser General Public License for more details. -# -# You should have received a copy of the GNU Lesser General Public -# License along with this library; if not, write to the Free Software -# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA -# 02110-1301 USA -######################### END LICENSE BLOCK ######################### - -import logging -import re -from typing import Optional, Union - -from .enums import LanguageFilter, ProbingState - -INTERNATIONAL_WORDS_PATTERN = re.compile( - b"[a-zA-Z]*[\x80-\xFF]+[a-zA-Z]*[^a-zA-Z\x80-\xFF]?" -) - - -class CharSetProber: - - SHORTCUT_THRESHOLD = 0.95 - - def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None: - self._state = ProbingState.DETECTING - self.active = True - self.lang_filter = lang_filter - self.logger = logging.getLogger(__name__) - - def reset(self) -> None: - self._state = ProbingState.DETECTING - - @property - def charset_name(self) -> Optional[str]: - return None - - @property - def language(self) -> Optional[str]: - raise NotImplementedError - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - raise NotImplementedError - - @property - def state(self) -> ProbingState: - return self._state - - def get_confidence(self) -> float: - return 0.0 - - @staticmethod - def filter_high_byte_only(buf: Union[bytes, bytearray]) -> bytes: - buf = re.sub(b"([\x00-\x7F])+", b" ", buf) - return buf - - @staticmethod - def filter_international_words(buf: Union[bytes, bytearray]) -> bytearray: - """ - We define three types of bytes: - alphabet: english alphabets [a-zA-Z] - international: international characters [\x80-\xFF] - marker: everything else [^a-zA-Z\x80-\xFF] - The input buffer can be thought to contain a series of words delimited - by markers. This function works to filter all words that contain at - least one international character. All contiguous sequences of markers - are replaced by a single space ascii character. - This filter applies to all scripts which do not use English characters. - """ - filtered = bytearray() - - # This regex expression filters out only words that have at-least one - # international character. The word may include one marker character at - # the end. - words = INTERNATIONAL_WORDS_PATTERN.findall(buf) - - for word in words: - filtered.extend(word[:-1]) - - # If the last character in the word is a marker, replace it with a - # space as markers shouldn't affect our analysis (they are used - # similarly across all languages and may thus have similar - # frequencies). - last_char = word[-1:] - if not last_char.isalpha() and last_char < b"\x80": - last_char = b" " - filtered.extend(last_char) - - return filtered - - @staticmethod - def remove_xml_tags(buf: Union[bytes, bytearray]) -> bytes: - """ - Returns a copy of ``buf`` that retains only the sequences of English - alphabet and high byte characters that are not between <> characters. - This filter can be applied to all scripts which contain both English - characters and extended ASCII characters, but is currently only used by - ``Latin1Prober``. - """ - filtered = bytearray() - in_tag = False - prev = 0 - buf = memoryview(buf).cast("c") - - for curr, buf_char in enumerate(buf): - # Check if we're coming out of or entering an XML tag - - # https://github.com/python/typeshed/issues/8182 - if buf_char == b">": # type: ignore[comparison-overlap] - prev = curr + 1 - in_tag = False - # https://github.com/python/typeshed/issues/8182 - elif buf_char == b"<": # type: ignore[comparison-overlap] - if curr > prev and not in_tag: - # Keep everything after last non-extended-ASCII, - # non-alphabetic character - filtered.extend(buf[prev:curr]) - # Output a space to delimit stretch we kept - filtered.extend(b" ") - in_tag = True - - # If we're not in a tag... - if not in_tag: - # Keep everything after last non-extended-ASCII, non-alphabetic - # character - filtered.extend(buf[prev:]) - - return filtered diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py b/myenv/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-311.pyc deleted file mode 100644 index 310773771ba228981672af33b8db96e3b6278ebc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 216 zcmZ3^%ge<81kQ*0(m?cM5CH>>P{wCAAY(d13PUi1CZpdW8QVtyd;ftit!@dE>lC}IYR0RUw&I^6&O diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-311.pyc deleted file mode 100644 index 093491443ab1ac0656e458db160320c04d46a00b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4355 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 F{SW@zbXEWW diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py b/myenv/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py deleted file mode 100644 index 43f6e14..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py +++ /dev/null @@ -1,112 +0,0 @@ -""" -Script which takes one or more file paths and reports on their detected -encodings - -Example:: - - % chardetect somefile someotherfile - somefile: windows-1252 with confidence 0.5 - someotherfile: ascii with confidence 1.0 - -If no paths are provided, it takes its input from stdin. - -""" - - -import argparse -import sys -from typing import Iterable, List, Optional - -from .. import __version__ -from ..universaldetector import UniversalDetector - - -def description_of( - lines: Iterable[bytes], - name: str = "stdin", - minimal: bool = False, - should_rename_legacy: bool = False, -) -> Optional[str]: - """ - Return a string describing the probable encoding of a file or - list of strings. - - :param lines: The lines to get the encoding of. - :type lines: Iterable of bytes - :param name: Name of file or collection of lines - :type name: str - :param should_rename_legacy: Should we rename legacy encodings to - their more modern equivalents? - :type should_rename_legacy: ``bool`` - """ - u = UniversalDetector(should_rename_legacy=should_rename_legacy) - for line in lines: - line = bytearray(line) - u.feed(line) - # shortcut out of the loop to save reading further - particularly useful if we read a BOM. - if u.done: - break - u.close() - result = u.result - if minimal: - return result["encoding"] - if result["encoding"]: - return f'{name}: {result["encoding"]} with confidence {result["confidence"]}' - return f"{name}: no result" - - -def main(argv: Optional[List[str]] = None) -> None: - """ - Handles command line arguments and gets things started. - - :param argv: List of arguments, as if specified on the command-line. - If None, ``sys.argv[1:]`` is used instead. - :type argv: list of str - """ - # Get command line arguments - parser = argparse.ArgumentParser( - description=( - "Takes one or more file paths and reports their detected encodings" - ) - ) - parser.add_argument( - "input", - help="File whose encoding we would like to determine. (default: stdin)", - type=argparse.FileType("rb"), - nargs="*", - default=[sys.stdin.buffer], - ) - parser.add_argument( - "--minimal", - help="Print only the encoding to standard output", - action="store_true", - ) - parser.add_argument( - "-l", - "--legacy", - help="Rename legacy encodings to more modern ones.", - action="store_true", - ) - parser.add_argument( - "--version", action="version", version=f"%(prog)s {__version__}" - ) - args = parser.parse_args(argv) - - for f in args.input: - if f.isatty(): - print( - "You are running chardetect interactively. Press " - "CTRL-D twice at the start of a blank line to signal the " - "end of your input. If you want help, run chardetect " - "--help\n", - file=sys.stderr, - ) - print( - description_of( - f, f.name, minimal=args.minimal, should_rename_legacy=args.legacy - ) - ) - - -if __name__ == "__main__": - main() diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py b/myenv/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py deleted file mode 100644 index 8ed4a87..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py +++ /dev/null @@ -1,90 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# This library is free software; you can redistribute it and/or -# modify it under the terms of the GNU Lesser General Public -# License as published by the Free Software Foundation; either -# version 2.1 of the License, or (at your option) any later version. -# -# This library is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -# Lesser General Public License for more details. -# -# You should have received a copy of the GNU Lesser General Public -# License along with this library; if not, write to the Free Software -# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA -# 02110-1301 USA -######################### END LICENSE BLOCK ######################### - -import logging - -from .codingstatemachinedict import CodingStateMachineDict -from .enums import MachineState - - -class CodingStateMachine: - """ - A state machine to verify a byte sequence for a particular encoding. For - each byte the detector receives, it will feed that byte to every active - state machine available, one byte at a time. The state machine changes its - state based on its previous state and the byte it receives. There are 3 - states in a state machine that are of interest to an auto-detector: - - START state: This is the state to start with, or a legal byte sequence - (i.e. a valid code point) for character has been identified. - - ME state: This indicates that the state machine identified a byte sequence - that is specific to the charset it is designed for and that - there is no other possible encoding which can contain this byte - sequence. This will to lead to an immediate positive answer for - the detector. - - ERROR state: This indicates the state machine identified an illegal byte - sequence for that encoding. This will lead to an immediate - negative answer for this encoding. Detector will exclude this - encoding from consideration from here on. - """ - - def __init__(self, sm: CodingStateMachineDict) -> None: - self._model = sm - self._curr_byte_pos = 0 - self._curr_char_len = 0 - self._curr_state = MachineState.START - self.active = True - self.logger = logging.getLogger(__name__) - self.reset() - - def reset(self) -> None: - self._curr_state = MachineState.START - - def next_state(self, c: int) -> int: - # for each byte we get its class - # if it is first byte, we also get byte length - byte_class = self._model["class_table"][c] - if self._curr_state == MachineState.START: - self._curr_byte_pos = 0 - self._curr_char_len = self._model["char_len_table"][byte_class] - # from byte's class and state_table, we get its next state - curr_state = self._curr_state * self._model["class_factor"] + byte_class - self._curr_state = self._model["state_table"][curr_state] - self._curr_byte_pos += 1 - return self._curr_state - - def get_current_charlen(self) -> int: - return self._curr_char_len - - def get_coding_state_machine(self) -> str: - return self._model["name"] - - @property - def language(self) -> str: - return self._model["language"] diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/codingstatemachinedict.py b/myenv/Lib/site-packages/pip/_vendor/chardet/codingstatemachinedict.py deleted file mode 100644 index 7a3c4c7..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/codingstatemachinedict.py +++ /dev/null @@ -1,19 +0,0 @@ -from typing import TYPE_CHECKING, Tuple - -if TYPE_CHECKING: - # TypedDict was introduced in Python 3.8. - # - # TODO: Remove the else block and TYPE_CHECKING check when dropping support - # for Python 3.7. - from typing import TypedDict - - class CodingStateMachineDict(TypedDict, total=False): - class_table: Tuple[int, ...] - class_factor: int - state_table: Tuple[int, ...] - char_len_table: Tuple[int, ...] - name: str - language: str # Optional key - -else: - CodingStateMachineDict = dict diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/cp949prober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/cp949prober.py deleted file mode 100644 index fa7307e..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/cp949prober.py +++ /dev/null @@ -1,49 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 .chardistribution import EUCKRDistributionAnalysis -from .codingstatemachine import CodingStateMachine -from .mbcharsetprober import MultiByteCharSetProber -from .mbcssm import CP949_SM_MODEL - - -class CP949Prober(MultiByteCharSetProber): - def __init__(self) -> None: - super().__init__() - self.coding_sm = CodingStateMachine(CP949_SM_MODEL) - # NOTE: CP949 is a superset of EUC-KR, so the distribution should be - # not different. - self.distribution_analyzer = EUCKRDistributionAnalysis() - self.reset() - - @property - def charset_name(self) -> str: - return "CP949" - - @property - def language(self) -> str: - return "Korean" diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/enums.py b/myenv/Lib/site-packages/pip/_vendor/chardet/enums.py deleted file mode 100644 index 5e3e198..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/enums.py +++ /dev/null @@ -1,85 +0,0 @@ -""" -All of the Enums that are used throughout the chardet package. - -:author: Dan Blanchard (dan.blanchard@gmail.com) -""" - -from enum import Enum, Flag - - -class InputState: - """ - This enum represents the different states a universal detector can be in. - """ - - PURE_ASCII = 0 - ESC_ASCII = 1 - HIGH_BYTE = 2 - - -class LanguageFilter(Flag): - """ - This enum represents the different language filters we can apply to a - ``UniversalDetector``. - """ - - NONE = 0x00 - CHINESE_SIMPLIFIED = 0x01 - CHINESE_TRADITIONAL = 0x02 - JAPANESE = 0x04 - KOREAN = 0x08 - NON_CJK = 0x10 - ALL = 0x1F - CHINESE = CHINESE_SIMPLIFIED | CHINESE_TRADITIONAL - CJK = CHINESE | JAPANESE | KOREAN - - -class ProbingState(Enum): - """ - This enum represents the different states a prober can be in. - """ - - DETECTING = 0 - FOUND_IT = 1 - NOT_ME = 2 - - -class MachineState: - """ - This enum represents the different states a state machine can be in. - """ - - START = 0 - ERROR = 1 - ITS_ME = 2 - - -class SequenceLikelihood: - """ - This enum represents the likelihood of a character following the previous one. - """ - - NEGATIVE = 0 - UNLIKELY = 1 - LIKELY = 2 - POSITIVE = 3 - - @classmethod - def get_num_categories(cls) -> int: - """:returns: The number of likelihood categories in the enum.""" - return 4 - - -class CharacterCategory: - """ - This enum represents the different categories language models for - ``SingleByteCharsetProber`` put characters into. - - Anything less than CONTROL is considered a letter. - """ - - UNDEFINED = 255 - LINE_BREAK = 254 - SYMBOL = 253 - DIGIT = 252 - CONTROL = 251 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/escprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/escprober.py deleted file mode 100644 index fd71383..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/escprober.py +++ /dev/null @@ -1,102 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 Optional, Union - -from .charsetprober import CharSetProber -from .codingstatemachine import CodingStateMachine -from .enums import LanguageFilter, MachineState, ProbingState -from .escsm import ( - HZ_SM_MODEL, - ISO2022CN_SM_MODEL, - ISO2022JP_SM_MODEL, - ISO2022KR_SM_MODEL, -) - - -class EscCharSetProber(CharSetProber): - """ - This CharSetProber uses a "code scheme" approach for detecting encodings, - whereby easily recognizable escape or shift sequences are relied on to - identify these encodings. - """ - - def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None: - super().__init__(lang_filter=lang_filter) - self.coding_sm = [] - if self.lang_filter & LanguageFilter.CHINESE_SIMPLIFIED: - self.coding_sm.append(CodingStateMachine(HZ_SM_MODEL)) - self.coding_sm.append(CodingStateMachine(ISO2022CN_SM_MODEL)) - if self.lang_filter & LanguageFilter.JAPANESE: - self.coding_sm.append(CodingStateMachine(ISO2022JP_SM_MODEL)) - if self.lang_filter & LanguageFilter.KOREAN: - self.coding_sm.append(CodingStateMachine(ISO2022KR_SM_MODEL)) - self.active_sm_count = 0 - self._detected_charset: Optional[str] = None - self._detected_language: Optional[str] = None - self._state = ProbingState.DETECTING - self.reset() - - def reset(self) -> None: - super().reset() - for coding_sm in self.coding_sm: - coding_sm.active = True - coding_sm.reset() - self.active_sm_count = len(self.coding_sm) - self._detected_charset = None - self._detected_language = None - - @property - def charset_name(self) -> Optional[str]: - return self._detected_charset - - @property - def language(self) -> Optional[str]: - return self._detected_language - - def get_confidence(self) -> float: - return 0.99 if self._detected_charset else 0.00 - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - for c in byte_str: - for coding_sm in self.coding_sm: - if not coding_sm.active: - continue - coding_state = coding_sm.next_state(c) - if coding_state == MachineState.ERROR: - coding_sm.active = False - self.active_sm_count -= 1 - if self.active_sm_count <= 0: - self._state = ProbingState.NOT_ME - return self.state - elif coding_state == MachineState.ITS_ME: - self._state = ProbingState.FOUND_IT - self._detected_charset = coding_sm.get_coding_state_machine() - self._detected_language = coding_sm.language - return self.state - - return self.state diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/escsm.py b/myenv/Lib/site-packages/pip/_vendor/chardet/escsm.py deleted file mode 100644 index 11d4adf..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/escsm.py +++ /dev/null @@ -1,261 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 .codingstatemachinedict import CodingStateMachineDict -from .enums import MachineState - -# fmt: off -HZ_CLS = ( - 1, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 - 0, 0, 0, 0, 0, 0, 0, 0, # 08 - 0f - 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 - 0, 0, 0, 1, 0, 0, 0, 0, # 18 - 1f - 0, 0, 0, 0, 0, 0, 0, 0, # 20 - 27 - 0, 0, 0, 0, 0, 0, 0, 0, # 28 - 2f - 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 - 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f - 0, 0, 0, 0, 0, 0, 0, 0, # 40 - 47 - 0, 0, 0, 0, 0, 0, 0, 0, # 48 - 4f - 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 - 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f - 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 - 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f - 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 - 0, 0, 0, 4, 0, 5, 2, 0, # 78 - 7f - 1, 1, 1, 1, 1, 1, 1, 1, # 80 - 87 - 1, 1, 1, 1, 1, 1, 1, 1, # 88 - 8f - 1, 1, 1, 1, 1, 1, 1, 1, # 90 - 97 - 1, 1, 1, 1, 1, 1, 1, 1, # 98 - 9f - 1, 1, 1, 1, 1, 1, 1, 1, # a0 - a7 - 1, 1, 1, 1, 1, 1, 1, 1, # a8 - af - 1, 1, 1, 1, 1, 1, 1, 1, # b0 - b7 - 1, 1, 1, 1, 1, 1, 1, 1, # b8 - bf - 1, 1, 1, 1, 1, 1, 1, 1, # c0 - c7 - 1, 1, 1, 1, 1, 1, 1, 1, # c8 - cf - 1, 1, 1, 1, 1, 1, 1, 1, # d0 - d7 - 1, 1, 1, 1, 1, 1, 1, 1, # d8 - df - 1, 1, 1, 1, 1, 1, 1, 1, # e0 - e7 - 1, 1, 1, 1, 1, 1, 1, 1, # e8 - ef - 1, 1, 1, 1, 1, 1, 1, 1, # f0 - f7 - 1, 1, 1, 1, 1, 1, 1, 1, # f8 - ff -) - -HZ_ST = ( -MachineState.START, MachineState.ERROR, 3, MachineState.START, MachineState.START, MachineState.START, MachineState.ERROR, MachineState.ERROR, # 00-07 -MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 08-0f -MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.START, MachineState.START, 4, MachineState.ERROR, # 10-17 - 5, MachineState.ERROR, 6, MachineState.ERROR, 5, 5, 4, MachineState.ERROR, # 18-1f - 4, MachineState.ERROR, 4, 4, 4, MachineState.ERROR, 4, MachineState.ERROR, # 20-27 - 4, MachineState.ITS_ME, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 28-2f -) -# fmt: on - -HZ_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0) - -HZ_SM_MODEL: CodingStateMachineDict = { - "class_table": HZ_CLS, - "class_factor": 6, - "state_table": HZ_ST, - "char_len_table": HZ_CHAR_LEN_TABLE, - "name": "HZ-GB-2312", - "language": "Chinese", -} - -# fmt: off -ISO2022CN_CLS = ( - 2, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 - 0, 0, 0, 0, 0, 0, 0, 0, # 08 - 0f - 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 - 0, 0, 0, 1, 0, 0, 0, 0, # 18 - 1f - 0, 0, 0, 0, 0, 0, 0, 0, # 20 - 27 - 0, 3, 0, 0, 0, 0, 0, 0, # 28 - 2f - 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 - 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f - 0, 0, 0, 4, 0, 0, 0, 0, # 40 - 47 - 0, 0, 0, 0, 0, 0, 0, 0, # 48 - 4f - 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 - 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f - 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 - 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f - 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 - 0, 0, 0, 0, 0, 0, 0, 0, # 78 - 7f - 2, 2, 2, 2, 2, 2, 2, 2, # 80 - 87 - 2, 2, 2, 2, 2, 2, 2, 2, # 88 - 8f - 2, 2, 2, 2, 2, 2, 2, 2, # 90 - 97 - 2, 2, 2, 2, 2, 2, 2, 2, # 98 - 9f - 2, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 - 2, 2, 2, 2, 2, 2, 2, 2, # a8 - af - 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 - 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf - 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 - 2, 2, 2, 2, 2, 2, 2, 2, # c8 - cf - 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 - 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df - 2, 2, 2, 2, 2, 2, 2, 2, # e0 - e7 - 2, 2, 2, 2, 2, 2, 2, 2, # e8 - ef - 2, 2, 2, 2, 2, 2, 2, 2, # f0 - f7 - 2, 2, 2, 2, 2, 2, 2, 2, # f8 - ff -) - -ISO2022CN_ST = ( - MachineState.START, 3, MachineState.ERROR, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 00-07 - MachineState.START, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 08-0f - MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 10-17 - MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, 4, MachineState.ERROR, # 18-1f - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 20-27 - 5, 6, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 28-2f - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 30-37 - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.START, # 38-3f -) -# fmt: on - -ISO2022CN_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0, 0, 0, 0) - -ISO2022CN_SM_MODEL: CodingStateMachineDict = { - "class_table": ISO2022CN_CLS, - "class_factor": 9, - "state_table": ISO2022CN_ST, - "char_len_table": ISO2022CN_CHAR_LEN_TABLE, - "name": "ISO-2022-CN", - "language": "Chinese", -} - -# fmt: off -ISO2022JP_CLS = ( - 2, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 - 0, 0, 0, 0, 0, 0, 2, 2, # 08 - 0f - 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 - 0, 0, 0, 1, 0, 0, 0, 0, # 18 - 1f - 0, 0, 0, 0, 7, 0, 0, 0, # 20 - 27 - 3, 0, 0, 0, 0, 0, 0, 0, # 28 - 2f - 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 - 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f - 6, 0, 4, 0, 8, 0, 0, 0, # 40 - 47 - 0, 9, 5, 0, 0, 0, 0, 0, # 48 - 4f - 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 - 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f - 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 - 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f - 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 - 0, 0, 0, 0, 0, 0, 0, 0, # 78 - 7f - 2, 2, 2, 2, 2, 2, 2, 2, # 80 - 87 - 2, 2, 2, 2, 2, 2, 2, 2, # 88 - 8f - 2, 2, 2, 2, 2, 2, 2, 2, # 90 - 97 - 2, 2, 2, 2, 2, 2, 2, 2, # 98 - 9f - 2, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 - 2, 2, 2, 2, 2, 2, 2, 2, # a8 - af - 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 - 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf - 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 - 2, 2, 2, 2, 2, 2, 2, 2, # c8 - cf - 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 - 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df - 2, 2, 2, 2, 2, 2, 2, 2, # e0 - e7 - 2, 2, 2, 2, 2, 2, 2, 2, # e8 - ef - 2, 2, 2, 2, 2, 2, 2, 2, # f0 - f7 - 2, 2, 2, 2, 2, 2, 2, 2, # f8 - ff -) - -ISO2022JP_ST = ( - MachineState.START, 3, MachineState.ERROR, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 00-07 - MachineState.START, MachineState.START, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 08-0f - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 10-17 - MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, # 18-1f - MachineState.ERROR, 5, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, 4, MachineState.ERROR, MachineState.ERROR, # 20-27 - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, 6, MachineState.ITS_ME, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, # 28-2f - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, # 30-37 - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 38-3f - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.START, MachineState.START, # 40-47 -) -# fmt: on - -ISO2022JP_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0, 0, 0, 0, 0) - -ISO2022JP_SM_MODEL: CodingStateMachineDict = { - "class_table": ISO2022JP_CLS, - "class_factor": 10, - "state_table": ISO2022JP_ST, - "char_len_table": ISO2022JP_CHAR_LEN_TABLE, - "name": "ISO-2022-JP", - "language": "Japanese", -} - -# fmt: off -ISO2022KR_CLS = ( - 2, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 - 0, 0, 0, 0, 0, 0, 0, 0, # 08 - 0f - 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 - 0, 0, 0, 1, 0, 0, 0, 0, # 18 - 1f - 0, 0, 0, 0, 3, 0, 0, 0, # 20 - 27 - 0, 4, 0, 0, 0, 0, 0, 0, # 28 - 2f - 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 - 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f - 0, 0, 0, 5, 0, 0, 0, 0, # 40 - 47 - 0, 0, 0, 0, 0, 0, 0, 0, # 48 - 4f - 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 - 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f - 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 - 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f - 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 - 0, 0, 0, 0, 0, 0, 0, 0, # 78 - 7f - 2, 2, 2, 2, 2, 2, 2, 2, # 80 - 87 - 2, 2, 2, 2, 2, 2, 2, 2, # 88 - 8f - 2, 2, 2, 2, 2, 2, 2, 2, # 90 - 97 - 2, 2, 2, 2, 2, 2, 2, 2, # 98 - 9f - 2, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 - 2, 2, 2, 2, 2, 2, 2, 2, # a8 - af - 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 - 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf - 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 - 2, 2, 2, 2, 2, 2, 2, 2, # c8 - cf - 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 - 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df - 2, 2, 2, 2, 2, 2, 2, 2, # e0 - e7 - 2, 2, 2, 2, 2, 2, 2, 2, # e8 - ef - 2, 2, 2, 2, 2, 2, 2, 2, # f0 - f7 - 2, 2, 2, 2, 2, 2, 2, 2, # f8 - ff -) - -ISO2022KR_ST = ( - MachineState.START, 3, MachineState.ERROR, MachineState.START, MachineState.START, MachineState.START, MachineState.ERROR, MachineState.ERROR, # 00-07 - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 08-0f - MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, 4, MachineState.ERROR, MachineState.ERROR, # 10-17 - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, 5, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 18-1f - MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 20-27 -) -# fmt: on - -ISO2022KR_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0) - -ISO2022KR_SM_MODEL: CodingStateMachineDict = { - "class_table": ISO2022KR_CLS, - "class_factor": 6, - "state_table": ISO2022KR_ST, - "char_len_table": ISO2022KR_CHAR_LEN_TABLE, - "name": "ISO-2022-KR", - "language": "Korean", -} diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py deleted file mode 100644 index 39487f4..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py +++ /dev/null @@ -1,102 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 Union - -from .chardistribution import EUCJPDistributionAnalysis -from .codingstatemachine import CodingStateMachine -from .enums import MachineState, ProbingState -from .jpcntx import EUCJPContextAnalysis -from .mbcharsetprober import MultiByteCharSetProber -from .mbcssm import EUCJP_SM_MODEL - - -class EUCJPProber(MultiByteCharSetProber): - def __init__(self) -> None: - super().__init__() - self.coding_sm = CodingStateMachine(EUCJP_SM_MODEL) - self.distribution_analyzer = EUCJPDistributionAnalysis() - self.context_analyzer = EUCJPContextAnalysis() - self.reset() - - def reset(self) -> None: - super().reset() - self.context_analyzer.reset() - - @property - def charset_name(self) -> str: - return "EUC-JP" - - @property - def language(self) -> str: - return "Japanese" - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - assert self.coding_sm is not None - assert self.distribution_analyzer is not None - - for i, byte in enumerate(byte_str): - # PY3K: byte_str is a byte array, so byte is an int, not a byte - coding_state = self.coding_sm.next_state(byte) - if coding_state == MachineState.ERROR: - self.logger.debug( - "%s %s prober hit error at byte %s", - self.charset_name, - self.language, - i, - ) - self._state = ProbingState.NOT_ME - break - if coding_state == MachineState.ITS_ME: - self._state = ProbingState.FOUND_IT - break - if coding_state == MachineState.START: - char_len = self.coding_sm.get_current_charlen() - if i == 0: - self._last_char[1] = byte - self.context_analyzer.feed(self._last_char, char_len) - self.distribution_analyzer.feed(self._last_char, char_len) - else: - self.context_analyzer.feed(byte_str[i - 1 : i + 1], char_len) - self.distribution_analyzer.feed(byte_str[i - 1 : i + 1], char_len) - - self._last_char[0] = byte_str[-1] - - if self.state == ProbingState.DETECTING: - if self.context_analyzer.got_enough_data() and ( - self.get_confidence() > self.SHORTCUT_THRESHOLD - ): - self._state = ProbingState.FOUND_IT - - return self.state - - def get_confidence(self) -> float: - assert self.distribution_analyzer is not None - - context_conf = self.context_analyzer.get_confidence() - distrib_conf = self.distribution_analyzer.get_confidence() - return max(context_conf, distrib_conf) diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py b/myenv/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py deleted file mode 100644 index 7dc3b10..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py +++ /dev/null @@ -1,196 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Communicator client code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 ######################### - -# Sampling from about 20M text materials include literature and computer technology - -# 128 --> 0.79 -# 256 --> 0.92 -# 512 --> 0.986 -# 1024 --> 0.99944 -# 2048 --> 0.99999 -# -# Idea Distribution Ratio = 0.98653 / (1-0.98653) = 73.24 -# Random Distribution Ration = 512 / (2350-512) = 0.279. -# -# Typical Distribution Ratio - -EUCKR_TYPICAL_DISTRIBUTION_RATIO = 6.0 - -EUCKR_TABLE_SIZE = 2352 - -# Char to FreqOrder table , -# fmt: off -EUCKR_CHAR_TO_FREQ_ORDER = ( - 13, 130, 120,1396, 481,1719,1720, 328, 609, 212,1721, 707, 400, 299,1722, 87, -1397,1723, 104, 536,1117,1203,1724,1267, 685,1268, 508,1725,1726,1727,1728,1398, -1399,1729,1730,1731, 141, 621, 326,1057, 368,1732, 267, 488, 20,1733,1269,1734, - 945,1400,1735, 47, 904,1270,1736,1737, 773, 248,1738, 409, 313, 786, 429,1739, - 116, 987, 813,1401, 683, 75,1204, 145,1740,1741,1742,1743, 16, 847, 667, 622, - 708,1744,1745,1746, 966, 787, 304, 129,1747, 60, 820, 123, 676,1748,1749,1750, -1751, 617,1752, 626,1753,1754,1755,1756, 653,1757,1758,1759,1760,1761,1762, 856, - 344,1763,1764,1765,1766, 89, 401, 418, 806, 905, 848,1767,1768,1769, 946,1205, - 709,1770,1118,1771, 241,1772,1773,1774,1271,1775, 569,1776, 999,1777,1778,1779, -1780, 337, 751,1058, 28, 628, 254,1781, 177, 906, 270, 349, 891,1079,1782, 19, -1783, 379,1784, 315,1785, 629, 754,1402, 559,1786, 636, 203,1206,1787, 710, 567, -1788, 935, 814,1789,1790,1207, 766, 528,1791,1792,1208,1793,1794,1795,1796,1797, -1403,1798,1799, 533,1059,1404,1405,1156,1406, 936, 884,1080,1800, 351,1801,1802, -1803,1804,1805, 801,1806,1807,1808,1119,1809,1157, 714, 474,1407,1810, 298, 899, - 885,1811,1120, 802,1158,1812, 892,1813,1814,1408, 659,1815,1816,1121,1817,1818, -1819,1820,1821,1822, 319,1823, 594, 545,1824, 815, 937,1209,1825,1826, 573,1409, -1022,1827,1210,1828,1829,1830,1831,1832,1833, 556, 722, 807,1122,1060,1834, 697, -1835, 900, 557, 715,1836,1410, 540,1411, 752,1159, 294, 597,1211, 976, 803, 770, -1412,1837,1838, 39, 794,1413, 358,1839, 371, 925,1840, 453, 661, 788, 531, 723, - 544,1023,1081, 869, 91,1841, 392, 430, 790, 602,1414, 677,1082, 457,1415,1416, -1842,1843, 475, 327,1024,1417, 795, 121,1844, 733, 403,1418,1845,1846,1847, 300, - 119, 711,1212, 627,1848,1272, 207,1849,1850, 796,1213, 382,1851, 519,1852,1083, - 893,1853,1854,1855, 367, 809, 487, 671,1856, 663,1857,1858, 956, 471, 306, 857, -1859,1860,1160,1084,1861,1862,1863,1864,1865,1061,1866,1867,1868,1869,1870,1871, - 282, 96, 574,1872, 502,1085,1873,1214,1874, 907,1875,1876, 827, 977,1419,1420, -1421, 268,1877,1422,1878,1879,1880, 308,1881, 2, 537,1882,1883,1215,1884,1885, - 127, 791,1886,1273,1423,1887, 34, 336, 404, 643,1888, 571, 654, 894, 840,1889, - 0, 886,1274, 122, 575, 260, 908, 938,1890,1275, 410, 316,1891,1892, 100,1893, -1894,1123, 48,1161,1124,1025,1895, 633, 901,1276,1896,1897, 115, 816,1898, 317, -1899, 694,1900, 909, 734,1424, 572, 866,1425, 691, 85, 524,1010, 543, 394, 841, -1901,1902,1903,1026,1904,1905,1906,1907,1908,1909, 30, 451, 651, 988, 310,1910, -1911,1426, 810,1216, 93,1912,1913,1277,1217,1914, 858, 759, 45, 58, 181, 610, - 269,1915,1916, 131,1062, 551, 443,1000, 821,1427, 957, 895,1086,1917,1918, 375, -1919, 359,1920, 687,1921, 822,1922, 293,1923,1924, 40, 662, 118, 692, 29, 939, - 887, 640, 482, 174,1925, 69,1162, 728,1428, 910,1926,1278,1218,1279, 386, 870, - 217, 854,1163, 823,1927,1928,1929,1930, 834,1931, 78,1932, 859,1933,1063,1934, -1935,1936,1937, 438,1164, 208, 595,1938,1939,1940,1941,1219,1125,1942, 280, 888, -1429,1430,1220,1431,1943,1944,1945,1946,1947,1280, 150, 510,1432,1948,1949,1950, -1951,1952,1953,1954,1011,1087,1955,1433,1043,1956, 881,1957, 614, 958,1064,1065, -1221,1958, 638,1001, 860, 967, 896,1434, 989, 492, 553,1281,1165,1959,1282,1002, -1283,1222,1960,1961,1962,1963, 36, 383, 228, 753, 247, 454,1964, 876, 678,1965, -1966,1284, 126, 464, 490, 835, 136, 672, 529, 940,1088,1435, 473,1967,1968, 467, - 50, 390, 227, 587, 279, 378, 598, 792, 968, 240, 151, 160, 849, 882,1126,1285, - 639,1044, 133, 140, 288, 360, 811, 563,1027, 561, 142, 523,1969,1970,1971, 7, - 103, 296, 439, 407, 506, 634, 990,1972,1973,1974,1975, 645,1976,1977,1978,1979, -1980,1981, 236,1982,1436,1983,1984,1089, 192, 828, 618, 518,1166, 333,1127,1985, - 818,1223,1986,1987,1988,1989,1990,1991,1992,1993, 342,1128,1286, 746, 842,1994, -1995, 560, 223,1287, 98, 8, 189, 650, 978,1288,1996,1437,1997, 17, 345, 250, - 423, 277, 234, 512, 226, 97, 289, 42, 167,1998, 201,1999,2000, 843, 836, 824, - 532, 338, 783,1090, 182, 576, 436,1438,1439, 527, 500,2001, 947, 889,2002,2003, -2004,2005, 262, 600, 314, 447,2006, 547,2007, 693, 738,1129,2008, 71,1440, 745, - 619, 688,2009, 829,2010,2011, 147,2012, 33, 948,2013,2014, 74, 224,2015, 61, - 191, 918, 399, 637,2016,1028,1130, 257, 902,2017,2018,2019,2020,2021,2022,2023, -2024,2025,2026, 837,2027,2028,2029,2030, 179, 874, 591, 52, 724, 246,2031,2032, -2033,2034,1167, 969,2035,1289, 630, 605, 911,1091,1168,2036,2037,2038,1441, 912, -2039, 623,2040,2041, 253,1169,1290,2042,1442, 146, 620, 611, 577, 433,2043,1224, - 719,1170, 959, 440, 437, 534, 84, 388, 480,1131, 159, 220, 198, 679,2044,1012, - 819,1066,1443, 113,1225, 194, 318,1003,1029,2045,2046,2047,2048,1067,2049,2050, -2051,2052,2053, 59, 913, 112,2054, 632,2055, 455, 144, 739,1291,2056, 273, 681, - 499,2057, 448,2058,2059, 760,2060,2061, 970, 384, 169, 245,1132,2062,2063, 414, -1444,2064,2065, 41, 235,2066, 157, 252, 877, 568, 919, 789, 580,2067, 725,2068, -2069,1292,2070,2071,1445,2072,1446,2073,2074, 55, 588, 66,1447, 271,1092,2075, -1226,2076, 960,1013, 372,2077,2078,2079,2080,2081,1293,2082,2083,2084,2085, 850, -2086,2087,2088,2089,2090, 186,2091,1068, 180,2092,2093,2094, 109,1227, 522, 606, -2095, 867,1448,1093, 991,1171, 926, 353,1133,2096, 581,2097,2098,2099,1294,1449, -1450,2100, 596,1172,1014,1228,2101,1451,1295,1173,1229,2102,2103,1296,1134,1452, - 949,1135,2104,2105,1094,1453,1454,1455,2106,1095,2107,2108,2109,2110,2111,2112, -2113,2114,2115,2116,2117, 804,2118,2119,1230,1231, 805,1456, 405,1136,2120,2121, -2122,2123,2124, 720, 701,1297, 992,1457, 927,1004,2125,2126,2127,2128,2129,2130, - 22, 417,2131, 303,2132, 385,2133, 971, 520, 513,2134,1174, 73,1096, 231, 274, - 962,1458, 673,2135,1459,2136, 152,1137,2137,2138,2139,2140,1005,1138,1460,1139, -2141,2142,2143,2144, 11, 374, 844,2145, 154,1232, 46,1461,2146, 838, 830, 721, -1233, 106,2147, 90, 428, 462, 578, 566,1175, 352,2148,2149, 538,1234, 124,1298, -2150,1462, 761, 565,2151, 686,2152, 649,2153, 72, 173,2154, 460, 415,2155,1463, -2156,1235, 305,2157,2158,2159,2160,2161,2162, 579,2163,2164,2165,2166,2167, 747, -2168,2169,2170,2171,1464, 669,2172,2173,2174,2175,2176,1465,2177, 23, 530, 285, -2178, 335, 729,2179, 397,2180,2181,2182,1030,2183,2184, 698,2185,2186, 325,2187, -2188, 369,2189, 799,1097,1015, 348,2190,1069, 680,2191, 851,1466,2192,2193, 10, -2194, 613, 424,2195, 979, 108, 449, 589, 27, 172, 81,1031, 80, 774, 281, 350, -1032, 525, 301, 582,1176,2196, 674,1045,2197,2198,1467, 730, 762,2199,2200,2201, -2202,1468,2203, 993,2204,2205, 266,1070, 963,1140,2206,2207,2208, 664,1098, 972, -2209,2210,2211,1177,1469,1470, 871,2212,2213,2214,2215,2216,1471,2217,2218,2219, -2220,2221,2222,2223,2224,2225,2226,2227,1472,1236,2228,2229,2230,2231,2232,2233, -2234,2235,1299,2236,2237, 200,2238, 477, 373,2239,2240, 731, 825, 777,2241,2242, -2243, 521, 486, 548,2244,2245,2246,1473,1300, 53, 549, 137, 875, 76, 158,2247, -1301,1474, 469, 396,1016, 278, 712,2248, 321, 442, 503, 767, 744, 941,1237,1178, -1475,2249, 82, 178,1141,1179, 973,2250,1302,2251, 297,2252,2253, 570,2254,2255, -2256, 18, 450, 206,2257, 290, 292,1142,2258, 511, 162, 99, 346, 164, 735,2259, -1476,1477, 4, 554, 343, 798,1099,2260,1100,2261, 43, 171,1303, 139, 215,2262, -2263, 717, 775,2264,1033, 322, 216,2265, 831,2266, 149,2267,1304,2268,2269, 702, -1238, 135, 845, 347, 309,2270, 484,2271, 878, 655, 238,1006,1478,2272, 67,2273, - 295,2274,2275, 461,2276, 478, 942, 412,2277,1034,2278,2279,2280, 265,2281, 541, -2282,2283,2284,2285,2286, 70, 852,1071,2287,2288,2289,2290, 21, 56, 509, 117, - 432,2291,2292, 331, 980, 552,1101, 148, 284, 105, 393,1180,1239, 755,2293, 187, -2294,1046,1479,2295, 340,2296, 63,1047, 230,2297,2298,1305, 763,1306, 101, 800, - 808, 494,2299,2300,2301, 903,2302, 37,1072, 14, 5,2303, 79, 675,2304, 312, -2305,2306,2307,2308,2309,1480, 6,1307,2310,2311,2312, 1, 470, 35, 24, 229, -2313, 695, 210, 86, 778, 15, 784, 592, 779, 32, 77, 855, 964,2314, 259,2315, - 501, 380,2316,2317, 83, 981, 153, 689,1308,1481,1482,1483,2318,2319, 716,1484, -2320,2321,2322,2323,2324,2325,1485,2326,2327, 128, 57, 68, 261,1048, 211, 170, -1240, 31,2328, 51, 435, 742,2329,2330,2331, 635,2332, 264, 456,2333,2334,2335, - 425,2336,1486, 143, 507, 263, 943,2337, 363, 920,1487, 256,1488,1102, 243, 601, -1489,2338,2339,2340,2341,2342,2343,2344, 861,2345,2346,2347,2348,2349,2350, 395, -2351,1490,1491, 62, 535, 166, 225,2352,2353, 668, 419,1241, 138, 604, 928,2354, -1181,2355,1492,1493,2356,2357,2358,1143,2359, 696,2360, 387, 307,1309, 682, 476, -2361,2362, 332, 12, 222, 156,2363, 232,2364, 641, 276, 656, 517,1494,1495,1035, - 416, 736,1496,2365,1017, 586,2366,2367,2368,1497,2369, 242,2370,2371,2372,1498, -2373, 965, 713,2374,2375,2376,2377, 740, 982,1499, 944,1500,1007,2378,2379,1310, -1501,2380,2381,2382, 785, 329,2383,2384,1502,2385,2386,2387, 932,2388,1503,2389, -2390,2391,2392,1242,2393,2394,2395,2396,2397, 994, 950,2398,2399,2400,2401,1504, -1311,2402,2403,2404,2405,1049, 749,2406,2407, 853, 718,1144,1312,2408,1182,1505, -2409,2410, 255, 516, 479, 564, 550, 214,1506,1507,1313, 413, 239, 444, 339,1145, -1036,1508,1509,1314,1037,1510,1315,2411,1511,2412,2413,2414, 176, 703, 497, 624, - 593, 921, 302,2415, 341, 165,1103,1512,2416,1513,2417,2418,2419, 376,2420, 700, -2421,2422,2423, 258, 768,1316,2424,1183,2425, 995, 608,2426,2427,2428,2429, 221, -2430,2431,2432,2433,2434,2435,2436,2437, 195, 323, 726, 188, 897, 983,1317, 377, - 644,1050, 879,2438, 452,2439,2440,2441,2442,2443,2444, 914,2445,2446,2447,2448, - 915, 489,2449,1514,1184,2450,2451, 515, 64, 427, 495,2452, 583,2453, 483, 485, -1038, 562, 213,1515, 748, 666,2454,2455,2456,2457, 334,2458, 780, 996,1008, 705, -1243,2459,2460,2461,2462,2463, 114,2464, 493,1146, 366, 163,1516, 961,1104,2465, - 291,2466,1318,1105,2467,1517, 365,2468, 355, 951,1244,2469,1319,2470, 631,2471, -2472, 218,1320, 364, 320, 756,1518,1519,1321,1520,1322,2473,2474,2475,2476, 997, -2477,2478,2479,2480, 665,1185,2481, 916,1521,2482,2483,2484, 584, 684,2485,2486, - 797,2487,1051,1186,2488,2489,2490,1522,2491,2492, 370,2493,1039,1187, 65,2494, - 434, 205, 463,1188,2495, 125, 812, 391, 402, 826, 699, 286, 398, 155, 781, 771, - 585,2496, 590, 505,1073,2497, 599, 244, 219, 917,1018, 952, 646,1523,2498,1323, -2499,2500, 49, 984, 354, 741,2501, 625,2502,1324,2503,1019, 190, 357, 757, 491, - 95, 782, 868,2504,2505,2506,2507,2508,2509, 134,1524,1074, 422,1525, 898,2510, - 161,2511,2512,2513,2514, 769,2515,1526,2516,2517, 411,1325,2518, 472,1527,2519, -2520,2521,2522,2523,2524, 985,2525,2526,2527,2528,2529,2530, 764,2531,1245,2532, -2533, 25, 204, 311,2534, 496,2535,1052,2536,2537,2538,2539,2540,2541,2542, 199, - 704, 504, 468, 758, 657,1528, 196, 44, 839,1246, 272, 750,2543, 765, 862,2544, -2545,1326,2546, 132, 615, 933,2547, 732,2548,2549,2550,1189,1529,2551, 283,1247, -1053, 607, 929,2552,2553,2554, 930, 183, 872, 616,1040,1147,2555,1148,1020, 441, - 249,1075,2556,2557,2558, 466, 743,2559,2560,2561, 92, 514, 426, 420, 526,2562, -2563,2564,2565,2566,2567,2568, 185,2569,2570,2571,2572, 776,1530, 658,2573, 362, -2574, 361, 922,1076, 793,2575,2576,2577,2578,2579,2580,1531, 251,2581,2582,2583, -2584,1532, 54, 612, 237,1327,2585,2586, 275, 408, 647, 111,2587,1533,1106, 465, - 3, 458, 9, 38,2588, 107, 110, 890, 209, 26, 737, 498,2589,1534,2590, 431, - 202, 88,1535, 356, 287,1107, 660,1149,2591, 381,1536, 986,1150, 445,1248,1151, - 974,2592,2593, 846,2594, 446, 953, 184,1249,1250, 727,2595, 923, 193, 883,2596, -2597,2598, 102, 324, 539, 817,2599, 421,1041,2600, 832,2601, 94, 175, 197, 406, -2602, 459,2603,2604,2605,2606,2607, 330, 555,2608,2609,2610, 706,1108, 389,2611, -2612,2613,2614, 233,2615, 833, 558, 931, 954,1251,2616,2617,1537, 546,2618,2619, -1009,2620,2621,2622,1538, 690,1328,2623, 955,2624,1539,2625,2626, 772,2627,2628, -2629,2630,2631, 924, 648, 863, 603,2632,2633, 934,1540, 864, 865,2634, 642,1042, - 670,1190,2635,2636,2637,2638, 168,2639, 652, 873, 542,1054,1541,2640,2641,2642, # 512, 256 -) -# fmt: on diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/euckrprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/euckrprober.py deleted file mode 100644 index 1fc5de0..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/euckrprober.py +++ /dev/null @@ -1,47 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 .chardistribution import EUCKRDistributionAnalysis -from .codingstatemachine import CodingStateMachine -from .mbcharsetprober import MultiByteCharSetProber -from .mbcssm import EUCKR_SM_MODEL - - -class EUCKRProber(MultiByteCharSetProber): - def __init__(self) -> None: - super().__init__() - self.coding_sm = CodingStateMachine(EUCKR_SM_MODEL) - self.distribution_analyzer = EUCKRDistributionAnalysis() - self.reset() - - @property - def charset_name(self) -> str: - return "EUC-KR" - - @property - def language(self) -> str: - return "Korean" diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py b/myenv/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py deleted file mode 100644 index 4900ccc..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py +++ /dev/null @@ -1,388 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Communicator client code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 ######################### - -# EUCTW frequency table -# Converted from big5 work -# by Taiwan's Mandarin Promotion Council -# - -# 128 --> 0.42261 -# 256 --> 0.57851 -# 512 --> 0.74851 -# 1024 --> 0.89384 -# 2048 --> 0.97583 -# -# Idea Distribution Ratio = 0.74851/(1-0.74851) =2.98 -# Random Distribution Ration = 512/(5401-512)=0.105 -# -# Typical Distribution Ratio about 25% of Ideal one, still much higher than RDR - -EUCTW_TYPICAL_DISTRIBUTION_RATIO = 0.75 - -# Char to FreqOrder table -EUCTW_TABLE_SIZE = 5376 - -# fmt: off -EUCTW_CHAR_TO_FREQ_ORDER = ( - 1, 1800, 1506, 255, 1431, 198, 9, 82, 6, 7310, 177, 202, 3615, 1256, 2808, 110, # 2742 - 3735, 33, 3241, 261, 76, 44, 2113, 16, 2931, 2184, 1176, 659, 3868, 26, 3404, 2643, # 2758 - 1198, 3869, 3313, 4060, 410, 2211, 302, 590, 361, 1963, 8, 204, 58, 4296, 7311, 1931, # 2774 - 63, 7312, 7313, 317, 1614, 75, 222, 159, 4061, 2412, 1480, 7314, 3500, 3068, 224, 2809, # 2790 - 3616, 3, 10, 3870, 1471, 29, 2774, 1135, 2852, 1939, 873, 130, 3242, 1123, 312, 7315, # 2806 - 4297, 2051, 507, 252, 682, 7316, 142, 1914, 124, 206, 2932, 34, 3501, 3173, 64, 604, # 2822 - 7317, 2494, 1976, 1977, 155, 1990, 645, 641, 1606, 7318, 3405, 337, 72, 406, 7319, 80, # 2838 - 630, 238, 3174, 1509, 263, 939, 1092, 2644, 756, 1440, 1094, 3406, 449, 69, 2969, 591, # 2854 - 179, 2095, 471, 115, 2034, 1843, 60, 50, 2970, 134, 806, 1868, 734, 2035, 3407, 180, # 2870 - 995, 1607, 156, 537, 2893, 688, 7320, 319, 1305, 779, 2144, 514, 2374, 298, 4298, 359, # 2886 - 2495, 90, 2707, 1338, 663, 11, 906, 1099, 2545, 20, 2436, 182, 532, 1716, 7321, 732, # 2902 - 1376, 4062, 1311, 1420, 3175, 25, 2312, 1056, 113, 399, 382, 1949, 242, 3408, 2467, 529, # 2918 - 3243, 475, 1447, 3617, 7322, 117, 21, 656, 810, 1297, 2295, 2329, 3502, 7323, 126, 4063, # 2934 - 706, 456, 150, 613, 4299, 71, 1118, 2036, 4064, 145, 3069, 85, 835, 486, 2114, 1246, # 2950 - 1426, 428, 727, 1285, 1015, 800, 106, 623, 303, 1281, 7324, 2127, 2354, 347, 3736, 221, # 2966 - 3503, 3110, 7325, 1955, 1153, 4065, 83, 296, 1199, 3070, 192, 624, 93, 7326, 822, 1897, # 2982 - 2810, 3111, 795, 2064, 991, 1554, 1542, 1592, 27, 43, 2853, 859, 139, 1456, 860, 4300, # 2998 - 437, 712, 3871, 164, 2392, 3112, 695, 211, 3017, 2096, 195, 3872, 1608, 3504, 3505, 3618, # 3014 - 3873, 234, 811, 2971, 2097, 3874, 2229, 1441, 3506, 1615, 2375, 668, 2076, 1638, 305, 228, # 3030 - 1664, 4301, 467, 415, 7327, 262, 2098, 1593, 239, 108, 300, 200, 1033, 512, 1247, 2077, # 3046 - 7328, 7329, 2173, 3176, 3619, 2673, 593, 845, 1062, 3244, 88, 1723, 2037, 3875, 1950, 212, # 3062 - 266, 152, 149, 468, 1898, 4066, 4302, 77, 187, 7330, 3018, 37, 5, 2972, 7331, 3876, # 3078 - 7332, 7333, 39, 2517, 4303, 2894, 3177, 2078, 55, 148, 74, 4304, 545, 483, 1474, 1029, # 3094 - 1665, 217, 1869, 1531, 3113, 1104, 2645, 4067, 24, 172, 3507, 900, 3877, 3508, 3509, 4305, # 3110 - 32, 1408, 2811, 1312, 329, 487, 2355, 2247, 2708, 784, 2674, 4, 3019, 3314, 1427, 1788, # 3126 - 188, 109, 499, 7334, 3620, 1717, 1789, 888, 1217, 3020, 4306, 7335, 3510, 7336, 3315, 1520, # 3142 - 3621, 3878, 196, 1034, 775, 7337, 7338, 929, 1815, 249, 439, 38, 7339, 1063, 7340, 794, # 3158 - 3879, 1435, 2296, 46, 178, 3245, 2065, 7341, 2376, 7342, 214, 1709, 4307, 804, 35, 707, # 3174 - 324, 3622, 1601, 2546, 140, 459, 4068, 7343, 7344, 1365, 839, 272, 978, 2257, 2572, 3409, # 3190 - 2128, 1363, 3623, 1423, 697, 100, 3071, 48, 70, 1231, 495, 3114, 2193, 7345, 1294, 7346, # 3206 - 2079, 462, 586, 1042, 3246, 853, 256, 988, 185, 2377, 3410, 1698, 434, 1084, 7347, 3411, # 3222 - 314, 2615, 2775, 4308, 2330, 2331, 569, 2280, 637, 1816, 2518, 757, 1162, 1878, 1616, 3412, # 3238 - 287, 1577, 2115, 768, 4309, 1671, 2854, 3511, 2519, 1321, 3737, 909, 2413, 7348, 4069, 933, # 3254 - 3738, 7349, 2052, 2356, 1222, 4310, 765, 2414, 1322, 786, 4311, 7350, 1919, 1462, 1677, 2895, # 3270 - 1699, 7351, 4312, 1424, 2437, 3115, 3624, 2590, 3316, 1774, 1940, 3413, 3880, 4070, 309, 1369, # 3286 - 1130, 2812, 364, 2230, 1653, 1299, 3881, 3512, 3882, 3883, 2646, 525, 1085, 3021, 902, 2000, # 3302 - 1475, 964, 4313, 421, 1844, 1415, 1057, 2281, 940, 1364, 3116, 376, 4314, 4315, 1381, 7, # 3318 - 2520, 983, 2378, 336, 1710, 2675, 1845, 321, 3414, 559, 1131, 3022, 2742, 1808, 1132, 1313, # 3334 - 265, 1481, 1857, 7352, 352, 1203, 2813, 3247, 167, 1089, 420, 2814, 776, 792, 1724, 3513, # 3350 - 4071, 2438, 3248, 7353, 4072, 7354, 446, 229, 333, 2743, 901, 3739, 1200, 1557, 4316, 2647, # 3366 - 1920, 395, 2744, 2676, 3740, 4073, 1835, 125, 916, 3178, 2616, 4317, 7355, 7356, 3741, 7357, # 3382 - 7358, 7359, 4318, 3117, 3625, 1133, 2547, 1757, 3415, 1510, 2313, 1409, 3514, 7360, 2145, 438, # 3398 - 2591, 2896, 2379, 3317, 1068, 958, 3023, 461, 311, 2855, 2677, 4074, 1915, 3179, 4075, 1978, # 3414 - 383, 750, 2745, 2617, 4076, 274, 539, 385, 1278, 1442, 7361, 1154, 1964, 384, 561, 210, # 3430 - 98, 1295, 2548, 3515, 7362, 1711, 2415, 1482, 3416, 3884, 2897, 1257, 129, 7363, 3742, 642, # 3446 - 523, 2776, 2777, 2648, 7364, 141, 2231, 1333, 68, 176, 441, 876, 907, 4077, 603, 2592, # 3462 - 710, 171, 3417, 404, 549, 18, 3118, 2393, 1410, 3626, 1666, 7365, 3516, 4319, 2898, 4320, # 3478 - 7366, 2973, 368, 7367, 146, 366, 99, 871, 3627, 1543, 748, 807, 1586, 1185, 22, 2258, # 3494 - 379, 3743, 3180, 7368, 3181, 505, 1941, 2618, 1991, 1382, 2314, 7369, 380, 2357, 218, 702, # 3510 - 1817, 1248, 3418, 3024, 3517, 3318, 3249, 7370, 2974, 3628, 930, 3250, 3744, 7371, 59, 7372, # 3526 - 585, 601, 4078, 497, 3419, 1112, 1314, 4321, 1801, 7373, 1223, 1472, 2174, 7374, 749, 1836, # 3542 - 690, 1899, 3745, 1772, 3885, 1476, 429, 1043, 1790, 2232, 2116, 917, 4079, 447, 1086, 1629, # 3558 - 7375, 556, 7376, 7377, 2020, 1654, 844, 1090, 105, 550, 966, 1758, 2815, 1008, 1782, 686, # 3574 - 1095, 7378, 2282, 793, 1602, 7379, 3518, 2593, 4322, 4080, 2933, 2297, 4323, 3746, 980, 2496, # 3590 - 544, 353, 527, 4324, 908, 2678, 2899, 7380, 381, 2619, 1942, 1348, 7381, 1341, 1252, 560, # 3606 - 3072, 7382, 3420, 2856, 7383, 2053, 973, 886, 2080, 143, 4325, 7384, 7385, 157, 3886, 496, # 3622 - 4081, 57, 840, 540, 2038, 4326, 4327, 3421, 2117, 1445, 970, 2259, 1748, 1965, 2081, 4082, # 3638 - 3119, 1234, 1775, 3251, 2816, 3629, 773, 1206, 2129, 1066, 2039, 1326, 3887, 1738, 1725, 4083, # 3654 - 279, 3120, 51, 1544, 2594, 423, 1578, 2130, 2066, 173, 4328, 1879, 7386, 7387, 1583, 264, # 3670 - 610, 3630, 4329, 2439, 280, 154, 7388, 7389, 7390, 1739, 338, 1282, 3073, 693, 2857, 1411, # 3686 - 1074, 3747, 2440, 7391, 4330, 7392, 7393, 1240, 952, 2394, 7394, 2900, 1538, 2679, 685, 1483, # 3702 - 4084, 2468, 1436, 953, 4085, 2054, 4331, 671, 2395, 79, 4086, 2441, 3252, 608, 567, 2680, # 3718 - 3422, 4087, 4088, 1691, 393, 1261, 1791, 2396, 7395, 4332, 7396, 7397, 7398, 7399, 1383, 1672, # 3734 - 3748, 3182, 1464, 522, 1119, 661, 1150, 216, 675, 4333, 3888, 1432, 3519, 609, 4334, 2681, # 3750 - 2397, 7400, 7401, 7402, 4089, 3025, 0, 7403, 2469, 315, 231, 2442, 301, 3319, 4335, 2380, # 3766 - 7404, 233, 4090, 3631, 1818, 4336, 4337, 7405, 96, 1776, 1315, 2082, 7406, 257, 7407, 1809, # 3782 - 3632, 2709, 1139, 1819, 4091, 2021, 1124, 2163, 2778, 1777, 2649, 7408, 3074, 363, 1655, 3183, # 3798 - 7409, 2975, 7410, 7411, 7412, 3889, 1567, 3890, 718, 103, 3184, 849, 1443, 341, 3320, 2934, # 3814 - 1484, 7413, 1712, 127, 67, 339, 4092, 2398, 679, 1412, 821, 7414, 7415, 834, 738, 351, # 3830 - 2976, 2146, 846, 235, 1497, 1880, 418, 1992, 3749, 2710, 186, 1100, 2147, 2746, 3520, 1545, # 3846 - 1355, 2935, 2858, 1377, 583, 3891, 4093, 2573, 2977, 7416, 1298, 3633, 1078, 2549, 3634, 2358, # 3862 - 78, 3750, 3751, 267, 1289, 2099, 2001, 1594, 4094, 348, 369, 1274, 2194, 2175, 1837, 4338, # 3878 - 1820, 2817, 3635, 2747, 2283, 2002, 4339, 2936, 2748, 144, 3321, 882, 4340, 3892, 2749, 3423, # 3894 - 4341, 2901, 7417, 4095, 1726, 320, 7418, 3893, 3026, 788, 2978, 7419, 2818, 1773, 1327, 2859, # 3910 - 3894, 2819, 7420, 1306, 4342, 2003, 1700, 3752, 3521, 2359, 2650, 787, 2022, 506, 824, 3636, # 3926 - 534, 323, 4343, 1044, 3322, 2023, 1900, 946, 3424, 7421, 1778, 1500, 1678, 7422, 1881, 4344, # 3942 - 165, 243, 4345, 3637, 2521, 123, 683, 4096, 764, 4346, 36, 3895, 1792, 589, 2902, 816, # 3958 - 626, 1667, 3027, 2233, 1639, 1555, 1622, 3753, 3896, 7423, 3897, 2860, 1370, 1228, 1932, 891, # 3974 - 2083, 2903, 304, 4097, 7424, 292, 2979, 2711, 3522, 691, 2100, 4098, 1115, 4347, 118, 662, # 3990 - 7425, 611, 1156, 854, 2381, 1316, 2861, 2, 386, 515, 2904, 7426, 7427, 3253, 868, 2234, # 4006 - 1486, 855, 2651, 785, 2212, 3028, 7428, 1040, 3185, 3523, 7429, 3121, 448, 7430, 1525, 7431, # 4022 - 2164, 4348, 7432, 3754, 7433, 4099, 2820, 3524, 3122, 503, 818, 3898, 3123, 1568, 814, 676, # 4038 - 1444, 306, 1749, 7434, 3755, 1416, 1030, 197, 1428, 805, 2821, 1501, 4349, 7435, 7436, 7437, # 4054 - 1993, 7438, 4350, 7439, 7440, 2195, 13, 2779, 3638, 2980, 3124, 1229, 1916, 7441, 3756, 2131, # 4070 - 7442, 4100, 4351, 2399, 3525, 7443, 2213, 1511, 1727, 1120, 7444, 7445, 646, 3757, 2443, 307, # 4086 - 7446, 7447, 1595, 3186, 7448, 7449, 7450, 3639, 1113, 1356, 3899, 1465, 2522, 2523, 7451, 519, # 4102 - 7452, 128, 2132, 92, 2284, 1979, 7453, 3900, 1512, 342, 3125, 2196, 7454, 2780, 2214, 1980, # 4118 - 3323, 7455, 290, 1656, 1317, 789, 827, 2360, 7456, 3758, 4352, 562, 581, 3901, 7457, 401, # 4134 - 4353, 2248, 94, 4354, 1399, 2781, 7458, 1463, 2024, 4355, 3187, 1943, 7459, 828, 1105, 4101, # 4150 - 1262, 1394, 7460, 4102, 605, 4356, 7461, 1783, 2862, 7462, 2822, 819, 2101, 578, 2197, 2937, # 4166 - 7463, 1502, 436, 3254, 4103, 3255, 2823, 3902, 2905, 3425, 3426, 7464, 2712, 2315, 7465, 7466, # 4182 - 2332, 2067, 23, 4357, 193, 826, 3759, 2102, 699, 1630, 4104, 3075, 390, 1793, 1064, 3526, # 4198 - 7467, 1579, 3076, 3077, 1400, 7468, 4105, 1838, 1640, 2863, 7469, 4358, 4359, 137, 4106, 598, # 4214 - 3078, 1966, 780, 104, 974, 2938, 7470, 278, 899, 253, 402, 572, 504, 493, 1339, 7471, # 4230 - 3903, 1275, 4360, 2574, 2550, 7472, 3640, 3029, 3079, 2249, 565, 1334, 2713, 863, 41, 7473, # 4246 - 7474, 4361, 7475, 1657, 2333, 19, 463, 2750, 4107, 606, 7476, 2981, 3256, 1087, 2084, 1323, # 4262 - 2652, 2982, 7477, 1631, 1623, 1750, 4108, 2682, 7478, 2864, 791, 2714, 2653, 2334, 232, 2416, # 4278 - 7479, 2983, 1498, 7480, 2654, 2620, 755, 1366, 3641, 3257, 3126, 2025, 1609, 119, 1917, 3427, # 4294 - 862, 1026, 4109, 7481, 3904, 3760, 4362, 3905, 4363, 2260, 1951, 2470, 7482, 1125, 817, 4110, # 4310 - 4111, 3906, 1513, 1766, 2040, 1487, 4112, 3030, 3258, 2824, 3761, 3127, 7483, 7484, 1507, 7485, # 4326 - 2683, 733, 40, 1632, 1106, 2865, 345, 4113, 841, 2524, 230, 4364, 2984, 1846, 3259, 3428, # 4342 - 7486, 1263, 986, 3429, 7487, 735, 879, 254, 1137, 857, 622, 1300, 1180, 1388, 1562, 3907, # 4358 - 3908, 2939, 967, 2751, 2655, 1349, 592, 2133, 1692, 3324, 2985, 1994, 4114, 1679, 3909, 1901, # 4374 - 2185, 7488, 739, 3642, 2715, 1296, 1290, 7489, 4115, 2198, 2199, 1921, 1563, 2595, 2551, 1870, # 4390 - 2752, 2986, 7490, 435, 7491, 343, 1108, 596, 17, 1751, 4365, 2235, 3430, 3643, 7492, 4366, # 4406 - 294, 3527, 2940, 1693, 477, 979, 281, 2041, 3528, 643, 2042, 3644, 2621, 2782, 2261, 1031, # 4422 - 2335, 2134, 2298, 3529, 4367, 367, 1249, 2552, 7493, 3530, 7494, 4368, 1283, 3325, 2004, 240, # 4438 - 1762, 3326, 4369, 4370, 836, 1069, 3128, 474, 7495, 2148, 2525, 268, 3531, 7496, 3188, 1521, # 4454 - 1284, 7497, 1658, 1546, 4116, 7498, 3532, 3533, 7499, 4117, 3327, 2684, 1685, 4118, 961, 1673, # 4470 - 2622, 190, 2005, 2200, 3762, 4371, 4372, 7500, 570, 2497, 3645, 1490, 7501, 4373, 2623, 3260, # 4486 - 1956, 4374, 584, 1514, 396, 1045, 1944, 7502, 4375, 1967, 2444, 7503, 7504, 4376, 3910, 619, # 4502 - 7505, 3129, 3261, 215, 2006, 2783, 2553, 3189, 4377, 3190, 4378, 763, 4119, 3763, 4379, 7506, # 4518 - 7507, 1957, 1767, 2941, 3328, 3646, 1174, 452, 1477, 4380, 3329, 3130, 7508, 2825, 1253, 2382, # 4534 - 2186, 1091, 2285, 4120, 492, 7509, 638, 1169, 1824, 2135, 1752, 3911, 648, 926, 1021, 1324, # 4550 - 4381, 520, 4382, 997, 847, 1007, 892, 4383, 3764, 2262, 1871, 3647, 7510, 2400, 1784, 4384, # 4566 - 1952, 2942, 3080, 3191, 1728, 4121, 2043, 3648, 4385, 2007, 1701, 3131, 1551, 30, 2263, 4122, # 4582 - 7511, 2026, 4386, 3534, 7512, 501, 7513, 4123, 594, 3431, 2165, 1821, 3535, 3432, 3536, 3192, # 4598 - 829, 2826, 4124, 7514, 1680, 3132, 1225, 4125, 7515, 3262, 4387, 4126, 3133, 2336, 7516, 4388, # 4614 - 4127, 7517, 3912, 3913, 7518, 1847, 2383, 2596, 3330, 7519, 4389, 374, 3914, 652, 4128, 4129, # 4630 - 375, 1140, 798, 7520, 7521, 7522, 2361, 4390, 2264, 546, 1659, 138, 3031, 2445, 4391, 7523, # 4646 - 2250, 612, 1848, 910, 796, 3765, 1740, 1371, 825, 3766, 3767, 7524, 2906, 2554, 7525, 692, # 4662 - 444, 3032, 2624, 801, 4392, 4130, 7526, 1491, 244, 1053, 3033, 4131, 4132, 340, 7527, 3915, # 4678 - 1041, 2987, 293, 1168, 87, 1357, 7528, 1539, 959, 7529, 2236, 721, 694, 4133, 3768, 219, # 4694 - 1478, 644, 1417, 3331, 2656, 1413, 1401, 1335, 1389, 3916, 7530, 7531, 2988, 2362, 3134, 1825, # 4710 - 730, 1515, 184, 2827, 66, 4393, 7532, 1660, 2943, 246, 3332, 378, 1457, 226, 3433, 975, # 4726 - 3917, 2944, 1264, 3537, 674, 696, 7533, 163, 7534, 1141, 2417, 2166, 713, 3538, 3333, 4394, # 4742 - 3918, 7535, 7536, 1186, 15, 7537, 1079, 1070, 7538, 1522, 3193, 3539, 276, 1050, 2716, 758, # 4758 - 1126, 653, 2945, 3263, 7539, 2337, 889, 3540, 3919, 3081, 2989, 903, 1250, 4395, 3920, 3434, # 4774 - 3541, 1342, 1681, 1718, 766, 3264, 286, 89, 2946, 3649, 7540, 1713, 7541, 2597, 3334, 2990, # 4790 - 7542, 2947, 2215, 3194, 2866, 7543, 4396, 2498, 2526, 181, 387, 1075, 3921, 731, 2187, 3335, # 4806 - 7544, 3265, 310, 313, 3435, 2299, 770, 4134, 54, 3034, 189, 4397, 3082, 3769, 3922, 7545, # 4822 - 1230, 1617, 1849, 355, 3542, 4135, 4398, 3336, 111, 4136, 3650, 1350, 3135, 3436, 3035, 4137, # 4838 - 2149, 3266, 3543, 7546, 2784, 3923, 3924, 2991, 722, 2008, 7547, 1071, 247, 1207, 2338, 2471, # 4854 - 1378, 4399, 2009, 864, 1437, 1214, 4400, 373, 3770, 1142, 2216, 667, 4401, 442, 2753, 2555, # 4870 - 3771, 3925, 1968, 4138, 3267, 1839, 837, 170, 1107, 934, 1336, 1882, 7548, 7549, 2118, 4139, # 4886 - 2828, 743, 1569, 7550, 4402, 4140, 582, 2384, 1418, 3437, 7551, 1802, 7552, 357, 1395, 1729, # 4902 - 3651, 3268, 2418, 1564, 2237, 7553, 3083, 3772, 1633, 4403, 1114, 2085, 4141, 1532, 7554, 482, # 4918 - 2446, 4404, 7555, 7556, 1492, 833, 1466, 7557, 2717, 3544, 1641, 2829, 7558, 1526, 1272, 3652, # 4934 - 4142, 1686, 1794, 416, 2556, 1902, 1953, 1803, 7559, 3773, 2785, 3774, 1159, 2316, 7560, 2867, # 4950 - 4405, 1610, 1584, 3036, 2419, 2754, 443, 3269, 1163, 3136, 7561, 7562, 3926, 7563, 4143, 2499, # 4966 - 3037, 4406, 3927, 3137, 2103, 1647, 3545, 2010, 1872, 4144, 7564, 4145, 431, 3438, 7565, 250, # 4982 - 97, 81, 4146, 7566, 1648, 1850, 1558, 160, 848, 7567, 866, 740, 1694, 7568, 2201, 2830, # 4998 - 3195, 4147, 4407, 3653, 1687, 950, 2472, 426, 469, 3196, 3654, 3655, 3928, 7569, 7570, 1188, # 5014 - 424, 1995, 861, 3546, 4148, 3775, 2202, 2685, 168, 1235, 3547, 4149, 7571, 2086, 1674, 4408, # 5030 - 3337, 3270, 220, 2557, 1009, 7572, 3776, 670, 2992, 332, 1208, 717, 7573, 7574, 3548, 2447, # 5046 - 3929, 3338, 7575, 513, 7576, 1209, 2868, 3339, 3138, 4409, 1080, 7577, 7578, 7579, 7580, 2527, # 5062 - 3656, 3549, 815, 1587, 3930, 3931, 7581, 3550, 3439, 3777, 1254, 4410, 1328, 3038, 1390, 3932, # 5078 - 1741, 3933, 3778, 3934, 7582, 236, 3779, 2448, 3271, 7583, 7584, 3657, 3780, 1273, 3781, 4411, # 5094 - 7585, 308, 7586, 4412, 245, 4413, 1851, 2473, 1307, 2575, 430, 715, 2136, 2449, 7587, 270, # 5110 - 199, 2869, 3935, 7588, 3551, 2718, 1753, 761, 1754, 725, 1661, 1840, 4414, 3440, 3658, 7589, # 5126 - 7590, 587, 14, 3272, 227, 2598, 326, 480, 2265, 943, 2755, 3552, 291, 650, 1883, 7591, # 5142 - 1702, 1226, 102, 1547, 62, 3441, 904, 4415, 3442, 1164, 4150, 7592, 7593, 1224, 1548, 2756, # 5158 - 391, 498, 1493, 7594, 1386, 1419, 7595, 2055, 1177, 4416, 813, 880, 1081, 2363, 566, 1145, # 5174 - 4417, 2286, 1001, 1035, 2558, 2599, 2238, 394, 1286, 7596, 7597, 2068, 7598, 86, 1494, 1730, # 5190 - 3936, 491, 1588, 745, 897, 2948, 843, 3340, 3937, 2757, 2870, 3273, 1768, 998, 2217, 2069, # 5206 - 397, 1826, 1195, 1969, 3659, 2993, 3341, 284, 7599, 3782, 2500, 2137, 2119, 1903, 7600, 3938, # 5222 - 2150, 3939, 4151, 1036, 3443, 1904, 114, 2559, 4152, 209, 1527, 7601, 7602, 2949, 2831, 2625, # 5238 - 2385, 2719, 3139, 812, 2560, 7603, 3274, 7604, 1559, 737, 1884, 3660, 1210, 885, 28, 2686, # 5254 - 3553, 3783, 7605, 4153, 1004, 1779, 4418, 7606, 346, 1981, 2218, 2687, 4419, 3784, 1742, 797, # 5270 - 1642, 3940, 1933, 1072, 1384, 2151, 896, 3941, 3275, 3661, 3197, 2871, 3554, 7607, 2561, 1958, # 5286 - 4420, 2450, 1785, 7608, 7609, 7610, 3942, 4154, 1005, 1308, 3662, 4155, 2720, 4421, 4422, 1528, # 5302 - 2600, 161, 1178, 4156, 1982, 987, 4423, 1101, 4157, 631, 3943, 1157, 3198, 2420, 1343, 1241, # 5318 - 1016, 2239, 2562, 372, 877, 2339, 2501, 1160, 555, 1934, 911, 3944, 7611, 466, 1170, 169, # 5334 - 1051, 2907, 2688, 3663, 2474, 2994, 1182, 2011, 2563, 1251, 2626, 7612, 992, 2340, 3444, 1540, # 5350 - 2721, 1201, 2070, 2401, 1996, 2475, 7613, 4424, 528, 1922, 2188, 1503, 1873, 1570, 2364, 3342, # 5366 - 3276, 7614, 557, 1073, 7615, 1827, 3445, 2087, 2266, 3140, 3039, 3084, 767, 3085, 2786, 4425, # 5382 - 1006, 4158, 4426, 2341, 1267, 2176, 3664, 3199, 778, 3945, 3200, 2722, 1597, 2657, 7616, 4427, # 5398 - 7617, 3446, 7618, 7619, 7620, 3277, 2689, 1433, 3278, 131, 95, 1504, 3946, 723, 4159, 3141, # 5414 - 1841, 3555, 2758, 2189, 3947, 2027, 2104, 3665, 7621, 2995, 3948, 1218, 7622, 3343, 3201, 3949, # 5430 - 4160, 2576, 248, 1634, 3785, 912, 7623, 2832, 3666, 3040, 3786, 654, 53, 7624, 2996, 7625, # 5446 - 1688, 4428, 777, 3447, 1032, 3950, 1425, 7626, 191, 820, 2120, 2833, 971, 4429, 931, 3202, # 5462 - 135, 664, 783, 3787, 1997, 772, 2908, 1935, 3951, 3788, 4430, 2909, 3203, 282, 2723, 640, # 5478 - 1372, 3448, 1127, 922, 325, 3344, 7627, 7628, 711, 2044, 7629, 7630, 3952, 2219, 2787, 1936, # 5494 - 3953, 3345, 2220, 2251, 3789, 2300, 7631, 4431, 3790, 1258, 3279, 3954, 3204, 2138, 2950, 3955, # 5510 - 3956, 7632, 2221, 258, 3205, 4432, 101, 1227, 7633, 3280, 1755, 7634, 1391, 3281, 7635, 2910, # 5526 - 2056, 893, 7636, 7637, 7638, 1402, 4161, 2342, 7639, 7640, 3206, 3556, 7641, 7642, 878, 1325, # 5542 - 1780, 2788, 4433, 259, 1385, 2577, 744, 1183, 2267, 4434, 7643, 3957, 2502, 7644, 684, 1024, # 5558 - 4162, 7645, 472, 3557, 3449, 1165, 3282, 3958, 3959, 322, 2152, 881, 455, 1695, 1152, 1340, # 5574 - 660, 554, 2153, 4435, 1058, 4436, 4163, 830, 1065, 3346, 3960, 4437, 1923, 7646, 1703, 1918, # 5590 - 7647, 932, 2268, 122, 7648, 4438, 947, 677, 7649, 3791, 2627, 297, 1905, 1924, 2269, 4439, # 5606 - 2317, 3283, 7650, 7651, 4164, 7652, 4165, 84, 4166, 112, 989, 7653, 547, 1059, 3961, 701, # 5622 - 3558, 1019, 7654, 4167, 7655, 3450, 942, 639, 457, 2301, 2451, 993, 2951, 407, 851, 494, # 5638 - 4440, 3347, 927, 7656, 1237, 7657, 2421, 3348, 573, 4168, 680, 921, 2911, 1279, 1874, 285, # 5654 - 790, 1448, 1983, 719, 2167, 7658, 7659, 4441, 3962, 3963, 1649, 7660, 1541, 563, 7661, 1077, # 5670 - 7662, 3349, 3041, 3451, 511, 2997, 3964, 3965, 3667, 3966, 1268, 2564, 3350, 3207, 4442, 4443, # 5686 - 7663, 535, 1048, 1276, 1189, 2912, 2028, 3142, 1438, 1373, 2834, 2952, 1134, 2012, 7664, 4169, # 5702 - 1238, 2578, 3086, 1259, 7665, 700, 7666, 2953, 3143, 3668, 4170, 7667, 4171, 1146, 1875, 1906, # 5718 - 4444, 2601, 3967, 781, 2422, 132, 1589, 203, 147, 273, 2789, 2402, 898, 1786, 2154, 3968, # 5734 - 3969, 7668, 3792, 2790, 7669, 7670, 4445, 4446, 7671, 3208, 7672, 1635, 3793, 965, 7673, 1804, # 5750 - 2690, 1516, 3559, 1121, 1082, 1329, 3284, 3970, 1449, 3794, 65, 1128, 2835, 2913, 2759, 1590, # 5766 - 3795, 7674, 7675, 12, 2658, 45, 976, 2579, 3144, 4447, 517, 2528, 1013, 1037, 3209, 7676, # 5782 - 3796, 2836, 7677, 3797, 7678, 3452, 7679, 2602, 614, 1998, 2318, 3798, 3087, 2724, 2628, 7680, # 5798 - 2580, 4172, 599, 1269, 7681, 1810, 3669, 7682, 2691, 3088, 759, 1060, 489, 1805, 3351, 3285, # 5814 - 1358, 7683, 7684, 2386, 1387, 1215, 2629, 2252, 490, 7685, 7686, 4173, 1759, 2387, 2343, 7687, # 5830 - 4448, 3799, 1907, 3971, 2630, 1806, 3210, 4449, 3453, 3286, 2760, 2344, 874, 7688, 7689, 3454, # 5846 - 3670, 1858, 91, 2914, 3671, 3042, 3800, 4450, 7690, 3145, 3972, 2659, 7691, 3455, 1202, 1403, # 5862 - 3801, 2954, 2529, 1517, 2503, 4451, 3456, 2504, 7692, 4452, 7693, 2692, 1885, 1495, 1731, 3973, # 5878 - 2365, 4453, 7694, 2029, 7695, 7696, 3974, 2693, 1216, 237, 2581, 4174, 2319, 3975, 3802, 4454, # 5894 - 4455, 2694, 3560, 3457, 445, 4456, 7697, 7698, 7699, 7700, 2761, 61, 3976, 3672, 1822, 3977, # 5910 - 7701, 687, 2045, 935, 925, 405, 2660, 703, 1096, 1859, 2725, 4457, 3978, 1876, 1367, 2695, # 5926 - 3352, 918, 2105, 1781, 2476, 334, 3287, 1611, 1093, 4458, 564, 3146, 3458, 3673, 3353, 945, # 5942 - 2631, 2057, 4459, 7702, 1925, 872, 4175, 7703, 3459, 2696, 3089, 349, 4176, 3674, 3979, 4460, # 5958 - 3803, 4177, 3675, 2155, 3980, 4461, 4462, 4178, 4463, 2403, 2046, 782, 3981, 400, 251, 4179, # 5974 - 1624, 7704, 7705, 277, 3676, 299, 1265, 476, 1191, 3804, 2121, 4180, 4181, 1109, 205, 7706, # 5990 - 2582, 1000, 2156, 3561, 1860, 7707, 7708, 7709, 4464, 7710, 4465, 2565, 107, 2477, 2157, 3982, # 6006 - 3460, 3147, 7711, 1533, 541, 1301, 158, 753, 4182, 2872, 3562, 7712, 1696, 370, 1088, 4183, # 6022 - 4466, 3563, 579, 327, 440, 162, 2240, 269, 1937, 1374, 3461, 968, 3043, 56, 1396, 3090, # 6038 - 2106, 3288, 3354, 7713, 1926, 2158, 4467, 2998, 7714, 3564, 7715, 7716, 3677, 4468, 2478, 7717, # 6054 - 2791, 7718, 1650, 4469, 7719, 2603, 7720, 7721, 3983, 2661, 3355, 1149, 3356, 3984, 3805, 3985, # 6070 - 7722, 1076, 49, 7723, 951, 3211, 3289, 3290, 450, 2837, 920, 7724, 1811, 2792, 2366, 4184, # 6086 - 1908, 1138, 2367, 3806, 3462, 7725, 3212, 4470, 1909, 1147, 1518, 2423, 4471, 3807, 7726, 4472, # 6102 - 2388, 2604, 260, 1795, 3213, 7727, 7728, 3808, 3291, 708, 7729, 3565, 1704, 7730, 3566, 1351, # 6118 - 1618, 3357, 2999, 1886, 944, 4185, 3358, 4186, 3044, 3359, 4187, 7731, 3678, 422, 413, 1714, # 6134 - 3292, 500, 2058, 2345, 4188, 2479, 7732, 1344, 1910, 954, 7733, 1668, 7734, 7735, 3986, 2404, # 6150 - 4189, 3567, 3809, 4190, 7736, 2302, 1318, 2505, 3091, 133, 3092, 2873, 4473, 629, 31, 2838, # 6166 - 2697, 3810, 4474, 850, 949, 4475, 3987, 2955, 1732, 2088, 4191, 1496, 1852, 7737, 3988, 620, # 6182 - 3214, 981, 1242, 3679, 3360, 1619, 3680, 1643, 3293, 2139, 2452, 1970, 1719, 3463, 2168, 7738, # 6198 - 3215, 7739, 7740, 3361, 1828, 7741, 1277, 4476, 1565, 2047, 7742, 1636, 3568, 3093, 7743, 869, # 6214 - 2839, 655, 3811, 3812, 3094, 3989, 3000, 3813, 1310, 3569, 4477, 7744, 7745, 7746, 1733, 558, # 6230 - 4478, 3681, 335, 1549, 3045, 1756, 4192, 3682, 1945, 3464, 1829, 1291, 1192, 470, 2726, 2107, # 6246 - 2793, 913, 1054, 3990, 7747, 1027, 7748, 3046, 3991, 4479, 982, 2662, 3362, 3148, 3465, 3216, # 6262 - 3217, 1946, 2794, 7749, 571, 4480, 7750, 1830, 7751, 3570, 2583, 1523, 2424, 7752, 2089, 984, # 6278 - 4481, 3683, 1959, 7753, 3684, 852, 923, 2795, 3466, 3685, 969, 1519, 999, 2048, 2320, 1705, # 6294 - 7754, 3095, 615, 1662, 151, 597, 3992, 2405, 2321, 1049, 275, 4482, 3686, 4193, 568, 3687, # 6310 - 3571, 2480, 4194, 3688, 7755, 2425, 2270, 409, 3218, 7756, 1566, 2874, 3467, 1002, 769, 2840, # 6326 - 194, 2090, 3149, 3689, 2222, 3294, 4195, 628, 1505, 7757, 7758, 1763, 2177, 3001, 3993, 521, # 6342 - 1161, 2584, 1787, 2203, 2406, 4483, 3994, 1625, 4196, 4197, 412, 42, 3096, 464, 7759, 2632, # 6358 - 4484, 3363, 1760, 1571, 2875, 3468, 2530, 1219, 2204, 3814, 2633, 2140, 2368, 4485, 4486, 3295, # 6374 - 1651, 3364, 3572, 7760, 7761, 3573, 2481, 3469, 7762, 3690, 7763, 7764, 2271, 2091, 460, 7765, # 6390 - 4487, 7766, 3002, 962, 588, 3574, 289, 3219, 2634, 1116, 52, 7767, 3047, 1796, 7768, 7769, # 6406 - 7770, 1467, 7771, 1598, 1143, 3691, 4198, 1984, 1734, 1067, 4488, 1280, 3365, 465, 4489, 1572, # 6422 - 510, 7772, 1927, 2241, 1812, 1644, 3575, 7773, 4490, 3692, 7774, 7775, 2663, 1573, 1534, 7776, # 6438 - 7777, 4199, 536, 1807, 1761, 3470, 3815, 3150, 2635, 7778, 7779, 7780, 4491, 3471, 2915, 1911, # 6454 - 2796, 7781, 3296, 1122, 377, 3220, 7782, 360, 7783, 7784, 4200, 1529, 551, 7785, 2059, 3693, # 6470 - 1769, 2426, 7786, 2916, 4201, 3297, 3097, 2322, 2108, 2030, 4492, 1404, 136, 1468, 1479, 672, # 6486 - 1171, 3221, 2303, 271, 3151, 7787, 2762, 7788, 2049, 678, 2727, 865, 1947, 4493, 7789, 2013, # 6502 - 3995, 2956, 7790, 2728, 2223, 1397, 3048, 3694, 4494, 4495, 1735, 2917, 3366, 3576, 7791, 3816, # 6518 - 509, 2841, 2453, 2876, 3817, 7792, 7793, 3152, 3153, 4496, 4202, 2531, 4497, 2304, 1166, 1010, # 6534 - 552, 681, 1887, 7794, 7795, 2957, 2958, 3996, 1287, 1596, 1861, 3154, 358, 453, 736, 175, # 6550 - 478, 1117, 905, 1167, 1097, 7796, 1853, 1530, 7797, 1706, 7798, 2178, 3472, 2287, 3695, 3473, # 6566 - 3577, 4203, 2092, 4204, 7799, 3367, 1193, 2482, 4205, 1458, 2190, 2205, 1862, 1888, 1421, 3298, # 6582 - 2918, 3049, 2179, 3474, 595, 2122, 7800, 3997, 7801, 7802, 4206, 1707, 2636, 223, 3696, 1359, # 6598 - 751, 3098, 183, 3475, 7803, 2797, 3003, 419, 2369, 633, 704, 3818, 2389, 241, 7804, 7805, # 6614 - 7806, 838, 3004, 3697, 2272, 2763, 2454, 3819, 1938, 2050, 3998, 1309, 3099, 2242, 1181, 7807, # 6630 - 1136, 2206, 3820, 2370, 1446, 4207, 2305, 4498, 7808, 7809, 4208, 1055, 2605, 484, 3698, 7810, # 6646 - 3999, 625, 4209, 2273, 3368, 1499, 4210, 4000, 7811, 4001, 4211, 3222, 2274, 2275, 3476, 7812, # 6662 - 7813, 2764, 808, 2606, 3699, 3369, 4002, 4212, 3100, 2532, 526, 3370, 3821, 4213, 955, 7814, # 6678 - 1620, 4214, 2637, 2427, 7815, 1429, 3700, 1669, 1831, 994, 928, 7816, 3578, 1260, 7817, 7818, # 6694 - 7819, 1948, 2288, 741, 2919, 1626, 4215, 2729, 2455, 867, 1184, 362, 3371, 1392, 7820, 7821, # 6710 - 4003, 4216, 1770, 1736, 3223, 2920, 4499, 4500, 1928, 2698, 1459, 1158, 7822, 3050, 3372, 2877, # 6726 - 1292, 1929, 2506, 2842, 3701, 1985, 1187, 2071, 2014, 2607, 4217, 7823, 2566, 2507, 2169, 3702, # 6742 - 2483, 3299, 7824, 3703, 4501, 7825, 7826, 666, 1003, 3005, 1022, 3579, 4218, 7827, 4502, 1813, # 6758 - 2253, 574, 3822, 1603, 295, 1535, 705, 3823, 4219, 283, 858, 417, 7828, 7829, 3224, 4503, # 6774 - 4504, 3051, 1220, 1889, 1046, 2276, 2456, 4004, 1393, 1599, 689, 2567, 388, 4220, 7830, 2484, # 6790 - 802, 7831, 2798, 3824, 2060, 1405, 2254, 7832, 4505, 3825, 2109, 1052, 1345, 3225, 1585, 7833, # 6806 - 809, 7834, 7835, 7836, 575, 2730, 3477, 956, 1552, 1469, 1144, 2323, 7837, 2324, 1560, 2457, # 6822 - 3580, 3226, 4005, 616, 2207, 3155, 2180, 2289, 7838, 1832, 7839, 3478, 4506, 7840, 1319, 3704, # 6838 - 3705, 1211, 3581, 1023, 3227, 1293, 2799, 7841, 7842, 7843, 3826, 607, 2306, 3827, 762, 2878, # 6854 - 1439, 4221, 1360, 7844, 1485, 3052, 7845, 4507, 1038, 4222, 1450, 2061, 2638, 4223, 1379, 4508, # 6870 - 2585, 7846, 7847, 4224, 1352, 1414, 2325, 2921, 1172, 7848, 7849, 3828, 3829, 7850, 1797, 1451, # 6886 - 7851, 7852, 7853, 7854, 2922, 4006, 4007, 2485, 2346, 411, 4008, 4009, 3582, 3300, 3101, 4509, # 6902 - 1561, 2664, 1452, 4010, 1375, 7855, 7856, 47, 2959, 316, 7857, 1406, 1591, 2923, 3156, 7858, # 6918 - 1025, 2141, 3102, 3157, 354, 2731, 884, 2224, 4225, 2407, 508, 3706, 726, 3583, 996, 2428, # 6934 - 3584, 729, 7859, 392, 2191, 1453, 4011, 4510, 3707, 7860, 7861, 2458, 3585, 2608, 1675, 2800, # 6950 - 919, 2347, 2960, 2348, 1270, 4511, 4012, 73, 7862, 7863, 647, 7864, 3228, 2843, 2255, 1550, # 6966 - 1346, 3006, 7865, 1332, 883, 3479, 7866, 7867, 7868, 7869, 3301, 2765, 7870, 1212, 831, 1347, # 6982 - 4226, 4512, 2326, 3830, 1863, 3053, 720, 3831, 4513, 4514, 3832, 7871, 4227, 7872, 7873, 4515, # 6998 - 7874, 7875, 1798, 4516, 3708, 2609, 4517, 3586, 1645, 2371, 7876, 7877, 2924, 669, 2208, 2665, # 7014 - 2429, 7878, 2879, 7879, 7880, 1028, 3229, 7881, 4228, 2408, 7882, 2256, 1353, 7883, 7884, 4518, # 7030 - 3158, 518, 7885, 4013, 7886, 4229, 1960, 7887, 2142, 4230, 7888, 7889, 3007, 2349, 2350, 3833, # 7046 - 516, 1833, 1454, 4014, 2699, 4231, 4519, 2225, 2610, 1971, 1129, 3587, 7890, 2766, 7891, 2961, # 7062 - 1422, 577, 1470, 3008, 1524, 3373, 7892, 7893, 432, 4232, 3054, 3480, 7894, 2586, 1455, 2508, # 7078 - 2226, 1972, 1175, 7895, 1020, 2732, 4015, 3481, 4520, 7896, 2733, 7897, 1743, 1361, 3055, 3482, # 7094 - 2639, 4016, 4233, 4521, 2290, 895, 924, 4234, 2170, 331, 2243, 3056, 166, 1627, 3057, 1098, # 7110 - 7898, 1232, 2880, 2227, 3374, 4522, 657, 403, 1196, 2372, 542, 3709, 3375, 1600, 4235, 3483, # 7126 - 7899, 4523, 2767, 3230, 576, 530, 1362, 7900, 4524, 2533, 2666, 3710, 4017, 7901, 842, 3834, # 7142 - 7902, 2801, 2031, 1014, 4018, 213, 2700, 3376, 665, 621, 4236, 7903, 3711, 2925, 2430, 7904, # 7158 - 2431, 3302, 3588, 3377, 7905, 4237, 2534, 4238, 4525, 3589, 1682, 4239, 3484, 1380, 7906, 724, # 7174 - 2277, 600, 1670, 7907, 1337, 1233, 4526, 3103, 2244, 7908, 1621, 4527, 7909, 651, 4240, 7910, # 7190 - 1612, 4241, 2611, 7911, 2844, 7912, 2734, 2307, 3058, 7913, 716, 2459, 3059, 174, 1255, 2701, # 7206 - 4019, 3590, 548, 1320, 1398, 728, 4020, 1574, 7914, 1890, 1197, 3060, 4021, 7915, 3061, 3062, # 7222 - 3712, 3591, 3713, 747, 7916, 635, 4242, 4528, 7917, 7918, 7919, 4243, 7920, 7921, 4529, 7922, # 7238 - 3378, 4530, 2432, 451, 7923, 3714, 2535, 2072, 4244, 2735, 4245, 4022, 7924, 1764, 4531, 7925, # 7254 - 4246, 350, 7926, 2278, 2390, 2486, 7927, 4247, 4023, 2245, 1434, 4024, 488, 4532, 458, 4248, # 7270 - 4025, 3715, 771, 1330, 2391, 3835, 2568, 3159, 2159, 2409, 1553, 2667, 3160, 4249, 7928, 2487, # 7286 - 2881, 2612, 1720, 2702, 4250, 3379, 4533, 7929, 2536, 4251, 7930, 3231, 4252, 2768, 7931, 2015, # 7302 - 2736, 7932, 1155, 1017, 3716, 3836, 7933, 3303, 2308, 201, 1864, 4253, 1430, 7934, 4026, 7935, # 7318 - 7936, 7937, 7938, 7939, 4254, 1604, 7940, 414, 1865, 371, 2587, 4534, 4535, 3485, 2016, 3104, # 7334 - 4536, 1708, 960, 4255, 887, 389, 2171, 1536, 1663, 1721, 7941, 2228, 4027, 2351, 2926, 1580, # 7350 - 7942, 7943, 7944, 1744, 7945, 2537, 4537, 4538, 7946, 4539, 7947, 2073, 7948, 7949, 3592, 3380, # 7366 - 2882, 4256, 7950, 4257, 2640, 3381, 2802, 673, 2703, 2460, 709, 3486, 4028, 3593, 4258, 7951, # 7382 - 1148, 502, 634, 7952, 7953, 1204, 4540, 3594, 1575, 4541, 2613, 3717, 7954, 3718, 3105, 948, # 7398 - 3232, 121, 1745, 3837, 1110, 7955, 4259, 3063, 2509, 3009, 4029, 3719, 1151, 1771, 3838, 1488, # 7414 - 4030, 1986, 7956, 2433, 3487, 7957, 7958, 2093, 7959, 4260, 3839, 1213, 1407, 2803, 531, 2737, # 7430 - 2538, 3233, 1011, 1537, 7960, 2769, 4261, 3106, 1061, 7961, 3720, 3721, 1866, 2883, 7962, 2017, # 7446 - 120, 4262, 4263, 2062, 3595, 3234, 2309, 3840, 2668, 3382, 1954, 4542, 7963, 7964, 3488, 1047, # 7462 - 2704, 1266, 7965, 1368, 4543, 2845, 649, 3383, 3841, 2539, 2738, 1102, 2846, 2669, 7966, 7967, # 7478 - 1999, 7968, 1111, 3596, 2962, 7969, 2488, 3842, 3597, 2804, 1854, 3384, 3722, 7970, 7971, 3385, # 7494 - 2410, 2884, 3304, 3235, 3598, 7972, 2569, 7973, 3599, 2805, 4031, 1460, 856, 7974, 3600, 7975, # 7510 - 2885, 2963, 7976, 2886, 3843, 7977, 4264, 632, 2510, 875, 3844, 1697, 3845, 2291, 7978, 7979, # 7526 - 4544, 3010, 1239, 580, 4545, 4265, 7980, 914, 936, 2074, 1190, 4032, 1039, 2123, 7981, 7982, # 7542 - 7983, 3386, 1473, 7984, 1354, 4266, 3846, 7985, 2172, 3064, 4033, 915, 3305, 4267, 4268, 3306, # 7558 - 1605, 1834, 7986, 2739, 398, 3601, 4269, 3847, 4034, 328, 1912, 2847, 4035, 3848, 1331, 4270, # 7574 - 3011, 937, 4271, 7987, 3602, 4036, 4037, 3387, 2160, 4546, 3388, 524, 742, 538, 3065, 1012, # 7590 - 7988, 7989, 3849, 2461, 7990, 658, 1103, 225, 3850, 7991, 7992, 4547, 7993, 4548, 7994, 3236, # 7606 - 1243, 7995, 4038, 963, 2246, 4549, 7996, 2705, 3603, 3161, 7997, 7998, 2588, 2327, 7999, 4550, # 7622 - 8000, 8001, 8002, 3489, 3307, 957, 3389, 2540, 2032, 1930, 2927, 2462, 870, 2018, 3604, 1746, # 7638 - 2770, 2771, 2434, 2463, 8003, 3851, 8004, 3723, 3107, 3724, 3490, 3390, 3725, 8005, 1179, 3066, # 7654 - 8006, 3162, 2373, 4272, 3726, 2541, 3163, 3108, 2740, 4039, 8007, 3391, 1556, 2542, 2292, 977, # 7670 - 2887, 2033, 4040, 1205, 3392, 8008, 1765, 3393, 3164, 2124, 1271, 1689, 714, 4551, 3491, 8009, # 7686 - 2328, 3852, 533, 4273, 3605, 2181, 617, 8010, 2464, 3308, 3492, 2310, 8011, 8012, 3165, 8013, # 7702 - 8014, 3853, 1987, 618, 427, 2641, 3493, 3394, 8015, 8016, 1244, 1690, 8017, 2806, 4274, 4552, # 7718 - 8018, 3494, 8019, 8020, 2279, 1576, 473, 3606, 4275, 3395, 972, 8021, 3607, 8022, 3067, 8023, # 7734 - 8024, 4553, 4554, 8025, 3727, 4041, 4042, 8026, 153, 4555, 356, 8027, 1891, 2888, 4276, 2143, # 7750 - 408, 803, 2352, 8028, 3854, 8029, 4277, 1646, 2570, 2511, 4556, 4557, 3855, 8030, 3856, 4278, # 7766 - 8031, 2411, 3396, 752, 8032, 8033, 1961, 2964, 8034, 746, 3012, 2465, 8035, 4279, 3728, 698, # 7782 - 4558, 1892, 4280, 3608, 2543, 4559, 3609, 3857, 8036, 3166, 3397, 8037, 1823, 1302, 4043, 2706, # 7798 - 3858, 1973, 4281, 8038, 4282, 3167, 823, 1303, 1288, 1236, 2848, 3495, 4044, 3398, 774, 3859, # 7814 - 8039, 1581, 4560, 1304, 2849, 3860, 4561, 8040, 2435, 2161, 1083, 3237, 4283, 4045, 4284, 344, # 7830 - 1173, 288, 2311, 454, 1683, 8041, 8042, 1461, 4562, 4046, 2589, 8043, 8044, 4563, 985, 894, # 7846 - 8045, 3399, 3168, 8046, 1913, 2928, 3729, 1988, 8047, 2110, 1974, 8048, 4047, 8049, 2571, 1194, # 7862 - 425, 8050, 4564, 3169, 1245, 3730, 4285, 8051, 8052, 2850, 8053, 636, 4565, 1855, 3861, 760, # 7878 - 1799, 8054, 4286, 2209, 1508, 4566, 4048, 1893, 1684, 2293, 8055, 8056, 8057, 4287, 4288, 2210, # 7894 - 479, 8058, 8059, 832, 8060, 4049, 2489, 8061, 2965, 2490, 3731, 990, 3109, 627, 1814, 2642, # 7910 - 4289, 1582, 4290, 2125, 2111, 3496, 4567, 8062, 799, 4291, 3170, 8063, 4568, 2112, 1737, 3013, # 7926 - 1018, 543, 754, 4292, 3309, 1676, 4569, 4570, 4050, 8064, 1489, 8065, 3497, 8066, 2614, 2889, # 7942 - 4051, 8067, 8068, 2966, 8069, 8070, 8071, 8072, 3171, 4571, 4572, 2182, 1722, 8073, 3238, 3239, # 7958 - 1842, 3610, 1715, 481, 365, 1975, 1856, 8074, 8075, 1962, 2491, 4573, 8076, 2126, 3611, 3240, # 7974 - 433, 1894, 2063, 2075, 8077, 602, 2741, 8078, 8079, 8080, 8081, 8082, 3014, 1628, 3400, 8083, # 7990 - 3172, 4574, 4052, 2890, 4575, 2512, 8084, 2544, 2772, 8085, 8086, 8087, 3310, 4576, 2891, 8088, # 8006 - 4577, 8089, 2851, 4578, 4579, 1221, 2967, 4053, 2513, 8090, 8091, 8092, 1867, 1989, 8093, 8094, # 8022 - 8095, 1895, 8096, 8097, 4580, 1896, 4054, 318, 8098, 2094, 4055, 4293, 8099, 8100, 485, 8101, # 8038 - 938, 3862, 553, 2670, 116, 8102, 3863, 3612, 8103, 3498, 2671, 2773, 3401, 3311, 2807, 8104, # 8054 - 3613, 2929, 4056, 1747, 2930, 2968, 8105, 8106, 207, 8107, 8108, 2672, 4581, 2514, 8109, 3015, # 8070 - 890, 3614, 3864, 8110, 1877, 3732, 3402, 8111, 2183, 2353, 3403, 1652, 8112, 8113, 8114, 941, # 8086 - 2294, 208, 3499, 4057, 2019, 330, 4294, 3865, 2892, 2492, 3733, 4295, 8115, 8116, 8117, 8118, # 8102 -) -# fmt: on diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/euctwprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/euctwprober.py deleted file mode 100644 index a37ab18..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/euctwprober.py +++ /dev/null @@ -1,47 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 .chardistribution import EUCTWDistributionAnalysis -from .codingstatemachine import CodingStateMachine -from .mbcharsetprober import MultiByteCharSetProber -from .mbcssm import EUCTW_SM_MODEL - - -class EUCTWProber(MultiByteCharSetProber): - def __init__(self) -> None: - super().__init__() - self.coding_sm = CodingStateMachine(EUCTW_SM_MODEL) - self.distribution_analyzer = EUCTWDistributionAnalysis() - self.reset() - - @property - def charset_name(self) -> str: - return "EUC-TW" - - @property - def language(self) -> str: - return "Taiwan" diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py b/myenv/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py deleted file mode 100644 index b32bfc7..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py +++ /dev/null @@ -1,284 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Communicator client code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 ######################### - -# GB2312 most frequently used character table -# -# Char to FreqOrder table , from hz6763 - -# 512 --> 0.79 -- 0.79 -# 1024 --> 0.92 -- 0.13 -# 2048 --> 0.98 -- 0.06 -# 6768 --> 1.00 -- 0.02 -# -# Ideal Distribution Ratio = 0.79135/(1-0.79135) = 3.79 -# Random Distribution Ration = 512 / (3755 - 512) = 0.157 -# -# Typical Distribution Ratio about 25% of Ideal one, still much higher that RDR - -GB2312_TYPICAL_DISTRIBUTION_RATIO = 0.9 - -GB2312_TABLE_SIZE = 3760 - -# fmt: off -GB2312_CHAR_TO_FREQ_ORDER = ( -1671, 749,1443,2364,3924,3807,2330,3921,1704,3463,2691,1511,1515, 572,3191,2205, -2361, 224,2558, 479,1711, 963,3162, 440,4060,1905,2966,2947,3580,2647,3961,3842, -2204, 869,4207, 970,2678,5626,2944,2956,1479,4048, 514,3595, 588,1346,2820,3409, - 249,4088,1746,1873,2047,1774, 581,1813, 358,1174,3590,1014,1561,4844,2245, 670, -1636,3112, 889,1286, 953, 556,2327,3060,1290,3141, 613, 185,3477,1367, 850,3820, -1715,2428,2642,2303,2732,3041,2562,2648,3566,3946,1349, 388,3098,2091,1360,3585, - 152,1687,1539, 738,1559, 59,1232,2925,2267,1388,1249,1741,1679,2960, 151,1566, -1125,1352,4271, 924,4296, 385,3166,4459, 310,1245,2850, 70,3285,2729,3534,3575, -2398,3298,3466,1960,2265, 217,3647, 864,1909,2084,4401,2773,1010,3269,5152, 853, -3051,3121,1244,4251,1895, 364,1499,1540,2313,1180,3655,2268, 562, 715,2417,3061, - 544, 336,3768,2380,1752,4075, 950, 280,2425,4382, 183,2759,3272, 333,4297,2155, -1688,2356,1444,1039,4540, 736,1177,3349,2443,2368,2144,2225, 565, 196,1482,3406, - 927,1335,4147, 692, 878,1311,1653,3911,3622,1378,4200,1840,2969,3149,2126,1816, -2534,1546,2393,2760, 737,2494, 13, 447, 245,2747, 38,2765,2129,2589,1079, 606, - 360, 471,3755,2890, 404, 848, 699,1785,1236, 370,2221,1023,3746,2074,2026,2023, -2388,1581,2119, 812,1141,3091,2536,1519, 804,2053, 406,1596,1090, 784, 548,4414, -1806,2264,2936,1100, 343,4114,5096, 622,3358, 743,3668,1510,1626,5020,3567,2513, -3195,4115,5627,2489,2991, 24,2065,2697,1087,2719, 48,1634, 315, 68, 985,2052, - 198,2239,1347,1107,1439, 597,2366,2172, 871,3307, 919,2487,2790,1867, 236,2570, -1413,3794, 906,3365,3381,1701,1982,1818,1524,2924,1205, 616,2586,2072,2004, 575, - 253,3099, 32,1365,1182, 197,1714,2454,1201, 554,3388,3224,2748, 756,2587, 250, -2567,1507,1517,3529,1922,2761,2337,3416,1961,1677,2452,2238,3153, 615, 911,1506, -1474,2495,1265,1906,2749,3756,3280,2161, 898,2714,1759,3450,2243,2444, 563, 26, -3286,2266,3769,3344,2707,3677, 611,1402, 531,1028,2871,4548,1375, 261,2948, 835, -1190,4134, 353, 840,2684,1900,3082,1435,2109,1207,1674, 329,1872,2781,4055,2686, -2104, 608,3318,2423,2957,2768,1108,3739,3512,3271,3985,2203,1771,3520,1418,2054, -1681,1153, 225,1627,2929, 162,2050,2511,3687,1954, 124,1859,2431,1684,3032,2894, - 585,4805,3969,2869,2704,2088,2032,2095,3656,2635,4362,2209, 256, 518,2042,2105, -3777,3657, 643,2298,1148,1779, 190, 989,3544, 414, 11,2135,2063,2979,1471, 403, -3678, 126, 770,1563, 671,2499,3216,2877, 600,1179, 307,2805,4937,1268,1297,2694, - 252,4032,1448,1494,1331,1394, 127,2256, 222,1647,1035,1481,3056,1915,1048, 873, -3651, 210, 33,1608,2516, 200,1520, 415, 102, 0,3389,1287, 817, 91,3299,2940, - 836,1814, 549,2197,1396,1669,2987,3582,2297,2848,4528,1070, 687, 20,1819, 121, -1552,1364,1461,1968,2617,3540,2824,2083, 177, 948,4938,2291, 110,4549,2066, 648, -3359,1755,2110,2114,4642,4845,1693,3937,3308,1257,1869,2123, 208,1804,3159,2992, -2531,2549,3361,2418,1350,2347,2800,2568,1291,2036,2680, 72, 842,1990, 212,1233, -1154,1586, 75,2027,3410,4900,1823,1337,2710,2676, 728,2810,1522,3026,4995, 157, - 755,1050,4022, 710, 785,1936,2194,2085,1406,2777,2400, 150,1250,4049,1206, 807, -1910, 534, 529,3309,1721,1660, 274, 39,2827, 661,2670,1578, 925,3248,3815,1094, -4278,4901,4252, 41,1150,3747,2572,2227,4501,3658,4902,3813,3357,3617,2884,2258, - 887, 538,4187,3199,1294,2439,3042,2329,2343,2497,1255, 107, 543,1527, 521,3478, -3568, 194,5062, 15, 961,3870,1241,1192,2664, 66,5215,3260,2111,1295,1127,2152, -3805,4135, 901,1164,1976, 398,1278, 530,1460, 748, 904,1054,1966,1426, 53,2909, - 509, 523,2279,1534, 536,1019, 239,1685, 460,2353, 673,1065,2401,3600,4298,2272, -1272,2363, 284,1753,3679,4064,1695, 81, 815,2677,2757,2731,1386, 859, 500,4221, -2190,2566, 757,1006,2519,2068,1166,1455, 337,2654,3203,1863,1682,1914,3025,1252, -1409,1366, 847, 714,2834,2038,3209, 964,2970,1901, 885,2553,1078,1756,3049, 301, -1572,3326, 688,2130,1996,2429,1805,1648,2930,3421,2750,3652,3088, 262,1158,1254, - 389,1641,1812, 526,1719, 923,2073,1073,1902, 468, 489,4625,1140, 857,2375,3070, -3319,2863, 380, 116,1328,2693,1161,2244, 273,1212,1884,2769,3011,1775,1142, 461, -3066,1200,2147,2212, 790, 702,2695,4222,1601,1058, 434,2338,5153,3640, 67,2360, -4099,2502, 618,3472,1329, 416,1132, 830,2782,1807,2653,3211,3510,1662, 192,2124, - 296,3979,1739,1611,3684, 23, 118, 324, 446,1239,1225, 293,2520,3814,3795,2535, -3116, 17,1074, 467,2692,2201, 387,2922, 45,1326,3055,1645,3659,2817, 958, 243, -1903,2320,1339,2825,1784,3289, 356, 576, 865,2315,2381,3377,3916,1088,3122,1713, -1655, 935, 628,4689,1034,1327, 441, 800, 720, 894,1979,2183,1528,5289,2702,1071, -4046,3572,2399,1571,3281, 79, 761,1103, 327, 134, 758,1899,1371,1615, 879, 442, - 215,2605,2579, 173,2048,2485,1057,2975,3317,1097,2253,3801,4263,1403,1650,2946, - 814,4968,3487,1548,2644,1567,1285, 2, 295,2636, 97, 946,3576, 832, 141,4257, -3273, 760,3821,3521,3156,2607, 949,1024,1733,1516,1803,1920,2125,2283,2665,3180, -1501,2064,3560,2171,1592, 803,3518,1416, 732,3897,4258,1363,1362,2458, 119,1427, - 602,1525,2608,1605,1639,3175, 694,3064, 10, 465, 76,2000,4846,4208, 444,3781, -1619,3353,2206,1273,3796, 740,2483, 320,1723,2377,3660,2619,1359,1137,1762,1724, -2345,2842,1850,1862, 912, 821,1866, 612,2625,1735,2573,3369,1093, 844, 89, 937, - 930,1424,3564,2413,2972,1004,3046,3019,2011, 711,3171,1452,4178, 428, 801,1943, - 432, 445,2811, 206,4136,1472, 730, 349, 73, 397,2802,2547, 998,1637,1167, 789, - 396,3217, 154,1218, 716,1120,1780,2819,4826,1931,3334,3762,2139,1215,2627, 552, -3664,3628,3232,1405,2383,3111,1356,2652,3577,3320,3101,1703, 640,1045,1370,1246, -4996, 371,1575,2436,1621,2210, 984,4033,1734,2638, 16,4529, 663,2755,3255,1451, -3917,2257,1253,1955,2234,1263,2951, 214,1229, 617, 485, 359,1831,1969, 473,2310, - 750,2058, 165, 80,2864,2419, 361,4344,2416,2479,1134, 796,3726,1266,2943, 860, -2715, 938, 390,2734,1313,1384, 248, 202, 877,1064,2854, 522,3907, 279,1602, 297, -2357, 395,3740, 137,2075, 944,4089,2584,1267,3802, 62,1533,2285, 178, 176, 780, -2440, 201,3707, 590, 478,1560,4354,2117,1075, 30, 74,4643,4004,1635,1441,2745, - 776,2596, 238,1077,1692,1912,2844, 605, 499,1742,3947, 241,3053, 980,1749, 936, -2640,4511,2582, 515,1543,2162,5322,2892,2993, 890,2148,1924, 665,1827,3581,1032, - 968,3163, 339,1044,1896, 270, 583,1791,1720,4367,1194,3488,3669, 43,2523,1657, - 163,2167, 290,1209,1622,3378, 550, 634,2508,2510, 695,2634,2384,2512,1476,1414, - 220,1469,2341,2138,2852,3183,2900,4939,2865,3502,1211,3680, 854,3227,1299,2976, -3172, 186,2998,1459, 443,1067,3251,1495, 321,1932,3054, 909, 753,1410,1828, 436, -2441,1119,1587,3164,2186,1258, 227, 231,1425,1890,3200,3942, 247, 959, 725,5254, -2741, 577,2158,2079, 929, 120, 174, 838,2813, 591,1115, 417,2024, 40,3240,1536, -1037, 291,4151,2354, 632,1298,2406,2500,3535,1825,1846,3451, 205,1171, 345,4238, - 18,1163, 811, 685,2208,1217, 425,1312,1508,1175,4308,2552,1033, 587,1381,3059, -2984,3482, 340,1316,4023,3972, 792,3176, 519, 777,4690, 918, 933,4130,2981,3741, - 90,3360,2911,2200,5184,4550, 609,3079,2030, 272,3379,2736, 363,3881,1130,1447, - 286, 779, 357,1169,3350,3137,1630,1220,2687,2391, 747,1277,3688,2618,2682,2601, -1156,3196,5290,4034,3102,1689,3596,3128, 874, 219,2783, 798, 508,1843,2461, 269, -1658,1776,1392,1913,2983,3287,2866,2159,2372, 829,4076, 46,4253,2873,1889,1894, - 915,1834,1631,2181,2318, 298, 664,2818,3555,2735, 954,3228,3117, 527,3511,2173, - 681,2712,3033,2247,2346,3467,1652, 155,2164,3382, 113,1994, 450, 899, 494, 994, -1237,2958,1875,2336,1926,3727, 545,1577,1550, 633,3473, 204,1305,3072,2410,1956, -2471, 707,2134, 841,2195,2196,2663,3843,1026,4940, 990,3252,4997, 368,1092, 437, -3212,3258,1933,1829, 675,2977,2893, 412, 943,3723,4644,3294,3283,2230,2373,5154, -2389,2241,2661,2323,1404,2524, 593, 787, 677,3008,1275,2059, 438,2709,2609,2240, -2269,2246,1446, 36,1568,1373,3892,1574,2301,1456,3962, 693,2276,5216,2035,1143, -2720,1919,1797,1811,2763,4137,2597,1830,1699,1488,1198,2090, 424,1694, 312,3634, -3390,4179,3335,2252,1214, 561,1059,3243,2295,2561, 975,5155,2321,2751,3772, 472, -1537,3282,3398,1047,2077,2348,2878,1323,3340,3076, 690,2906, 51, 369, 170,3541, -1060,2187,2688,3670,2541,1083,1683, 928,3918, 459, 109,4427, 599,3744,4286, 143, -2101,2730,2490, 82,1588,3036,2121, 281,1860, 477,4035,1238,2812,3020,2716,3312, -1530,2188,2055,1317, 843, 636,1808,1173,3495, 649, 181,1002, 147,3641,1159,2414, -3750,2289,2795, 813,3123,2610,1136,4368, 5,3391,4541,2174, 420, 429,1728, 754, -1228,2115,2219, 347,2223,2733, 735,1518,3003,2355,3134,1764,3948,3329,1888,2424, -1001,1234,1972,3321,3363,1672,1021,1450,1584, 226, 765, 655,2526,3404,3244,2302, -3665, 731, 594,2184, 319,1576, 621, 658,2656,4299,2099,3864,1279,2071,2598,2739, - 795,3086,3699,3908,1707,2352,2402,1382,3136,2475,1465,4847,3496,3865,1085,3004, -2591,1084, 213,2287,1963,3565,2250, 822, 793,4574,3187,1772,1789,3050, 595,1484, -1959,2770,1080,2650, 456, 422,2996, 940,3322,4328,4345,3092,2742, 965,2784, 739, -4124, 952,1358,2498,2949,2565, 332,2698,2378, 660,2260,2473,4194,3856,2919, 535, -1260,2651,1208,1428,1300,1949,1303,2942, 433,2455,2450,1251,1946, 614,1269, 641, -1306,1810,2737,3078,2912, 564,2365,1419,1415,1497,4460,2367,2185,1379,3005,1307, -3218,2175,1897,3063, 682,1157,4040,4005,1712,1160,1941,1399, 394, 402,2952,1573, -1151,2986,2404, 862, 299,2033,1489,3006, 346, 171,2886,3401,1726,2932, 168,2533, - 47,2507,1030,3735,1145,3370,1395,1318,1579,3609,4560,2857,4116,1457,2529,1965, - 504,1036,2690,2988,2405, 745,5871, 849,2397,2056,3081, 863,2359,3857,2096, 99, -1397,1769,2300,4428,1643,3455,1978,1757,3718,1440, 35,4879,3742,1296,4228,2280, - 160,5063,1599,2013, 166, 520,3479,1646,3345,3012, 490,1937,1545,1264,2182,2505, -1096,1188,1369,1436,2421,1667,2792,2460,1270,2122, 727,3167,2143, 806,1706,1012, -1800,3037, 960,2218,1882, 805, 139,2456,1139,1521, 851,1052,3093,3089, 342,2039, - 744,5097,1468,1502,1585,2087, 223, 939, 326,2140,2577, 892,2481,1623,4077, 982, -3708, 135,2131, 87,2503,3114,2326,1106, 876,1616, 547,2997,2831,2093,3441,4530, -4314, 9,3256,4229,4148, 659,1462,1986,1710,2046,2913,2231,4090,4880,5255,3392, -3274,1368,3689,4645,1477, 705,3384,3635,1068,1529,2941,1458,3782,1509, 100,1656, -2548, 718,2339, 408,1590,2780,3548,1838,4117,3719,1345,3530, 717,3442,2778,3220, -2898,1892,4590,3614,3371,2043,1998,1224,3483, 891, 635, 584,2559,3355, 733,1766, -1729,1172,3789,1891,2307, 781,2982,2271,1957,1580,5773,2633,2005,4195,3097,1535, -3213,1189,1934,5693,3262, 586,3118,1324,1598, 517,1564,2217,1868,1893,4445,3728, -2703,3139,1526,1787,1992,3882,2875,1549,1199,1056,2224,1904,2711,5098,4287, 338, -1993,3129,3489,2689,1809,2815,1997, 957,1855,3898,2550,3275,3057,1105,1319, 627, -1505,1911,1883,3526, 698,3629,3456,1833,1431, 746, 77,1261,2017,2296,1977,1885, - 125,1334,1600, 525,1798,1109,2222,1470,1945, 559,2236,1186,3443,2476,1929,1411, -2411,3135,1777,3372,2621,1841,1613,3229, 668,1430,1839,2643,2916, 195,1989,2671, -2358,1387, 629,3205,2293,5256,4439, 123,1310, 888,1879,4300,3021,3605,1003,1162, -3192,2910,2010, 140,2395,2859, 55,1082,2012,2901, 662, 419,2081,1438, 680,2774, -4654,3912,1620,1731,1625,5035,4065,2328, 512,1344, 802,5443,2163,2311,2537, 524, -3399, 98,1155,2103,1918,2606,3925,2816,1393,2465,1504,3773,2177,3963,1478,4346, - 180,1113,4655,3461,2028,1698, 833,2696,1235,1322,1594,4408,3623,3013,3225,2040, -3022, 541,2881, 607,3632,2029,1665,1219, 639,1385,1686,1099,2803,3231,1938,3188, -2858, 427, 676,2772,1168,2025, 454,3253,2486,3556, 230,1950, 580, 791,1991,1280, -1086,1974,2034, 630, 257,3338,2788,4903,1017, 86,4790, 966,2789,1995,1696,1131, - 259,3095,4188,1308, 179,1463,5257, 289,4107,1248, 42,3413,1725,2288, 896,1947, - 774,4474,4254, 604,3430,4264, 392,2514,2588, 452, 237,1408,3018, 988,4531,1970, -3034,3310, 540,2370,1562,1288,2990, 502,4765,1147, 4,1853,2708, 207, 294,2814, -4078,2902,2509, 684, 34,3105,3532,2551, 644, 709,2801,2344, 573,1727,3573,3557, -2021,1081,3100,4315,2100,3681, 199,2263,1837,2385, 146,3484,1195,2776,3949, 997, -1939,3973,1008,1091,1202,1962,1847,1149,4209,5444,1076, 493, 117,5400,2521, 972, -1490,2934,1796,4542,2374,1512,2933,2657, 413,2888,1135,2762,2314,2156,1355,2369, - 766,2007,2527,2170,3124,2491,2593,2632,4757,2437, 234,3125,3591,1898,1750,1376, -1942,3468,3138, 570,2127,2145,3276,4131, 962, 132,1445,4196, 19, 941,3624,3480, -3366,1973,1374,4461,3431,2629, 283,2415,2275, 808,2887,3620,2112,2563,1353,3610, - 955,1089,3103,1053, 96, 88,4097, 823,3808,1583, 399, 292,4091,3313, 421,1128, - 642,4006, 903,2539,1877,2082, 596, 29,4066,1790, 722,2157, 130, 995,1569, 769, -1485, 464, 513,2213, 288,1923,1101,2453,4316, 133, 486,2445, 50, 625, 487,2207, - 57, 423, 481,2962, 159,3729,1558, 491, 303, 482, 501, 240,2837, 112,3648,2392, -1783, 362, 8,3433,3422, 610,2793,3277,1390,1284,1654, 21,3823, 734, 367, 623, - 193, 287, 374,1009,1483, 816, 476, 313,2255,2340,1262,2150,2899,1146,2581, 782, -2116,1659,2018,1880, 255,3586,3314,1110,2867,2137,2564, 986,2767,5185,2006, 650, - 158, 926, 762, 881,3157,2717,2362,3587, 306,3690,3245,1542,3077,2427,1691,2478, -2118,2985,3490,2438, 539,2305, 983, 129,1754, 355,4201,2386, 827,2923, 104,1773, -2838,2771, 411,2905,3919, 376, 767, 122,1114, 828,2422,1817,3506, 266,3460,1007, -1609,4998, 945,2612,4429,2274, 726,1247,1964,2914,2199,2070,4002,4108, 657,3323, -1422, 579, 455,2764,4737,1222,2895,1670, 824,1223,1487,2525, 558, 861,3080, 598, -2659,2515,1967, 752,2583,2376,2214,4180, 977, 704,2464,4999,2622,4109,1210,2961, - 819,1541, 142,2284, 44, 418, 457,1126,3730,4347,4626,1644,1876,3671,1864, 302, -1063,5694, 624, 723,1984,3745,1314,1676,2488,1610,1449,3558,3569,2166,2098, 409, -1011,2325,3704,2306, 818,1732,1383,1824,1844,3757, 999,2705,3497,1216,1423,2683, -2426,2954,2501,2726,2229,1475,2554,5064,1971,1794,1666,2014,1343, 783, 724, 191, -2434,1354,2220,5065,1763,2752,2472,4152, 131, 175,2885,3434, 92,1466,4920,2616, -3871,3872,3866, 128,1551,1632, 669,1854,3682,4691,4125,1230, 188,2973,3290,1302, -1213, 560,3266, 917, 763,3909,3249,1760, 868,1958, 764,1782,2097, 145,2277,3774, -4462, 64,1491,3062, 971,2132,3606,2442, 221,1226,1617, 218, 323,1185,3207,3147, - 571, 619,1473,1005,1744,2281, 449,1887,2396,3685, 275, 375,3816,1743,3844,3731, - 845,1983,2350,4210,1377, 773, 967,3499,3052,3743,2725,4007,1697,1022,3943,1464, -3264,2855,2722,1952,1029,2839,2467, 84,4383,2215, 820,1391,2015,2448,3672, 377, -1948,2168, 797,2545,3536,2578,2645, 94,2874,1678, 405,1259,3071, 771, 546,1315, - 470,1243,3083, 895,2468, 981, 969,2037, 846,4181, 653,1276,2928, 14,2594, 557, -3007,2474, 156, 902,1338,1740,2574, 537,2518, 973,2282,2216,2433,1928, 138,2903, -1293,2631,1612, 646,3457, 839,2935, 111, 496,2191,2847, 589,3186, 149,3994,2060, -4031,2641,4067,3145,1870, 37,3597,2136,1025,2051,3009,3383,3549,1121,1016,3261, -1301, 251,2446,2599,2153, 872,3246, 637, 334,3705, 831, 884, 921,3065,3140,4092, -2198,1944, 246,2964, 108,2045,1152,1921,2308,1031, 203,3173,4170,1907,3890, 810, -1401,2003,1690, 506, 647,1242,2828,1761,1649,3208,2249,1589,3709,2931,5156,1708, - 498, 666,2613, 834,3817,1231, 184,2851,1124, 883,3197,2261,3710,1765,1553,2658, -1178,2639,2351, 93,1193, 942,2538,2141,4402, 235,1821, 870,1591,2192,1709,1871, -3341,1618,4126,2595,2334, 603, 651, 69, 701, 268,2662,3411,2555,1380,1606, 503, - 448, 254,2371,2646, 574,1187,2309,1770, 322,2235,1292,1801, 305, 566,1133, 229, -2067,2057, 706, 167, 483,2002,2672,3295,1820,3561,3067, 316, 378,2746,3452,1112, - 136,1981, 507,1651,2917,1117, 285,4591, 182,2580,3522,1304, 335,3303,1835,2504, -1795,1792,2248, 674,1018,2106,2449,1857,2292,2845, 976,3047,1781,2600,2727,1389, -1281, 52,3152, 153, 265,3950, 672,3485,3951,4463, 430,1183, 365, 278,2169, 27, -1407,1336,2304, 209,1340,1730,2202,1852,2403,2883, 979,1737,1062, 631,2829,2542, -3876,2592, 825,2086,2226,3048,3625, 352,1417,3724, 542, 991, 431,1351,3938,1861, -2294, 826,1361,2927,3142,3503,1738, 463,2462,2723, 582,1916,1595,2808, 400,3845, -3891,2868,3621,2254, 58,2492,1123, 910,2160,2614,1372,1603,1196,1072,3385,1700, -3267,1980, 696, 480,2430, 920, 799,1570,2920,1951,2041,4047,2540,1321,4223,2469, -3562,2228,1271,2602, 401,2833,3351,2575,5157, 907,2312,1256, 410, 263,3507,1582, - 996, 678,1849,2316,1480, 908,3545,2237, 703,2322, 667,1826,2849,1531,2604,2999, -2407,3146,2151,2630,1786,3711, 469,3542, 497,3899,2409, 858, 837,4446,3393,1274, - 786, 620,1845,2001,3311, 484, 308,3367,1204,1815,3691,2332,1532,2557,1842,2020, -2724,1927,2333,4440, 567, 22,1673,2728,4475,1987,1858,1144,1597, 101,1832,3601, - 12, 974,3783,4391, 951,1412, 1,3720, 453,4608,4041, 528,1041,1027,3230,2628, -1129, 875,1051,3291,1203,2262,1069,2860,2799,2149,2615,3278, 144,1758,3040, 31, - 475,1680, 366,2685,3184, 311,1642,4008,2466,5036,1593,1493,2809, 216,1420,1668, - 233, 304,2128,3284, 232,1429,1768,1040,2008,3407,2740,2967,2543, 242,2133, 778, -1565,2022,2620, 505,2189,2756,1098,2273, 372,1614, 708, 553,2846,2094,2278, 169, -3626,2835,4161, 228,2674,3165, 809,1454,1309, 466,1705,1095, 900,3423, 880,2667, -3751,5258,2317,3109,2571,4317,2766,1503,1342, 866,4447,1118, 63,2076, 314,1881, -1348,1061, 172, 978,3515,1747, 532, 511,3970, 6, 601, 905,2699,3300,1751, 276, -1467,3725,2668, 65,4239,2544,2779,2556,1604, 578,2451,1802, 992,2331,2624,1320, -3446, 713,1513,1013, 103,2786,2447,1661, 886,1702, 916, 654,3574,2031,1556, 751, -2178,2821,2179,1498,1538,2176, 271, 914,2251,2080,1325, 638,1953,2937,3877,2432, -2754, 95,3265,1716, 260,1227,4083, 775, 106,1357,3254, 426,1607, 555,2480, 772, -1985, 244,2546, 474, 495,1046,2611,1851,2061, 71,2089,1675,2590, 742,3758,2843, -3222,1433, 267,2180,2576,2826,2233,2092,3913,2435, 956,1745,3075, 856,2113,1116, - 451, 3,1988,2896,1398, 993,2463,1878,2049,1341,2718,2721,2870,2108, 712,2904, -4363,2753,2324, 277,2872,2349,2649, 384, 987, 435, 691,3000, 922, 164,3939, 652, -1500,1184,4153,2482,3373,2165,4848,2335,3775,3508,3154,2806,2830,1554,2102,1664, -2530,1434,2408, 893,1547,2623,3447,2832,2242,2532,3169,2856,3223,2078, 49,3770, -3469, 462, 318, 656,2259,3250,3069, 679,1629,2758, 344,1138,1104,3120,1836,1283, -3115,2154,1437,4448, 934, 759,1999, 794,2862,1038, 533,2560,1722,2342, 855,2626, -1197,1663,4476,3127, 85,4240,2528, 25,1111,1181,3673, 407,3470,4561,2679,2713, - 768,1925,2841,3986,1544,1165, 932, 373,1240,2146,1930,2673, 721,4766, 354,4333, - 391,2963, 187, 61,3364,1442,1102, 330,1940,1767, 341,3809,4118, 393,2496,2062, -2211, 105, 331, 300, 439, 913,1332, 626, 379,3304,1557, 328, 689,3952, 309,1555, - 931, 317,2517,3027, 325, 569, 686,2107,3084, 60,1042,1333,2794, 264,3177,4014, -1628, 258,3712, 7,4464,1176,1043,1778, 683, 114,1975, 78,1492, 383,1886, 510, - 386, 645,5291,2891,2069,3305,4138,3867,2939,2603,2493,1935,1066,1848,3588,1015, -1282,1289,4609, 697,1453,3044,2666,3611,1856,2412, 54, 719,1330, 568,3778,2459, -1748, 788, 492, 551,1191,1000, 488,3394,3763, 282,1799, 348,2016,1523,3155,2390, -1049, 382,2019,1788,1170, 729,2968,3523, 897,3926,2785,2938,3292, 350,2319,3238, -1718,1717,2655,3453,3143,4465, 161,2889,2980,2009,1421, 56,1908,1640,2387,2232, -1917,1874,2477,4921, 148, 83,3438, 592,4245,2882,1822,1055, 741, 115,1496,1624, - 381,1638,4592,1020, 516,3214, 458, 947,4575,1432, 211,1514,2926,1865,2142, 189, - 852,1221,1400,1486, 882,2299,4036, 351, 28,1122, 700,6479,6480,6481,6482,6483, #last 512 -) -# fmt: on diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py deleted file mode 100644 index d423e73..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py +++ /dev/null @@ -1,47 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 .chardistribution import GB2312DistributionAnalysis -from .codingstatemachine import CodingStateMachine -from .mbcharsetprober import MultiByteCharSetProber -from .mbcssm import GB2312_SM_MODEL - - -class GB2312Prober(MultiByteCharSetProber): - def __init__(self) -> None: - super().__init__() - self.coding_sm = CodingStateMachine(GB2312_SM_MODEL) - self.distribution_analyzer = GB2312DistributionAnalysis() - self.reset() - - @property - def charset_name(self) -> str: - return "GB2312" - - @property - def language(self) -> str: - return "Chinese" diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py deleted file mode 100644 index 785d005..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py +++ /dev/null @@ -1,316 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Universal charset detector code. -# -# The Initial Developer of the Original Code is -# Shy Shalom -# Portions created by the Initial Developer are Copyright (C) 2005 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 Optional, Union - -from .charsetprober import CharSetProber -from .enums import ProbingState -from .sbcharsetprober import SingleByteCharSetProber - -# This prober doesn't actually recognize a language or a charset. -# It is a helper prober for the use of the Hebrew model probers - -### General ideas of the Hebrew charset recognition ### -# -# Four main charsets exist in Hebrew: -# "ISO-8859-8" - Visual Hebrew -# "windows-1255" - Logical Hebrew -# "ISO-8859-8-I" - Logical Hebrew -# "x-mac-hebrew" - ?? Logical Hebrew ?? -# -# Both "ISO" charsets use a completely identical set of code points, whereas -# "windows-1255" and "x-mac-hebrew" are two different proper supersets of -# these code points. windows-1255 defines additional characters in the range -# 0x80-0x9F as some misc punctuation marks as well as some Hebrew-specific -# diacritics and additional 'Yiddish' ligature letters in the range 0xc0-0xd6. -# x-mac-hebrew defines similar additional code points but with a different -# mapping. -# -# As far as an average Hebrew text with no diacritics is concerned, all four -# charsets are identical with respect to code points. Meaning that for the -# main Hebrew alphabet, all four map the same values to all 27 Hebrew letters -# (including final letters). -# -# The dominant difference between these charsets is their directionality. -# "Visual" directionality means that the text is ordered as if the renderer is -# not aware of a BIDI rendering algorithm. The renderer sees the text and -# draws it from left to right. The text itself when ordered naturally is read -# backwards. A buffer of Visual Hebrew generally looks like so: -# "[last word of first line spelled backwards] [whole line ordered backwards -# and spelled backwards] [first word of first line spelled backwards] -# [end of line] [last word of second line] ... etc' " -# adding punctuation marks, numbers and English text to visual text is -# naturally also "visual" and from left to right. -# -# "Logical" directionality means the text is ordered "naturally" according to -# the order it is read. It is the responsibility of the renderer to display -# the text from right to left. A BIDI algorithm is used to place general -# punctuation marks, numbers and English text in the text. -# -# Texts in x-mac-hebrew are almost impossible to find on the Internet. From -# what little evidence I could find, it seems that its general directionality -# is Logical. -# -# To sum up all of the above, the Hebrew probing mechanism knows about two -# charsets: -# Visual Hebrew - "ISO-8859-8" - backwards text - Words and sentences are -# backwards while line order is natural. For charset recognition purposes -# the line order is unimportant (In fact, for this implementation, even -# word order is unimportant). -# Logical Hebrew - "windows-1255" - normal, naturally ordered text. -# -# "ISO-8859-8-I" is a subset of windows-1255 and doesn't need to be -# specifically identified. -# "x-mac-hebrew" is also identified as windows-1255. A text in x-mac-hebrew -# that contain special punctuation marks or diacritics is displayed with -# some unconverted characters showing as question marks. This problem might -# be corrected using another model prober for x-mac-hebrew. Due to the fact -# that x-mac-hebrew texts are so rare, writing another model prober isn't -# worth the effort and performance hit. -# -#### The Prober #### -# -# The prober is divided between two SBCharSetProbers and a HebrewProber, -# all of which are managed, created, fed data, inquired and deleted by the -# SBCSGroupProber. The two SBCharSetProbers identify that the text is in -# fact some kind of Hebrew, Logical or Visual. The final decision about which -# one is it is made by the HebrewProber by combining final-letter scores -# with the scores of the two SBCharSetProbers to produce a final answer. -# -# The SBCSGroupProber is responsible for stripping the original text of HTML -# tags, English characters, numbers, low-ASCII punctuation characters, spaces -# and new lines. It reduces any sequence of such characters to a single space. -# The buffer fed to each prober in the SBCS group prober is pure text in -# high-ASCII. -# The two SBCharSetProbers (model probers) share the same language model: -# Win1255Model. -# The first SBCharSetProber uses the model normally as any other -# SBCharSetProber does, to recognize windows-1255, upon which this model was -# built. The second SBCharSetProber is told to make the pair-of-letter -# lookup in the language model backwards. This in practice exactly simulates -# a visual Hebrew model using the windows-1255 logical Hebrew model. -# -# The HebrewProber is not using any language model. All it does is look for -# final-letter evidence suggesting the text is either logical Hebrew or visual -# Hebrew. Disjointed from the model probers, the results of the HebrewProber -# alone are meaningless. HebrewProber always returns 0.00 as confidence -# since it never identifies a charset by itself. Instead, the pointer to the -# HebrewProber is passed to the model probers as a helper "Name Prober". -# When the Group prober receives a positive identification from any prober, -# it asks for the name of the charset identified. If the prober queried is a -# Hebrew model prober, the model prober forwards the call to the -# HebrewProber to make the final decision. In the HebrewProber, the -# decision is made according to the final-letters scores maintained and Both -# model probers scores. The answer is returned in the form of the name of the -# charset identified, either "windows-1255" or "ISO-8859-8". - - -class HebrewProber(CharSetProber): - SPACE = 0x20 - # windows-1255 / ISO-8859-8 code points of interest - FINAL_KAF = 0xEA - NORMAL_KAF = 0xEB - FINAL_MEM = 0xED - NORMAL_MEM = 0xEE - FINAL_NUN = 0xEF - NORMAL_NUN = 0xF0 - FINAL_PE = 0xF3 - NORMAL_PE = 0xF4 - FINAL_TSADI = 0xF5 - NORMAL_TSADI = 0xF6 - - # Minimum Visual vs Logical final letter score difference. - # If the difference is below this, don't rely solely on the final letter score - # distance. - MIN_FINAL_CHAR_DISTANCE = 5 - - # Minimum Visual vs Logical model score difference. - # If the difference is below this, don't rely at all on the model score - # distance. - MIN_MODEL_DISTANCE = 0.01 - - VISUAL_HEBREW_NAME = "ISO-8859-8" - LOGICAL_HEBREW_NAME = "windows-1255" - - def __init__(self) -> None: - super().__init__() - self._final_char_logical_score = 0 - self._final_char_visual_score = 0 - self._prev = self.SPACE - self._before_prev = self.SPACE - self._logical_prober: Optional[SingleByteCharSetProber] = None - self._visual_prober: Optional[SingleByteCharSetProber] = None - self.reset() - - def reset(self) -> None: - self._final_char_logical_score = 0 - self._final_char_visual_score = 0 - # The two last characters seen in the previous buffer, - # mPrev and mBeforePrev are initialized to space in order to simulate - # a word delimiter at the beginning of the data - self._prev = self.SPACE - self._before_prev = self.SPACE - # These probers are owned by the group prober. - - def set_model_probers( - self, - logical_prober: SingleByteCharSetProber, - visual_prober: SingleByteCharSetProber, - ) -> None: - self._logical_prober = logical_prober - self._visual_prober = visual_prober - - def is_final(self, c: int) -> bool: - return c in [ - self.FINAL_KAF, - self.FINAL_MEM, - self.FINAL_NUN, - self.FINAL_PE, - self.FINAL_TSADI, - ] - - def is_non_final(self, c: int) -> bool: - # The normal Tsadi is not a good Non-Final letter due to words like - # 'lechotet' (to chat) containing an apostrophe after the tsadi. This - # apostrophe is converted to a space in FilterWithoutEnglishLetters - # causing the Non-Final tsadi to appear at an end of a word even - # though this is not the case in the original text. - # The letters Pe and Kaf rarely display a related behavior of not being - # a good Non-Final letter. Words like 'Pop', 'Winamp' and 'Mubarak' - # for example legally end with a Non-Final Pe or Kaf. However, the - # benefit of these letters as Non-Final letters outweighs the damage - # since these words are quite rare. - return c in [self.NORMAL_KAF, self.NORMAL_MEM, self.NORMAL_NUN, self.NORMAL_PE] - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - # Final letter analysis for logical-visual decision. - # Look for evidence that the received buffer is either logical Hebrew - # or visual Hebrew. - # The following cases are checked: - # 1) A word longer than 1 letter, ending with a final letter. This is - # an indication that the text is laid out "naturally" since the - # final letter really appears at the end. +1 for logical score. - # 2) A word longer than 1 letter, ending with a Non-Final letter. In - # normal Hebrew, words ending with Kaf, Mem, Nun, Pe or Tsadi, - # should not end with the Non-Final form of that letter. Exceptions - # to this rule are mentioned above in isNonFinal(). This is an - # indication that the text is laid out backwards. +1 for visual - # score - # 3) A word longer than 1 letter, starting with a final letter. Final - # letters should not appear at the beginning of a word. This is an - # indication that the text is laid out backwards. +1 for visual - # score. - # - # The visual score and logical score are accumulated throughout the - # text and are finally checked against each other in GetCharSetName(). - # No checking for final letters in the middle of words is done since - # that case is not an indication for either Logical or Visual text. - # - # We automatically filter out all 7-bit characters (replace them with - # spaces) so the word boundary detection works properly. [MAP] - - if self.state == ProbingState.NOT_ME: - # Both model probers say it's not them. No reason to continue. - return ProbingState.NOT_ME - - byte_str = self.filter_high_byte_only(byte_str) - - for cur in byte_str: - if cur == self.SPACE: - # We stand on a space - a word just ended - if self._before_prev != self.SPACE: - # next-to-last char was not a space so self._prev is not a - # 1 letter word - if self.is_final(self._prev): - # case (1) [-2:not space][-1:final letter][cur:space] - self._final_char_logical_score += 1 - elif self.is_non_final(self._prev): - # case (2) [-2:not space][-1:Non-Final letter][ - # cur:space] - self._final_char_visual_score += 1 - else: - # Not standing on a space - if ( - (self._before_prev == self.SPACE) - and (self.is_final(self._prev)) - and (cur != self.SPACE) - ): - # case (3) [-2:space][-1:final letter][cur:not space] - self._final_char_visual_score += 1 - self._before_prev = self._prev - self._prev = cur - - # Forever detecting, till the end or until both model probers return - # ProbingState.NOT_ME (handled above) - return ProbingState.DETECTING - - @property - def charset_name(self) -> str: - assert self._logical_prober is not None - assert self._visual_prober is not None - - # Make the decision: is it Logical or Visual? - # If the final letter score distance is dominant enough, rely on it. - finalsub = self._final_char_logical_score - self._final_char_visual_score - if finalsub >= self.MIN_FINAL_CHAR_DISTANCE: - return self.LOGICAL_HEBREW_NAME - if finalsub <= -self.MIN_FINAL_CHAR_DISTANCE: - return self.VISUAL_HEBREW_NAME - - # It's not dominant enough, try to rely on the model scores instead. - modelsub = ( - self._logical_prober.get_confidence() - self._visual_prober.get_confidence() - ) - if modelsub > self.MIN_MODEL_DISTANCE: - return self.LOGICAL_HEBREW_NAME - if modelsub < -self.MIN_MODEL_DISTANCE: - return self.VISUAL_HEBREW_NAME - - # Still no good, back to final letter distance, maybe it'll save the - # day. - if finalsub < 0.0: - return self.VISUAL_HEBREW_NAME - - # (finalsub > 0 - Logical) or (don't know what to do) default to - # Logical. - return self.LOGICAL_HEBREW_NAME - - @property - def language(self) -> str: - return "Hebrew" - - @property - def state(self) -> ProbingState: - assert self._logical_prober is not None - assert self._visual_prober is not None - - # Remain active as long as any of the model probers are active. - if (self._logical_prober.state == ProbingState.NOT_ME) and ( - self._visual_prober.state == ProbingState.NOT_ME - ): - return ProbingState.NOT_ME - return ProbingState.DETECTING diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/jisfreq.py b/myenv/Lib/site-packages/pip/_vendor/chardet/jisfreq.py deleted file mode 100644 index 3293576..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/jisfreq.py +++ /dev/null @@ -1,325 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Communicator client code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 ######################### - -# Sampling from about 20M text materials include literature and computer technology -# -# Japanese frequency table, applied to both S-JIS and EUC-JP -# They are sorted in order. - -# 128 --> 0.77094 -# 256 --> 0.85710 -# 512 --> 0.92635 -# 1024 --> 0.97130 -# 2048 --> 0.99431 -# -# Ideal Distribution Ratio = 0.92635 / (1-0.92635) = 12.58 -# Random Distribution Ration = 512 / (2965+62+83+86-512) = 0.191 -# -# Typical Distribution Ratio, 25% of IDR - -JIS_TYPICAL_DISTRIBUTION_RATIO = 3.0 - -# Char to FreqOrder table , -JIS_TABLE_SIZE = 4368 - -# fmt: off -JIS_CHAR_TO_FREQ_ORDER = ( - 40, 1, 6, 182, 152, 180, 295,2127, 285, 381,3295,4304,3068,4606,3165,3510, # 16 -3511,1822,2785,4607,1193,2226,5070,4608, 171,2996,1247, 18, 179,5071, 856,1661, # 32 -1262,5072, 619, 127,3431,3512,3230,1899,1700, 232, 228,1294,1298, 284, 283,2041, # 48 -2042,1061,1062, 48, 49, 44, 45, 433, 434,1040,1041, 996, 787,2997,1255,4305, # 64 -2108,4609,1684,1648,5073,5074,5075,5076,5077,5078,3687,5079,4610,5080,3927,3928, # 80 -5081,3296,3432, 290,2285,1471,2187,5082,2580,2825,1303,2140,1739,1445,2691,3375, # 96 -1691,3297,4306,4307,4611, 452,3376,1182,2713,3688,3069,4308,5083,5084,5085,5086, # 112 -5087,5088,5089,5090,5091,5092,5093,5094,5095,5096,5097,5098,5099,5100,5101,5102, # 128 -5103,5104,5105,5106,5107,5108,5109,5110,5111,5112,4097,5113,5114,5115,5116,5117, # 144 -5118,5119,5120,5121,5122,5123,5124,5125,5126,5127,5128,5129,5130,5131,5132,5133, # 160 -5134,5135,5136,5137,5138,5139,5140,5141,5142,5143,5144,5145,5146,5147,5148,5149, # 176 -5150,5151,5152,4612,5153,5154,5155,5156,5157,5158,5159,5160,5161,5162,5163,5164, # 192 -5165,5166,5167,5168,5169,5170,5171,5172,5173,5174,5175,1472, 598, 618, 820,1205, # 208 -1309,1412,1858,1307,1692,5176,5177,5178,5179,5180,5181,5182,1142,1452,1234,1172, # 224 -1875,2043,2149,1793,1382,2973, 925,2404,1067,1241, 960,1377,2935,1491, 919,1217, # 240 -1865,2030,1406,1499,2749,4098,5183,5184,5185,5186,5187,5188,2561,4099,3117,1804, # 256 -2049,3689,4309,3513,1663,5189,3166,3118,3298,1587,1561,3433,5190,3119,1625,2998, # 272 -3299,4613,1766,3690,2786,4614,5191,5192,5193,5194,2161, 26,3377, 2,3929, 20, # 288 -3691, 47,4100, 50, 17, 16, 35, 268, 27, 243, 42, 155, 24, 154, 29, 184, # 304 - 4, 91, 14, 92, 53, 396, 33, 289, 9, 37, 64, 620, 21, 39, 321, 5, # 320 - 12, 11, 52, 13, 3, 208, 138, 0, 7, 60, 526, 141, 151,1069, 181, 275, # 336 -1591, 83, 132,1475, 126, 331, 829, 15, 69, 160, 59, 22, 157, 55,1079, 312, # 352 - 109, 38, 23, 25, 10, 19, 79,5195, 61, 382,1124, 8, 30,5196,5197,5198, # 368 -5199,5200,5201,5202,5203,5204,5205,5206, 89, 62, 74, 34,2416, 112, 139, 196, # 384 - 271, 149, 84, 607, 131, 765, 46, 88, 153, 683, 76, 874, 101, 258, 57, 80, # 400 - 32, 364, 121,1508, 169,1547, 68, 235, 145,2999, 41, 360,3027, 70, 63, 31, # 416 - 43, 259, 262,1383, 99, 533, 194, 66, 93, 846, 217, 192, 56, 106, 58, 565, # 432 - 280, 272, 311, 256, 146, 82, 308, 71, 100, 128, 214, 655, 110, 261, 104,1140, # 448 - 54, 51, 36, 87, 67,3070, 185,2618,2936,2020, 28,1066,2390,2059,5207,5208, # 464 -5209,5210,5211,5212,5213,5214,5215,5216,4615,5217,5218,5219,5220,5221,5222,5223, # 480 -5224,5225,5226,5227,5228,5229,5230,5231,5232,5233,5234,5235,5236,3514,5237,5238, # 496 -5239,5240,5241,5242,5243,5244,2297,2031,4616,4310,3692,5245,3071,5246,3598,5247, # 512 -4617,3231,3515,5248,4101,4311,4618,3808,4312,4102,5249,4103,4104,3599,5250,5251, # 528 -5252,5253,5254,5255,5256,5257,5258,5259,5260,5261,5262,5263,5264,5265,5266,5267, # 544 -5268,5269,5270,5271,5272,5273,5274,5275,5276,5277,5278,5279,5280,5281,5282,5283, # 560 -5284,5285,5286,5287,5288,5289,5290,5291,5292,5293,5294,5295,5296,5297,5298,5299, # 576 -5300,5301,5302,5303,5304,5305,5306,5307,5308,5309,5310,5311,5312,5313,5314,5315, # 592 -5316,5317,5318,5319,5320,5321,5322,5323,5324,5325,5326,5327,5328,5329,5330,5331, # 608 -5332,5333,5334,5335,5336,5337,5338,5339,5340,5341,5342,5343,5344,5345,5346,5347, # 624 -5348,5349,5350,5351,5352,5353,5354,5355,5356,5357,5358,5359,5360,5361,5362,5363, # 640 -5364,5365,5366,5367,5368,5369,5370,5371,5372,5373,5374,5375,5376,5377,5378,5379, # 656 -5380,5381, 363, 642,2787,2878,2788,2789,2316,3232,2317,3434,2011, 165,1942,3930, # 672 -3931,3932,3933,5382,4619,5383,4620,5384,5385,5386,5387,5388,5389,5390,5391,5392, # 688 -5393,5394,5395,5396,5397,5398,5399,5400,5401,5402,5403,5404,5405,5406,5407,5408, # 704 -5409,5410,5411,5412,5413,5414,5415,5416,5417,5418,5419,5420,5421,5422,5423,5424, # 720 -5425,5426,5427,5428,5429,5430,5431,5432,5433,5434,5435,5436,5437,5438,5439,5440, # 736 -5441,5442,5443,5444,5445,5446,5447,5448,5449,5450,5451,5452,5453,5454,5455,5456, # 752 -5457,5458,5459,5460,5461,5462,5463,5464,5465,5466,5467,5468,5469,5470,5471,5472, # 768 -5473,5474,5475,5476,5477,5478,5479,5480,5481,5482,5483,5484,5485,5486,5487,5488, # 784 -5489,5490,5491,5492,5493,5494,5495,5496,5497,5498,5499,5500,5501,5502,5503,5504, # 800 -5505,5506,5507,5508,5509,5510,5511,5512,5513,5514,5515,5516,5517,5518,5519,5520, # 816 -5521,5522,5523,5524,5525,5526,5527,5528,5529,5530,5531,5532,5533,5534,5535,5536, # 832 -5537,5538,5539,5540,5541,5542,5543,5544,5545,5546,5547,5548,5549,5550,5551,5552, # 848 -5553,5554,5555,5556,5557,5558,5559,5560,5561,5562,5563,5564,5565,5566,5567,5568, # 864 -5569,5570,5571,5572,5573,5574,5575,5576,5577,5578,5579,5580,5581,5582,5583,5584, # 880 -5585,5586,5587,5588,5589,5590,5591,5592,5593,5594,5595,5596,5597,5598,5599,5600, # 896 -5601,5602,5603,5604,5605,5606,5607,5608,5609,5610,5611,5612,5613,5614,5615,5616, # 912 -5617,5618,5619,5620,5621,5622,5623,5624,5625,5626,5627,5628,5629,5630,5631,5632, # 928 -5633,5634,5635,5636,5637,5638,5639,5640,5641,5642,5643,5644,5645,5646,5647,5648, # 944 -5649,5650,5651,5652,5653,5654,5655,5656,5657,5658,5659,5660,5661,5662,5663,5664, # 960 -5665,5666,5667,5668,5669,5670,5671,5672,5673,5674,5675,5676,5677,5678,5679,5680, # 976 -5681,5682,5683,5684,5685,5686,5687,5688,5689,5690,5691,5692,5693,5694,5695,5696, # 992 -5697,5698,5699,5700,5701,5702,5703,5704,5705,5706,5707,5708,5709,5710,5711,5712, # 1008 -5713,5714,5715,5716,5717,5718,5719,5720,5721,5722,5723,5724,5725,5726,5727,5728, # 1024 -5729,5730,5731,5732,5733,5734,5735,5736,5737,5738,5739,5740,5741,5742,5743,5744, # 1040 -5745,5746,5747,5748,5749,5750,5751,5752,5753,5754,5755,5756,5757,5758,5759,5760, # 1056 -5761,5762,5763,5764,5765,5766,5767,5768,5769,5770,5771,5772,5773,5774,5775,5776, # 1072 -5777,5778,5779,5780,5781,5782,5783,5784,5785,5786,5787,5788,5789,5790,5791,5792, # 1088 -5793,5794,5795,5796,5797,5798,5799,5800,5801,5802,5803,5804,5805,5806,5807,5808, # 1104 -5809,5810,5811,5812,5813,5814,5815,5816,5817,5818,5819,5820,5821,5822,5823,5824, # 1120 -5825,5826,5827,5828,5829,5830,5831,5832,5833,5834,5835,5836,5837,5838,5839,5840, # 1136 -5841,5842,5843,5844,5845,5846,5847,5848,5849,5850,5851,5852,5853,5854,5855,5856, # 1152 -5857,5858,5859,5860,5861,5862,5863,5864,5865,5866,5867,5868,5869,5870,5871,5872, # 1168 -5873,5874,5875,5876,5877,5878,5879,5880,5881,5882,5883,5884,5885,5886,5887,5888, # 1184 -5889,5890,5891,5892,5893,5894,5895,5896,5897,5898,5899,5900,5901,5902,5903,5904, # 1200 -5905,5906,5907,5908,5909,5910,5911,5912,5913,5914,5915,5916,5917,5918,5919,5920, # 1216 -5921,5922,5923,5924,5925,5926,5927,5928,5929,5930,5931,5932,5933,5934,5935,5936, # 1232 -5937,5938,5939,5940,5941,5942,5943,5944,5945,5946,5947,5948,5949,5950,5951,5952, # 1248 -5953,5954,5955,5956,5957,5958,5959,5960,5961,5962,5963,5964,5965,5966,5967,5968, # 1264 -5969,5970,5971,5972,5973,5974,5975,5976,5977,5978,5979,5980,5981,5982,5983,5984, # 1280 -5985,5986,5987,5988,5989,5990,5991,5992,5993,5994,5995,5996,5997,5998,5999,6000, # 1296 -6001,6002,6003,6004,6005,6006,6007,6008,6009,6010,6011,6012,6013,6014,6015,6016, # 1312 -6017,6018,6019,6020,6021,6022,6023,6024,6025,6026,6027,6028,6029,6030,6031,6032, # 1328 -6033,6034,6035,6036,6037,6038,6039,6040,6041,6042,6043,6044,6045,6046,6047,6048, # 1344 -6049,6050,6051,6052,6053,6054,6055,6056,6057,6058,6059,6060,6061,6062,6063,6064, # 1360 -6065,6066,6067,6068,6069,6070,6071,6072,6073,6074,6075,6076,6077,6078,6079,6080, # 1376 -6081,6082,6083,6084,6085,6086,6087,6088,6089,6090,6091,6092,6093,6094,6095,6096, # 1392 -6097,6098,6099,6100,6101,6102,6103,6104,6105,6106,6107,6108,6109,6110,6111,6112, # 1408 -6113,6114,2044,2060,4621, 997,1235, 473,1186,4622, 920,3378,6115,6116, 379,1108, # 1424 -4313,2657,2735,3934,6117,3809, 636,3233, 573,1026,3693,3435,2974,3300,2298,4105, # 1440 - 854,2937,2463, 393,2581,2417, 539, 752,1280,2750,2480, 140,1161, 440, 708,1569, # 1456 - 665,2497,1746,1291,1523,3000, 164,1603, 847,1331, 537,1997, 486, 508,1693,2418, # 1472 -1970,2227, 878,1220, 299,1030, 969, 652,2751, 624,1137,3301,2619, 65,3302,2045, # 1488 -1761,1859,3120,1930,3694,3516, 663,1767, 852, 835,3695, 269, 767,2826,2339,1305, # 1504 - 896,1150, 770,1616,6118, 506,1502,2075,1012,2519, 775,2520,2975,2340,2938,4314, # 1520 -3028,2086,1224,1943,2286,6119,3072,4315,2240,1273,1987,3935,1557, 175, 597, 985, # 1536 -3517,2419,2521,1416,3029, 585, 938,1931,1007,1052,1932,1685,6120,3379,4316,4623, # 1552 - 804, 599,3121,1333,2128,2539,1159,1554,2032,3810, 687,2033,2904, 952, 675,1467, # 1568 -3436,6121,2241,1096,1786,2440,1543,1924, 980,1813,2228, 781,2692,1879, 728,1918, # 1584 -3696,4624, 548,1950,4625,1809,1088,1356,3303,2522,1944, 502, 972, 373, 513,2827, # 1600 - 586,2377,2391,1003,1976,1631,6122,2464,1084, 648,1776,4626,2141, 324, 962,2012, # 1616 -2177,2076,1384, 742,2178,1448,1173,1810, 222, 102, 301, 445, 125,2420, 662,2498, # 1632 - 277, 200,1476,1165,1068, 224,2562,1378,1446, 450,1880, 659, 791, 582,4627,2939, # 1648 -3936,1516,1274, 555,2099,3697,1020,1389,1526,3380,1762,1723,1787,2229, 412,2114, # 1664 -1900,2392,3518, 512,2597, 427,1925,2341,3122,1653,1686,2465,2499, 697, 330, 273, # 1680 - 380,2162, 951, 832, 780, 991,1301,3073, 965,2270,3519, 668,2523,2636,1286, 535, # 1696 -1407, 518, 671, 957,2658,2378, 267, 611,2197,3030,6123, 248,2299, 967,1799,2356, # 1712 - 850,1418,3437,1876,1256,1480,2828,1718,6124,6125,1755,1664,2405,6126,4628,2879, # 1728 -2829, 499,2179, 676,4629, 557,2329,2214,2090, 325,3234, 464, 811,3001, 992,2342, # 1744 -2481,1232,1469, 303,2242, 466,1070,2163, 603,1777,2091,4630,2752,4631,2714, 322, # 1760 -2659,1964,1768, 481,2188,1463,2330,2857,3600,2092,3031,2421,4632,2318,2070,1849, # 1776 -2598,4633,1302,2254,1668,1701,2422,3811,2905,3032,3123,2046,4106,1763,1694,4634, # 1792 -1604, 943,1724,1454, 917, 868,2215,1169,2940, 552,1145,1800,1228,1823,1955, 316, # 1808 -1080,2510, 361,1807,2830,4107,2660,3381,1346,1423,1134,4108,6127, 541,1263,1229, # 1824 -1148,2540, 545, 465,1833,2880,3438,1901,3074,2482, 816,3937, 713,1788,2500, 122, # 1840 -1575, 195,1451,2501,1111,6128, 859, 374,1225,2243,2483,4317, 390,1033,3439,3075, # 1856 -2524,1687, 266, 793,1440,2599, 946, 779, 802, 507, 897,1081, 528,2189,1292, 711, # 1872 -1866,1725,1167,1640, 753, 398,2661,1053, 246, 348,4318, 137,1024,3440,1600,2077, # 1888 -2129, 825,4319, 698, 238, 521, 187,2300,1157,2423,1641,1605,1464,1610,1097,2541, # 1904 -1260,1436, 759,2255,1814,2150, 705,3235, 409,2563,3304, 561,3033,2005,2564, 726, # 1920 -1956,2343,3698,4109, 949,3812,3813,3520,1669, 653,1379,2525, 881,2198, 632,2256, # 1936 -1027, 778,1074, 733,1957, 514,1481,2466, 554,2180, 702,3938,1606,1017,1398,6129, # 1952 -1380,3521, 921, 993,1313, 594, 449,1489,1617,1166, 768,1426,1360, 495,1794,3601, # 1968 -1177,3602,1170,4320,2344, 476, 425,3167,4635,3168,1424, 401,2662,1171,3382,1998, # 1984 -1089,4110, 477,3169, 474,6130,1909, 596,2831,1842, 494, 693,1051,1028,1207,3076, # 2000 - 606,2115, 727,2790,1473,1115, 743,3522, 630, 805,1532,4321,2021, 366,1057, 838, # 2016 - 684,1114,2142,4322,2050,1492,1892,1808,2271,3814,2424,1971,1447,1373,3305,1090, # 2032 -1536,3939,3523,3306,1455,2199, 336, 369,2331,1035, 584,2393, 902, 718,2600,6131, # 2048 -2753, 463,2151,1149,1611,2467, 715,1308,3124,1268, 343,1413,3236,1517,1347,2663, # 2064 -2093,3940,2022,1131,1553,2100,2941,1427,3441,2942,1323,2484,6132,1980, 872,2368, # 2080 -2441,2943, 320,2369,2116,1082, 679,1933,3941,2791,3815, 625,1143,2023, 422,2200, # 2096 -3816,6133, 730,1695, 356,2257,1626,2301,2858,2637,1627,1778, 937, 883,2906,2693, # 2112 -3002,1769,1086, 400,1063,1325,3307,2792,4111,3077, 456,2345,1046, 747,6134,1524, # 2128 - 884,1094,3383,1474,2164,1059, 974,1688,2181,2258,1047, 345,1665,1187, 358, 875, # 2144 -3170, 305, 660,3524,2190,1334,1135,3171,1540,1649,2542,1527, 927, 968,2793, 885, # 2160 -1972,1850, 482, 500,2638,1218,1109,1085,2543,1654,2034, 876, 78,2287,1482,1277, # 2176 - 861,1675,1083,1779, 724,2754, 454, 397,1132,1612,2332, 893, 672,1237, 257,2259, # 2192 -2370, 135,3384, 337,2244, 547, 352, 340, 709,2485,1400, 788,1138,2511, 540, 772, # 2208 -1682,2260,2272,2544,2013,1843,1902,4636,1999,1562,2288,4637,2201,1403,1533, 407, # 2224 - 576,3308,1254,2071, 978,3385, 170, 136,1201,3125,2664,3172,2394, 213, 912, 873, # 2240 -3603,1713,2202, 699,3604,3699, 813,3442, 493, 531,1054, 468,2907,1483, 304, 281, # 2256 -4112,1726,1252,2094, 339,2319,2130,2639, 756,1563,2944, 748, 571,2976,1588,2425, # 2272 -2715,1851,1460,2426,1528,1392,1973,3237, 288,3309, 685,3386, 296, 892,2716,2216, # 2288 -1570,2245, 722,1747,2217, 905,3238,1103,6135,1893,1441,1965, 251,1805,2371,3700, # 2304 -2601,1919,1078, 75,2182,1509,1592,1270,2640,4638,2152,6136,3310,3817, 524, 706, # 2320 -1075, 292,3818,1756,2602, 317, 98,3173,3605,3525,1844,2218,3819,2502, 814, 567, # 2336 - 385,2908,1534,6137, 534,1642,3239, 797,6138,1670,1529, 953,4323, 188,1071, 538, # 2352 - 178, 729,3240,2109,1226,1374,2000,2357,2977, 731,2468,1116,2014,2051,6139,1261, # 2368 -1593, 803,2859,2736,3443, 556, 682, 823,1541,6140,1369,2289,1706,2794, 845, 462, # 2384 -2603,2665,1361, 387, 162,2358,1740, 739,1770,1720,1304,1401,3241,1049, 627,1571, # 2400 -2427,3526,1877,3942,1852,1500, 431,1910,1503, 677, 297,2795, 286,1433,1038,1198, # 2416 -2290,1133,1596,4113,4639,2469,1510,1484,3943,6141,2442, 108, 712,4640,2372, 866, # 2432 -3701,2755,3242,1348, 834,1945,1408,3527,2395,3243,1811, 824, 994,1179,2110,1548, # 2448 -1453, 790,3003, 690,4324,4325,2832,2909,3820,1860,3821, 225,1748, 310, 346,1780, # 2464 -2470, 821,1993,2717,2796, 828, 877,3528,2860,2471,1702,2165,2910,2486,1789, 453, # 2480 - 359,2291,1676, 73,1164,1461,1127,3311, 421, 604, 314,1037, 589, 116,2487, 737, # 2496 - 837,1180, 111, 244, 735,6142,2261,1861,1362, 986, 523, 418, 581,2666,3822, 103, # 2512 - 855, 503,1414,1867,2488,1091, 657,1597, 979, 605,1316,4641,1021,2443,2078,2001, # 2528 -1209, 96, 587,2166,1032, 260,1072,2153, 173, 94, 226,3244, 819,2006,4642,4114, # 2544 -2203, 231,1744, 782, 97,2667, 786,3387, 887, 391, 442,2219,4326,1425,6143,2694, # 2560 - 633,1544,1202, 483,2015, 592,2052,1958,2472,1655, 419, 129,4327,3444,3312,1714, # 2576 -1257,3078,4328,1518,1098, 865,1310,1019,1885,1512,1734, 469,2444, 148, 773, 436, # 2592 -1815,1868,1128,1055,4329,1245,2756,3445,2154,1934,1039,4643, 579,1238, 932,2320, # 2608 - 353, 205, 801, 115,2428, 944,2321,1881, 399,2565,1211, 678, 766,3944, 335,2101, # 2624 -1459,1781,1402,3945,2737,2131,1010, 844, 981,1326,1013, 550,1816,1545,2620,1335, # 2640 -1008, 371,2881, 936,1419,1613,3529,1456,1395,2273,1834,2604,1317,2738,2503, 416, # 2656 -1643,4330, 806,1126, 229, 591,3946,1314,1981,1576,1837,1666, 347,1790, 977,3313, # 2672 - 764,2861,1853, 688,2429,1920,1462, 77, 595, 415,2002,3034, 798,1192,4115,6144, # 2688 -2978,4331,3035,2695,2582,2072,2566, 430,2430,1727, 842,1396,3947,3702, 613, 377, # 2704 - 278, 236,1417,3388,3314,3174, 757,1869, 107,3530,6145,1194, 623,2262, 207,1253, # 2720 -2167,3446,3948, 492,1117,1935, 536,1838,2757,1246,4332, 696,2095,2406,1393,1572, # 2736 -3175,1782, 583, 190, 253,1390,2230, 830,3126,3389, 934,3245,1703,1749,2979,1870, # 2752 -2545,1656,2204, 869,2346,4116,3176,1817, 496,1764,4644, 942,1504, 404,1903,1122, # 2768 -1580,3606,2945,1022, 515, 372,1735, 955,2431,3036,6146,2797,1110,2302,2798, 617, # 2784 -6147, 441, 762,1771,3447,3607,3608,1904, 840,3037, 86, 939,1385, 572,1370,2445, # 2800 -1336, 114,3703, 898, 294, 203,3315, 703,1583,2274, 429, 961,4333,1854,1951,3390, # 2816 -2373,3704,4334,1318,1381, 966,1911,2322,1006,1155, 309, 989, 458,2718,1795,1372, # 2832 -1203, 252,1689,1363,3177, 517,1936, 168,1490, 562, 193,3823,1042,4117,1835, 551, # 2848 - 470,4645, 395, 489,3448,1871,1465,2583,2641, 417,1493, 279,1295, 511,1236,1119, # 2864 - 72,1231,1982,1812,3004, 871,1564, 984,3449,1667,2696,2096,4646,2347,2833,1673, # 2880 -3609, 695,3246,2668, 807,1183,4647, 890, 388,2333,1801,1457,2911,1765,1477,1031, # 2896 -3316,3317,1278,3391,2799,2292,2526, 163,3450,4335,2669,1404,1802,6148,2323,2407, # 2912 -1584,1728,1494,1824,1269, 298, 909,3318,1034,1632, 375, 776,1683,2061, 291, 210, # 2928 -1123, 809,1249,1002,2642,3038, 206,1011,2132, 144, 975, 882,1565, 342, 667, 754, # 2944 -1442,2143,1299,2303,2062, 447, 626,2205,1221,2739,2912,1144,1214,2206,2584, 760, # 2960 -1715, 614, 950,1281,2670,2621, 810, 577,1287,2546,4648, 242,2168, 250,2643, 691, # 2976 - 123,2644, 647, 313,1029, 689,1357,2946,1650, 216, 771,1339,1306, 808,2063, 549, # 2992 - 913,1371,2913,2914,6149,1466,1092,1174,1196,1311,2605,2396,1783,1796,3079, 406, # 3008 -2671,2117,3949,4649, 487,1825,2220,6150,2915, 448,2348,1073,6151,2397,1707, 130, # 3024 - 900,1598, 329, 176,1959,2527,1620,6152,2275,4336,3319,1983,2191,3705,3610,2155, # 3040 -3706,1912,1513,1614,6153,1988, 646, 392,2304,1589,3320,3039,1826,1239,1352,1340, # 3056 -2916, 505,2567,1709,1437,2408,2547, 906,6154,2672, 384,1458,1594,1100,1329, 710, # 3072 - 423,3531,2064,2231,2622,1989,2673,1087,1882, 333, 841,3005,1296,2882,2379, 580, # 3088 -1937,1827,1293,2585, 601, 574, 249,1772,4118,2079,1120, 645, 901,1176,1690, 795, # 3104 -2207, 478,1434, 516,1190,1530, 761,2080, 930,1264, 355, 435,1552, 644,1791, 987, # 3120 - 220,1364,1163,1121,1538, 306,2169,1327,1222, 546,2645, 218, 241, 610,1704,3321, # 3136 -1984,1839,1966,2528, 451,6155,2586,3707,2568, 907,3178, 254,2947, 186,1845,4650, # 3152 - 745, 432,1757, 428,1633, 888,2246,2221,2489,3611,2118,1258,1265, 956,3127,1784, # 3168 -4337,2490, 319, 510, 119, 457,3612, 274,2035,2007,4651,1409,3128, 970,2758, 590, # 3184 -2800, 661,2247,4652,2008,3950,1420,1549,3080,3322,3951,1651,1375,2111, 485,2491, # 3200 -1429,1156,6156,2548,2183,1495, 831,1840,2529,2446, 501,1657, 307,1894,3247,1341, # 3216 - 666, 899,2156,1539,2549,1559, 886, 349,2208,3081,2305,1736,3824,2170,2759,1014, # 3232 -1913,1386, 542,1397,2948, 490, 368, 716, 362, 159, 282,2569,1129,1658,1288,1750, # 3248 -2674, 276, 649,2016, 751,1496, 658,1818,1284,1862,2209,2087,2512,3451, 622,2834, # 3264 - 376, 117,1060,2053,1208,1721,1101,1443, 247,1250,3179,1792,3952,2760,2398,3953, # 3280 -6157,2144,3708, 446,2432,1151,2570,3452,2447,2761,2835,1210,2448,3082, 424,2222, # 3296 -1251,2449,2119,2836, 504,1581,4338, 602, 817, 857,3825,2349,2306, 357,3826,1470, # 3312 -1883,2883, 255, 958, 929,2917,3248, 302,4653,1050,1271,1751,2307,1952,1430,2697, # 3328 -2719,2359, 354,3180, 777, 158,2036,4339,1659,4340,4654,2308,2949,2248,1146,2232, # 3344 -3532,2720,1696,2623,3827,6158,3129,1550,2698,1485,1297,1428, 637, 931,2721,2145, # 3360 - 914,2550,2587, 81,2450, 612, 827,2646,1242,4655,1118,2884, 472,1855,3181,3533, # 3376 -3534, 569,1353,2699,1244,1758,2588,4119,2009,2762,2171,3709,1312,1531,6159,1152, # 3392 -1938, 134,1830, 471,3710,2276,1112,1535,3323,3453,3535, 982,1337,2950, 488, 826, # 3408 - 674,1058,1628,4120,2017, 522,2399, 211, 568,1367,3454, 350, 293,1872,1139,3249, # 3424 -1399,1946,3006,1300,2360,3324, 588, 736,6160,2606, 744, 669,3536,3828,6161,1358, # 3440 - 199, 723, 848, 933, 851,1939,1505,1514,1338,1618,1831,4656,1634,3613, 443,2740, # 3456 -3829, 717,1947, 491,1914,6162,2551,1542,4121,1025,6163,1099,1223, 198,3040,2722, # 3472 - 370, 410,1905,2589, 998,1248,3182,2380, 519,1449,4122,1710, 947, 928,1153,4341, # 3488 -2277, 344,2624,1511, 615, 105, 161,1212,1076,1960,3130,2054,1926,1175,1906,2473, # 3504 - 414,1873,2801,6164,2309, 315,1319,3325, 318,2018,2146,2157, 963, 631, 223,4342, # 3520 -4343,2675, 479,3711,1197,2625,3712,2676,2361,6165,4344,4123,6166,2451,3183,1886, # 3536 -2184,1674,1330,1711,1635,1506, 799, 219,3250,3083,3954,1677,3713,3326,2081,3614, # 3552 -1652,2073,4657,1147,3041,1752, 643,1961, 147,1974,3955,6167,1716,2037, 918,3007, # 3568 -1994, 120,1537, 118, 609,3184,4345, 740,3455,1219, 332,1615,3830,6168,1621,2980, # 3584 -1582, 783, 212, 553,2350,3714,1349,2433,2082,4124, 889,6169,2310,1275,1410, 973, # 3600 - 166,1320,3456,1797,1215,3185,2885,1846,2590,2763,4658, 629, 822,3008, 763, 940, # 3616 -1990,2862, 439,2409,1566,1240,1622, 926,1282,1907,2764, 654,2210,1607, 327,1130, # 3632 -3956,1678,1623,6170,2434,2192, 686, 608,3831,3715, 903,3957,3042,6171,2741,1522, # 3648 -1915,1105,1555,2552,1359, 323,3251,4346,3457, 738,1354,2553,2311,2334,1828,2003, # 3664 -3832,1753,2351,1227,6172,1887,4125,1478,6173,2410,1874,1712,1847, 520,1204,2607, # 3680 - 264,4659, 836,2677,2102, 600,4660,3833,2278,3084,6174,4347,3615,1342, 640, 532, # 3696 - 543,2608,1888,2400,2591,1009,4348,1497, 341,1737,3616,2723,1394, 529,3252,1321, # 3712 - 983,4661,1515,2120, 971,2592, 924, 287,1662,3186,4349,2700,4350,1519, 908,1948, # 3728 -2452, 156, 796,1629,1486,2223,2055, 694,4126,1259,1036,3392,1213,2249,2742,1889, # 3744 -1230,3958,1015, 910, 408, 559,3617,4662, 746, 725, 935,4663,3959,3009,1289, 563, # 3760 - 867,4664,3960,1567,2981,2038,2626, 988,2263,2381,4351, 143,2374, 704,1895,6175, # 3776 -1188,3716,2088, 673,3085,2362,4352, 484,1608,1921,2765,2918, 215, 904,3618,3537, # 3792 - 894, 509, 976,3043,2701,3961,4353,2837,2982, 498,6176,6177,1102,3538,1332,3393, # 3808 -1487,1636,1637, 233, 245,3962, 383, 650, 995,3044, 460,1520,1206,2352, 749,3327, # 3824 - 530, 700, 389,1438,1560,1773,3963,2264, 719,2951,2724,3834, 870,1832,1644,1000, # 3840 - 839,2474,3717, 197,1630,3394, 365,2886,3964,1285,2133, 734, 922, 818,1106, 732, # 3856 - 480,2083,1774,3458, 923,2279,1350, 221,3086, 85,2233,2234,3835,1585,3010,2147, # 3872 -1387,1705,2382,1619,2475, 133, 239,2802,1991,1016,2084,2383, 411,2838,1113, 651, # 3888 -1985,1160,3328, 990,1863,3087,1048,1276,2647, 265,2627,1599,3253,2056, 150, 638, # 3904 -2019, 656, 853, 326,1479, 680,1439,4354,1001,1759, 413,3459,3395,2492,1431, 459, # 3920 -4355,1125,3329,2265,1953,1450,2065,2863, 849, 351,2678,3131,3254,3255,1104,1577, # 3936 - 227,1351,1645,2453,2193,1421,2887, 812,2121, 634, 95,2435, 201,2312,4665,1646, # 3952 -1671,2743,1601,2554,2702,2648,2280,1315,1366,2089,3132,1573,3718,3965,1729,1189, # 3968 - 328,2679,1077,1940,1136, 558,1283, 964,1195, 621,2074,1199,1743,3460,3619,1896, # 3984 -1916,1890,3836,2952,1154,2112,1064, 862, 378,3011,2066,2113,2803,1568,2839,6178, # 4000 -3088,2919,1941,1660,2004,1992,2194, 142, 707,1590,1708,1624,1922,1023,1836,1233, # 4016 -1004,2313, 789, 741,3620,6179,1609,2411,1200,4127,3719,3720,4666,2057,3721, 593, # 4032 -2840, 367,2920,1878,6180,3461,1521, 628,1168, 692,2211,2649, 300, 720,2067,2571, # 4048 -2953,3396, 959,2504,3966,3539,3462,1977, 701,6181, 954,1043, 800, 681, 183,3722, # 4064 -1803,1730,3540,4128,2103, 815,2314, 174, 467, 230,2454,1093,2134, 755,3541,3397, # 4080 -1141,1162,6182,1738,2039, 270,3256,2513,1005,1647,2185,3837, 858,1679,1897,1719, # 4096 -2954,2324,1806, 402, 670, 167,4129,1498,2158,2104, 750,6183, 915, 189,1680,1551, # 4112 - 455,4356,1501,2455, 405,1095,2955, 338,1586,1266,1819, 570, 641,1324, 237,1556, # 4128 -2650,1388,3723,6184,1368,2384,1343,1978,3089,2436, 879,3724, 792,1191, 758,3012, # 4144 -1411,2135,1322,4357, 240,4667,1848,3725,1574,6185, 420,3045,1546,1391, 714,4358, # 4160 -1967, 941,1864, 863, 664, 426, 560,1731,2680,1785,2864,1949,2363, 403,3330,1415, # 4176 -1279,2136,1697,2335, 204, 721,2097,3838, 90,6186,2085,2505, 191,3967, 124,2148, # 4192 -1376,1798,1178,1107,1898,1405, 860,4359,1243,1272,2375,2983,1558,2456,1638, 113, # 4208 -3621, 578,1923,2609, 880, 386,4130, 784,2186,2266,1422,2956,2172,1722, 497, 263, # 4224 -2514,1267,2412,2610, 177,2703,3542, 774,1927,1344, 616,1432,1595,1018, 172,4360, # 4240 -2325, 911,4361, 438,1468,3622, 794,3968,2024,2173,1681,1829,2957, 945, 895,3090, # 4256 - 575,2212,2476, 475,2401,2681, 785,2744,1745,2293,2555,1975,3133,2865, 394,4668, # 4272 -3839, 635,4131, 639, 202,1507,2195,2766,1345,1435,2572,3726,1908,1184,1181,2457, # 4288 -3727,3134,4362, 843,2611, 437, 916,4669, 234, 769,1884,3046,3047,3623, 833,6187, # 4304 -1639,2250,2402,1355,1185,2010,2047, 999, 525,1732,1290,1488,2612, 948,1578,3728, # 4320 -2413,2477,1216,2725,2159, 334,3840,1328,3624,2921,1525,4132, 564,1056, 891,4363, # 4336 -1444,1698,2385,2251,3729,1365,2281,2235,1717,6188, 864,3841,2515, 444, 527,2767, # 4352 -2922,3625, 544, 461,6189, 566, 209,2437,3398,2098,1065,2068,3331,3626,3257,2137, # 4368 #last 512 -) -# fmt: on diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/johabfreq.py b/myenv/Lib/site-packages/pip/_vendor/chardet/johabfreq.py deleted file mode 100644 index c129699..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/johabfreq.py +++ /dev/null @@ -1,2382 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Communicator client code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 ######################### - -# The frequency data itself is the same as euc-kr. -# This is just a mapping table to euc-kr. - -JOHAB_TO_EUCKR_ORDER_TABLE = { - 0x8861: 0, - 0x8862: 1, - 0x8865: 2, - 0x8868: 3, - 0x8869: 4, - 0x886A: 5, - 0x886B: 6, - 0x8871: 7, - 0x8873: 8, - 0x8874: 9, - 0x8875: 10, - 0x8876: 11, - 0x8877: 12, - 0x8878: 13, - 0x8879: 14, - 0x887B: 15, - 0x887C: 16, - 0x887D: 17, - 0x8881: 18, - 0x8882: 19, - 0x8885: 20, - 0x8889: 21, - 0x8891: 22, - 0x8893: 23, - 0x8895: 24, - 0x8896: 25, - 0x8897: 26, - 0x88A1: 27, - 0x88A2: 28, - 0x88A5: 29, - 0x88A9: 30, - 0x88B5: 31, - 0x88B7: 32, - 0x88C1: 33, - 0x88C5: 34, - 0x88C9: 35, - 0x88E1: 36, - 0x88E2: 37, - 0x88E5: 38, - 0x88E8: 39, - 0x88E9: 40, - 0x88EB: 41, - 0x88F1: 42, - 0x88F3: 43, - 0x88F5: 44, - 0x88F6: 45, - 0x88F7: 46, - 0x88F8: 47, - 0x88FB: 48, - 0x88FC: 49, - 0x88FD: 50, - 0x8941: 51, - 0x8945: 52, - 0x8949: 53, - 0x8951: 54, - 0x8953: 55, - 0x8955: 56, - 0x8956: 57, - 0x8957: 58, - 0x8961: 59, - 0x8962: 60, - 0x8963: 61, - 0x8965: 62, - 0x8968: 63, - 0x8969: 64, - 0x8971: 65, - 0x8973: 66, - 0x8975: 67, - 0x8976: 68, - 0x8977: 69, - 0x897B: 70, - 0x8981: 71, - 0x8985: 72, - 0x8989: 73, - 0x8993: 74, - 0x8995: 75, - 0x89A1: 76, - 0x89A2: 77, - 0x89A5: 78, - 0x89A8: 79, - 0x89A9: 80, - 0x89AB: 81, - 0x89AD: 82, - 0x89B0: 83, - 0x89B1: 84, - 0x89B3: 85, - 0x89B5: 86, - 0x89B7: 87, - 0x89B8: 88, - 0x89C1: 89, - 0x89C2: 90, - 0x89C5: 91, - 0x89C9: 92, - 0x89CB: 93, - 0x89D1: 94, - 0x89D3: 95, - 0x89D5: 96, - 0x89D7: 97, - 0x89E1: 98, - 0x89E5: 99, - 0x89E9: 100, - 0x89F3: 101, - 0x89F6: 102, - 0x89F7: 103, - 0x8A41: 104, - 0x8A42: 105, - 0x8A45: 106, - 0x8A49: 107, - 0x8A51: 108, - 0x8A53: 109, - 0x8A55: 110, - 0x8A57: 111, - 0x8A61: 112, - 0x8A65: 113, - 0x8A69: 114, - 0x8A73: 115, - 0x8A75: 116, - 0x8A81: 117, - 0x8A82: 118, - 0x8A85: 119, - 0x8A88: 120, - 0x8A89: 121, - 0x8A8A: 122, - 0x8A8B: 123, - 0x8A90: 124, - 0x8A91: 125, - 0x8A93: 126, - 0x8A95: 127, - 0x8A97: 128, - 0x8A98: 129, - 0x8AA1: 130, - 0x8AA2: 131, - 0x8AA5: 132, - 0x8AA9: 133, - 0x8AB6: 134, - 0x8AB7: 135, - 0x8AC1: 136, - 0x8AD5: 137, - 0x8AE1: 138, - 0x8AE2: 139, - 0x8AE5: 140, - 0x8AE9: 141, - 0x8AF1: 142, - 0x8AF3: 143, - 0x8AF5: 144, - 0x8B41: 145, - 0x8B45: 146, - 0x8B49: 147, - 0x8B61: 148, - 0x8B62: 149, - 0x8B65: 150, - 0x8B68: 151, - 0x8B69: 152, - 0x8B6A: 153, - 0x8B71: 154, - 0x8B73: 155, - 0x8B75: 156, - 0x8B77: 157, - 0x8B81: 158, - 0x8BA1: 159, - 0x8BA2: 160, - 0x8BA5: 161, - 0x8BA8: 162, - 0x8BA9: 163, - 0x8BAB: 164, - 0x8BB1: 165, - 0x8BB3: 166, - 0x8BB5: 167, - 0x8BB7: 168, - 0x8BB8: 169, - 0x8BBC: 170, - 0x8C61: 171, - 0x8C62: 172, - 0x8C63: 173, - 0x8C65: 174, - 0x8C69: 175, - 0x8C6B: 176, - 0x8C71: 177, - 0x8C73: 178, - 0x8C75: 179, - 0x8C76: 180, - 0x8C77: 181, - 0x8C7B: 182, - 0x8C81: 183, - 0x8C82: 184, - 0x8C85: 185, - 0x8C89: 186, - 0x8C91: 187, - 0x8C93: 188, - 0x8C95: 189, - 0x8C96: 190, - 0x8C97: 191, - 0x8CA1: 192, - 0x8CA2: 193, - 0x8CA9: 194, - 0x8CE1: 195, - 0x8CE2: 196, - 0x8CE3: 197, - 0x8CE5: 198, - 0x8CE9: 199, - 0x8CF1: 200, - 0x8CF3: 201, - 0x8CF5: 202, - 0x8CF6: 203, - 0x8CF7: 204, - 0x8D41: 205, - 0x8D42: 206, - 0x8D45: 207, - 0x8D51: 208, - 0x8D55: 209, - 0x8D57: 210, - 0x8D61: 211, - 0x8D65: 212, - 0x8D69: 213, - 0x8D75: 214, - 0x8D76: 215, - 0x8D7B: 216, - 0x8D81: 217, - 0x8DA1: 218, - 0x8DA2: 219, - 0x8DA5: 220, - 0x8DA7: 221, - 0x8DA9: 222, - 0x8DB1: 223, - 0x8DB3: 224, - 0x8DB5: 225, - 0x8DB7: 226, - 0x8DB8: 227, - 0x8DB9: 228, - 0x8DC1: 229, - 0x8DC2: 230, - 0x8DC9: 231, - 0x8DD6: 232, - 0x8DD7: 233, - 0x8DE1: 234, - 0x8DE2: 235, - 0x8DF7: 236, - 0x8E41: 237, - 0x8E45: 238, - 0x8E49: 239, - 0x8E51: 240, - 0x8E53: 241, - 0x8E57: 242, - 0x8E61: 243, - 0x8E81: 244, - 0x8E82: 245, - 0x8E85: 246, - 0x8E89: 247, - 0x8E90: 248, - 0x8E91: 249, - 0x8E93: 250, - 0x8E95: 251, - 0x8E97: 252, - 0x8E98: 253, - 0x8EA1: 254, - 0x8EA9: 255, - 0x8EB6: 256, - 0x8EB7: 257, - 0x8EC1: 258, - 0x8EC2: 259, - 0x8EC5: 260, - 0x8EC9: 261, - 0x8ED1: 262, - 0x8ED3: 263, - 0x8ED6: 264, - 0x8EE1: 265, - 0x8EE5: 266, - 0x8EE9: 267, - 0x8EF1: 268, - 0x8EF3: 269, - 0x8F41: 270, - 0x8F61: 271, - 0x8F62: 272, - 0x8F65: 273, - 0x8F67: 274, - 0x8F69: 275, - 0x8F6B: 276, - 0x8F70: 277, - 0x8F71: 278, - 0x8F73: 279, - 0x8F75: 280, - 0x8F77: 281, - 0x8F7B: 282, - 0x8FA1: 283, - 0x8FA2: 284, - 0x8FA5: 285, - 0x8FA9: 286, - 0x8FB1: 287, - 0x8FB3: 288, - 0x8FB5: 289, - 0x8FB7: 290, - 0x9061: 291, - 0x9062: 292, - 0x9063: 293, - 0x9065: 294, - 0x9068: 295, - 0x9069: 296, - 0x906A: 297, - 0x906B: 298, - 0x9071: 299, - 0x9073: 300, - 0x9075: 301, - 0x9076: 302, - 0x9077: 303, - 0x9078: 304, - 0x9079: 305, - 0x907B: 306, - 0x907D: 307, - 0x9081: 308, - 0x9082: 309, - 0x9085: 310, - 0x9089: 311, - 0x9091: 312, - 0x9093: 313, - 0x9095: 314, - 0x9096: 315, - 0x9097: 316, - 0x90A1: 317, - 0x90A2: 318, - 0x90A5: 319, - 0x90A9: 320, - 0x90B1: 321, - 0x90B7: 322, - 0x90E1: 323, - 0x90E2: 324, - 0x90E4: 325, - 0x90E5: 326, - 0x90E9: 327, - 0x90EB: 328, - 0x90EC: 329, - 0x90F1: 330, - 0x90F3: 331, - 0x90F5: 332, - 0x90F6: 333, - 0x90F7: 334, - 0x90FD: 335, - 0x9141: 336, - 0x9142: 337, - 0x9145: 338, - 0x9149: 339, - 0x9151: 340, - 0x9153: 341, - 0x9155: 342, - 0x9156: 343, - 0x9157: 344, - 0x9161: 345, - 0x9162: 346, - 0x9165: 347, - 0x9169: 348, - 0x9171: 349, - 0x9173: 350, - 0x9176: 351, - 0x9177: 352, - 0x917A: 353, - 0x9181: 354, - 0x9185: 355, - 0x91A1: 356, - 0x91A2: 357, - 0x91A5: 358, - 0x91A9: 359, - 0x91AB: 360, - 0x91B1: 361, - 0x91B3: 362, - 0x91B5: 363, - 0x91B7: 364, - 0x91BC: 365, - 0x91BD: 366, - 0x91C1: 367, - 0x91C5: 368, - 0x91C9: 369, - 0x91D6: 370, - 0x9241: 371, - 0x9245: 372, - 0x9249: 373, - 0x9251: 374, - 0x9253: 375, - 0x9255: 376, - 0x9261: 377, - 0x9262: 378, - 0x9265: 379, - 0x9269: 380, - 0x9273: 381, - 0x9275: 382, - 0x9277: 383, - 0x9281: 384, - 0x9282: 385, - 0x9285: 386, - 0x9288: 387, - 0x9289: 388, - 0x9291: 389, - 0x9293: 390, - 0x9295: 391, - 0x9297: 392, - 0x92A1: 393, - 0x92B6: 394, - 0x92C1: 395, - 0x92E1: 396, - 0x92E5: 397, - 0x92E9: 398, - 0x92F1: 399, - 0x92F3: 400, - 0x9341: 401, - 0x9342: 402, - 0x9349: 403, - 0x9351: 404, - 0x9353: 405, - 0x9357: 406, - 0x9361: 407, - 0x9362: 408, - 0x9365: 409, - 0x9369: 410, - 0x936A: 411, - 0x936B: 412, - 0x9371: 413, - 0x9373: 414, - 0x9375: 415, - 0x9377: 416, - 0x9378: 417, - 0x937C: 418, - 0x9381: 419, - 0x9385: 420, - 0x9389: 421, - 0x93A1: 422, - 0x93A2: 423, - 0x93A5: 424, - 0x93A9: 425, - 0x93AB: 426, - 0x93B1: 427, - 0x93B3: 428, - 0x93B5: 429, - 0x93B7: 430, - 0x93BC: 431, - 0x9461: 432, - 0x9462: 433, - 0x9463: 434, - 0x9465: 435, - 0x9468: 436, - 0x9469: 437, - 0x946A: 438, - 0x946B: 439, - 0x946C: 440, - 0x9470: 441, - 0x9471: 442, - 0x9473: 443, - 0x9475: 444, - 0x9476: 445, - 0x9477: 446, - 0x9478: 447, - 0x9479: 448, - 0x947D: 449, - 0x9481: 450, - 0x9482: 451, - 0x9485: 452, - 0x9489: 453, - 0x9491: 454, - 0x9493: 455, - 0x9495: 456, - 0x9496: 457, - 0x9497: 458, - 0x94A1: 459, - 0x94E1: 460, - 0x94E2: 461, - 0x94E3: 462, - 0x94E5: 463, - 0x94E8: 464, - 0x94E9: 465, - 0x94EB: 466, - 0x94EC: 467, - 0x94F1: 468, - 0x94F3: 469, - 0x94F5: 470, - 0x94F7: 471, - 0x94F9: 472, - 0x94FC: 473, - 0x9541: 474, - 0x9542: 475, - 0x9545: 476, - 0x9549: 477, - 0x9551: 478, - 0x9553: 479, - 0x9555: 480, - 0x9556: 481, - 0x9557: 482, - 0x9561: 483, - 0x9565: 484, - 0x9569: 485, - 0x9576: 486, - 0x9577: 487, - 0x9581: 488, - 0x9585: 489, - 0x95A1: 490, - 0x95A2: 491, - 0x95A5: 492, - 0x95A8: 493, - 0x95A9: 494, - 0x95AB: 495, - 0x95AD: 496, - 0x95B1: 497, - 0x95B3: 498, - 0x95B5: 499, - 0x95B7: 500, - 0x95B9: 501, - 0x95BB: 502, - 0x95C1: 503, - 0x95C5: 504, - 0x95C9: 505, - 0x95E1: 506, - 0x95F6: 507, - 0x9641: 508, - 0x9645: 509, - 0x9649: 510, - 0x9651: 511, - 0x9653: 512, - 0x9655: 513, - 0x9661: 514, - 0x9681: 515, - 0x9682: 516, - 0x9685: 517, - 0x9689: 518, - 0x9691: 519, - 0x9693: 520, - 0x9695: 521, - 0x9697: 522, - 0x96A1: 523, - 0x96B6: 524, - 0x96C1: 525, - 0x96D7: 526, - 0x96E1: 527, - 0x96E5: 528, - 0x96E9: 529, - 0x96F3: 530, - 0x96F5: 531, - 0x96F7: 532, - 0x9741: 533, - 0x9745: 534, - 0x9749: 535, - 0x9751: 536, - 0x9757: 537, - 0x9761: 538, - 0x9762: 539, - 0x9765: 540, - 0x9768: 541, - 0x9769: 542, - 0x976B: 543, - 0x9771: 544, - 0x9773: 545, - 0x9775: 546, - 0x9777: 547, - 0x9781: 548, - 0x97A1: 549, - 0x97A2: 550, - 0x97A5: 551, - 0x97A8: 552, - 0x97A9: 553, - 0x97B1: 554, - 0x97B3: 555, - 0x97B5: 556, - 0x97B6: 557, - 0x97B7: 558, - 0x97B8: 559, - 0x9861: 560, - 0x9862: 561, - 0x9865: 562, - 0x9869: 563, - 0x9871: 564, - 0x9873: 565, - 0x9875: 566, - 0x9876: 567, - 0x9877: 568, - 0x987D: 569, - 0x9881: 570, - 0x9882: 571, - 0x9885: 572, - 0x9889: 573, - 0x9891: 574, - 0x9893: 575, - 0x9895: 576, - 0x9896: 577, - 0x9897: 578, - 0x98E1: 579, - 0x98E2: 580, - 0x98E5: 581, - 0x98E9: 582, - 0x98EB: 583, - 0x98EC: 584, - 0x98F1: 585, - 0x98F3: 586, - 0x98F5: 587, - 0x98F6: 588, - 0x98F7: 589, - 0x98FD: 590, - 0x9941: 591, - 0x9942: 592, - 0x9945: 593, - 0x9949: 594, - 0x9951: 595, - 0x9953: 596, - 0x9955: 597, - 0x9956: 598, - 0x9957: 599, - 0x9961: 600, - 0x9976: 601, - 0x99A1: 602, - 0x99A2: 603, - 0x99A5: 604, - 0x99A9: 605, - 0x99B7: 606, - 0x99C1: 607, - 0x99C9: 608, - 0x99E1: 609, - 0x9A41: 610, - 0x9A45: 611, - 0x9A81: 612, - 0x9A82: 613, - 0x9A85: 614, - 0x9A89: 615, - 0x9A90: 616, - 0x9A91: 617, - 0x9A97: 618, - 0x9AC1: 619, - 0x9AE1: 620, - 0x9AE5: 621, - 0x9AE9: 622, - 0x9AF1: 623, - 0x9AF3: 624, - 0x9AF7: 625, - 0x9B61: 626, - 0x9B62: 627, - 0x9B65: 628, - 0x9B68: 629, - 0x9B69: 630, - 0x9B71: 631, - 0x9B73: 632, - 0x9B75: 633, - 0x9B81: 634, - 0x9B85: 635, - 0x9B89: 636, - 0x9B91: 637, - 0x9B93: 638, - 0x9BA1: 639, - 0x9BA5: 640, - 0x9BA9: 641, - 0x9BB1: 642, - 0x9BB3: 643, - 0x9BB5: 644, - 0x9BB7: 645, - 0x9C61: 646, - 0x9C62: 647, - 0x9C65: 648, - 0x9C69: 649, - 0x9C71: 650, - 0x9C73: 651, - 0x9C75: 652, - 0x9C76: 653, - 0x9C77: 654, - 0x9C78: 655, - 0x9C7C: 656, - 0x9C7D: 657, - 0x9C81: 658, - 0x9C82: 659, - 0x9C85: 660, - 0x9C89: 661, - 0x9C91: 662, - 0x9C93: 663, - 0x9C95: 664, - 0x9C96: 665, - 0x9C97: 666, - 0x9CA1: 667, - 0x9CA2: 668, - 0x9CA5: 669, - 0x9CB5: 670, - 0x9CB7: 671, - 0x9CE1: 672, - 0x9CE2: 673, - 0x9CE5: 674, - 0x9CE9: 675, - 0x9CF1: 676, - 0x9CF3: 677, - 0x9CF5: 678, - 0x9CF6: 679, - 0x9CF7: 680, - 0x9CFD: 681, - 0x9D41: 682, - 0x9D42: 683, - 0x9D45: 684, - 0x9D49: 685, - 0x9D51: 686, - 0x9D53: 687, - 0x9D55: 688, - 0x9D57: 689, - 0x9D61: 690, - 0x9D62: 691, - 0x9D65: 692, - 0x9D69: 693, - 0x9D71: 694, - 0x9D73: 695, - 0x9D75: 696, - 0x9D76: 697, - 0x9D77: 698, - 0x9D81: 699, - 0x9D85: 700, - 0x9D93: 701, - 0x9D95: 702, - 0x9DA1: 703, - 0x9DA2: 704, - 0x9DA5: 705, - 0x9DA9: 706, - 0x9DB1: 707, - 0x9DB3: 708, - 0x9DB5: 709, - 0x9DB7: 710, - 0x9DC1: 711, - 0x9DC5: 712, - 0x9DD7: 713, - 0x9DF6: 714, - 0x9E41: 715, - 0x9E45: 716, - 0x9E49: 717, - 0x9E51: 718, - 0x9E53: 719, - 0x9E55: 720, - 0x9E57: 721, - 0x9E61: 722, - 0x9E65: 723, - 0x9E69: 724, - 0x9E73: 725, - 0x9E75: 726, - 0x9E77: 727, - 0x9E81: 728, - 0x9E82: 729, - 0x9E85: 730, - 0x9E89: 731, - 0x9E91: 732, - 0x9E93: 733, - 0x9E95: 734, - 0x9E97: 735, - 0x9EA1: 736, - 0x9EB6: 737, - 0x9EC1: 738, - 0x9EE1: 739, - 0x9EE2: 740, - 0x9EE5: 741, - 0x9EE9: 742, - 0x9EF1: 743, - 0x9EF5: 744, - 0x9EF7: 745, - 0x9F41: 746, - 0x9F42: 747, - 0x9F45: 748, - 0x9F49: 749, - 0x9F51: 750, - 0x9F53: 751, - 0x9F55: 752, - 0x9F57: 753, - 0x9F61: 754, - 0x9F62: 755, - 0x9F65: 756, - 0x9F69: 757, - 0x9F71: 758, - 0x9F73: 759, - 0x9F75: 760, - 0x9F77: 761, - 0x9F78: 762, - 0x9F7B: 763, - 0x9F7C: 764, - 0x9FA1: 765, - 0x9FA2: 766, - 0x9FA5: 767, - 0x9FA9: 768, - 0x9FB1: 769, - 0x9FB3: 770, - 0x9FB5: 771, - 0x9FB7: 772, - 0xA061: 773, - 0xA062: 774, - 0xA065: 775, - 0xA067: 776, - 0xA068: 777, - 0xA069: 778, - 0xA06A: 779, - 0xA06B: 780, - 0xA071: 781, - 0xA073: 782, - 0xA075: 783, - 0xA077: 784, - 0xA078: 785, - 0xA07B: 786, - 0xA07D: 787, - 0xA081: 788, - 0xA082: 789, - 0xA085: 790, - 0xA089: 791, - 0xA091: 792, - 0xA093: 793, - 0xA095: 794, - 0xA096: 795, - 0xA097: 796, - 0xA098: 797, - 0xA0A1: 798, - 0xA0A2: 799, - 0xA0A9: 800, - 0xA0B7: 801, - 0xA0E1: 802, - 0xA0E2: 803, - 0xA0E5: 804, - 0xA0E9: 805, - 0xA0EB: 806, - 0xA0F1: 807, - 0xA0F3: 808, - 0xA0F5: 809, - 0xA0F7: 810, - 0xA0F8: 811, - 0xA0FD: 812, - 0xA141: 813, - 0xA142: 814, - 0xA145: 815, - 0xA149: 816, - 0xA151: 817, - 0xA153: 818, - 0xA155: 819, - 0xA156: 820, - 0xA157: 821, - 0xA161: 822, - 0xA162: 823, - 0xA165: 824, - 0xA169: 825, - 0xA175: 826, - 0xA176: 827, - 0xA177: 828, - 0xA179: 829, - 0xA181: 830, - 0xA1A1: 831, - 0xA1A2: 832, - 0xA1A4: 833, - 0xA1A5: 834, - 0xA1A9: 835, - 0xA1AB: 836, - 0xA1B1: 837, - 0xA1B3: 838, - 0xA1B5: 839, - 0xA1B7: 840, - 0xA1C1: 841, - 0xA1C5: 842, - 0xA1D6: 843, - 0xA1D7: 844, - 0xA241: 845, - 0xA245: 846, - 0xA249: 847, - 0xA253: 848, - 0xA255: 849, - 0xA257: 850, - 0xA261: 851, - 0xA265: 852, - 0xA269: 853, - 0xA273: 854, - 0xA275: 855, - 0xA281: 856, - 0xA282: 857, - 0xA283: 858, - 0xA285: 859, - 0xA288: 860, - 0xA289: 861, - 0xA28A: 862, - 0xA28B: 863, - 0xA291: 864, - 0xA293: 865, - 0xA295: 866, - 0xA297: 867, - 0xA29B: 868, - 0xA29D: 869, - 0xA2A1: 870, - 0xA2A5: 871, - 0xA2A9: 872, - 0xA2B3: 873, - 0xA2B5: 874, - 0xA2C1: 875, - 0xA2E1: 876, - 0xA2E5: 877, - 0xA2E9: 878, - 0xA341: 879, - 0xA345: 880, - 0xA349: 881, - 0xA351: 882, - 0xA355: 883, - 0xA361: 884, - 0xA365: 885, - 0xA369: 886, - 0xA371: 887, - 0xA375: 888, - 0xA3A1: 889, - 0xA3A2: 890, - 0xA3A5: 891, - 0xA3A8: 892, - 0xA3A9: 893, - 0xA3AB: 894, - 0xA3B1: 895, - 0xA3B3: 896, - 0xA3B5: 897, - 0xA3B6: 898, - 0xA3B7: 899, - 0xA3B9: 900, - 0xA3BB: 901, - 0xA461: 902, - 0xA462: 903, - 0xA463: 904, - 0xA464: 905, - 0xA465: 906, - 0xA468: 907, - 0xA469: 908, - 0xA46A: 909, - 0xA46B: 910, - 0xA46C: 911, - 0xA471: 912, - 0xA473: 913, - 0xA475: 914, - 0xA477: 915, - 0xA47B: 916, - 0xA481: 917, - 0xA482: 918, - 0xA485: 919, - 0xA489: 920, - 0xA491: 921, - 0xA493: 922, - 0xA495: 923, - 0xA496: 924, - 0xA497: 925, - 0xA49B: 926, - 0xA4A1: 927, - 0xA4A2: 928, - 0xA4A5: 929, - 0xA4B3: 930, - 0xA4E1: 931, - 0xA4E2: 932, - 0xA4E5: 933, - 0xA4E8: 934, - 0xA4E9: 935, - 0xA4EB: 936, - 0xA4F1: 937, - 0xA4F3: 938, - 0xA4F5: 939, - 0xA4F7: 940, - 0xA4F8: 941, - 0xA541: 942, - 0xA542: 943, - 0xA545: 944, - 0xA548: 945, - 0xA549: 946, - 0xA551: 947, - 0xA553: 948, - 0xA555: 949, - 0xA556: 950, - 0xA557: 951, - 0xA561: 952, - 0xA562: 953, - 0xA565: 954, - 0xA569: 955, - 0xA573: 956, - 0xA575: 957, - 0xA576: 958, - 0xA577: 959, - 0xA57B: 960, - 0xA581: 961, - 0xA585: 962, - 0xA5A1: 963, - 0xA5A2: 964, - 0xA5A3: 965, - 0xA5A5: 966, - 0xA5A9: 967, - 0xA5B1: 968, - 0xA5B3: 969, - 0xA5B5: 970, - 0xA5B7: 971, - 0xA5C1: 972, - 0xA5C5: 973, - 0xA5D6: 974, - 0xA5E1: 975, - 0xA5F6: 976, - 0xA641: 977, - 0xA642: 978, - 0xA645: 979, - 0xA649: 980, - 0xA651: 981, - 0xA653: 982, - 0xA661: 983, - 0xA665: 984, - 0xA681: 985, - 0xA682: 986, - 0xA685: 987, - 0xA688: 988, - 0xA689: 989, - 0xA68A: 990, - 0xA68B: 991, - 0xA691: 992, - 0xA693: 993, - 0xA695: 994, - 0xA697: 995, - 0xA69B: 996, - 0xA69C: 997, - 0xA6A1: 998, - 0xA6A9: 999, - 0xA6B6: 1000, - 0xA6C1: 1001, - 0xA6E1: 1002, - 0xA6E2: 1003, - 0xA6E5: 1004, - 0xA6E9: 1005, - 0xA6F7: 1006, - 0xA741: 1007, - 0xA745: 1008, - 0xA749: 1009, - 0xA751: 1010, - 0xA755: 1011, - 0xA757: 1012, - 0xA761: 1013, - 0xA762: 1014, - 0xA765: 1015, - 0xA769: 1016, - 0xA771: 1017, - 0xA773: 1018, - 0xA775: 1019, - 0xA7A1: 1020, - 0xA7A2: 1021, - 0xA7A5: 1022, - 0xA7A9: 1023, - 0xA7AB: 1024, - 0xA7B1: 1025, - 0xA7B3: 1026, - 0xA7B5: 1027, - 0xA7B7: 1028, - 0xA7B8: 1029, - 0xA7B9: 1030, - 0xA861: 1031, - 0xA862: 1032, - 0xA865: 1033, - 0xA869: 1034, - 0xA86B: 1035, - 0xA871: 1036, - 0xA873: 1037, - 0xA875: 1038, - 0xA876: 1039, - 0xA877: 1040, - 0xA87D: 1041, - 0xA881: 1042, - 0xA882: 1043, - 0xA885: 1044, - 0xA889: 1045, - 0xA891: 1046, - 0xA893: 1047, - 0xA895: 1048, - 0xA896: 1049, - 0xA897: 1050, - 0xA8A1: 1051, - 0xA8A2: 1052, - 0xA8B1: 1053, - 0xA8E1: 1054, - 0xA8E2: 1055, - 0xA8E5: 1056, - 0xA8E8: 1057, - 0xA8E9: 1058, - 0xA8F1: 1059, - 0xA8F5: 1060, - 0xA8F6: 1061, - 0xA8F7: 1062, - 0xA941: 1063, - 0xA957: 1064, - 0xA961: 1065, - 0xA962: 1066, - 0xA971: 1067, - 0xA973: 1068, - 0xA975: 1069, - 0xA976: 1070, - 0xA977: 1071, - 0xA9A1: 1072, - 0xA9A2: 1073, - 0xA9A5: 1074, - 0xA9A9: 1075, - 0xA9B1: 1076, - 0xA9B3: 1077, - 0xA9B7: 1078, - 0xAA41: 1079, - 0xAA61: 1080, - 0xAA77: 1081, - 0xAA81: 1082, - 0xAA82: 1083, - 0xAA85: 1084, - 0xAA89: 1085, - 0xAA91: 1086, - 0xAA95: 1087, - 0xAA97: 1088, - 0xAB41: 1089, - 0xAB57: 1090, - 0xAB61: 1091, - 0xAB65: 1092, - 0xAB69: 1093, - 0xAB71: 1094, - 0xAB73: 1095, - 0xABA1: 1096, - 0xABA2: 1097, - 0xABA5: 1098, - 0xABA9: 1099, - 0xABB1: 1100, - 0xABB3: 1101, - 0xABB5: 1102, - 0xABB7: 1103, - 0xAC61: 1104, - 0xAC62: 1105, - 0xAC64: 1106, - 0xAC65: 1107, - 0xAC68: 1108, - 0xAC69: 1109, - 0xAC6A: 1110, - 0xAC6B: 1111, - 0xAC71: 1112, - 0xAC73: 1113, - 0xAC75: 1114, - 0xAC76: 1115, - 0xAC77: 1116, - 0xAC7B: 1117, - 0xAC81: 1118, - 0xAC82: 1119, - 0xAC85: 1120, - 0xAC89: 1121, - 0xAC91: 1122, - 0xAC93: 1123, - 0xAC95: 1124, - 0xAC96: 1125, - 0xAC97: 1126, - 0xACA1: 1127, - 0xACA2: 1128, - 0xACA5: 1129, - 0xACA9: 1130, - 0xACB1: 1131, - 0xACB3: 1132, - 0xACB5: 1133, - 0xACB7: 1134, - 0xACC1: 1135, - 0xACC5: 1136, - 0xACC9: 1137, - 0xACD1: 1138, - 0xACD7: 1139, - 0xACE1: 1140, - 0xACE2: 1141, - 0xACE3: 1142, - 0xACE4: 1143, - 0xACE5: 1144, - 0xACE8: 1145, - 0xACE9: 1146, - 0xACEB: 1147, - 0xACEC: 1148, - 0xACF1: 1149, - 0xACF3: 1150, - 0xACF5: 1151, - 0xACF6: 1152, - 0xACF7: 1153, - 0xACFC: 1154, - 0xAD41: 1155, - 0xAD42: 1156, - 0xAD45: 1157, - 0xAD49: 1158, - 0xAD51: 1159, - 0xAD53: 1160, - 0xAD55: 1161, - 0xAD56: 1162, - 0xAD57: 1163, - 0xAD61: 1164, - 0xAD62: 1165, - 0xAD65: 1166, - 0xAD69: 1167, - 0xAD71: 1168, - 0xAD73: 1169, - 0xAD75: 1170, - 0xAD76: 1171, - 0xAD77: 1172, - 0xAD81: 1173, - 0xAD85: 1174, - 0xAD89: 1175, - 0xAD97: 1176, - 0xADA1: 1177, - 0xADA2: 1178, - 0xADA3: 1179, - 0xADA5: 1180, - 0xADA9: 1181, - 0xADAB: 1182, - 0xADB1: 1183, - 0xADB3: 1184, - 0xADB5: 1185, - 0xADB7: 1186, - 0xADBB: 1187, - 0xADC1: 1188, - 0xADC2: 1189, - 0xADC5: 1190, - 0xADC9: 1191, - 0xADD7: 1192, - 0xADE1: 1193, - 0xADE5: 1194, - 0xADE9: 1195, - 0xADF1: 1196, - 0xADF5: 1197, - 0xADF6: 1198, - 0xAE41: 1199, - 0xAE45: 1200, - 0xAE49: 1201, - 0xAE51: 1202, - 0xAE53: 1203, - 0xAE55: 1204, - 0xAE61: 1205, - 0xAE62: 1206, - 0xAE65: 1207, - 0xAE69: 1208, - 0xAE71: 1209, - 0xAE73: 1210, - 0xAE75: 1211, - 0xAE77: 1212, - 0xAE81: 1213, - 0xAE82: 1214, - 0xAE85: 1215, - 0xAE88: 1216, - 0xAE89: 1217, - 0xAE91: 1218, - 0xAE93: 1219, - 0xAE95: 1220, - 0xAE97: 1221, - 0xAE99: 1222, - 0xAE9B: 1223, - 0xAE9C: 1224, - 0xAEA1: 1225, - 0xAEB6: 1226, - 0xAEC1: 1227, - 0xAEC2: 1228, - 0xAEC5: 1229, - 0xAEC9: 1230, - 0xAED1: 1231, - 0xAED7: 1232, - 0xAEE1: 1233, - 0xAEE2: 1234, - 0xAEE5: 1235, - 0xAEE9: 1236, - 0xAEF1: 1237, - 0xAEF3: 1238, - 0xAEF5: 1239, - 0xAEF7: 1240, - 0xAF41: 1241, - 0xAF42: 1242, - 0xAF49: 1243, - 0xAF51: 1244, - 0xAF55: 1245, - 0xAF57: 1246, - 0xAF61: 1247, - 0xAF62: 1248, - 0xAF65: 1249, - 0xAF69: 1250, - 0xAF6A: 1251, - 0xAF71: 1252, - 0xAF73: 1253, - 0xAF75: 1254, - 0xAF77: 1255, - 0xAFA1: 1256, - 0xAFA2: 1257, - 0xAFA5: 1258, - 0xAFA8: 1259, - 0xAFA9: 1260, - 0xAFB0: 1261, - 0xAFB1: 1262, - 0xAFB3: 1263, - 0xAFB5: 1264, - 0xAFB7: 1265, - 0xAFBC: 1266, - 0xB061: 1267, - 0xB062: 1268, - 0xB064: 1269, - 0xB065: 1270, - 0xB069: 1271, - 0xB071: 1272, - 0xB073: 1273, - 0xB076: 1274, - 0xB077: 1275, - 0xB07D: 1276, - 0xB081: 1277, - 0xB082: 1278, - 0xB085: 1279, - 0xB089: 1280, - 0xB091: 1281, - 0xB093: 1282, - 0xB096: 1283, - 0xB097: 1284, - 0xB0B7: 1285, - 0xB0E1: 1286, - 0xB0E2: 1287, - 0xB0E5: 1288, - 0xB0E9: 1289, - 0xB0EB: 1290, - 0xB0F1: 1291, - 0xB0F3: 1292, - 0xB0F6: 1293, - 0xB0F7: 1294, - 0xB141: 1295, - 0xB145: 1296, - 0xB149: 1297, - 0xB185: 1298, - 0xB1A1: 1299, - 0xB1A2: 1300, - 0xB1A5: 1301, - 0xB1A8: 1302, - 0xB1A9: 1303, - 0xB1AB: 1304, - 0xB1B1: 1305, - 0xB1B3: 1306, - 0xB1B7: 1307, - 0xB1C1: 1308, - 0xB1C2: 1309, - 0xB1C5: 1310, - 0xB1D6: 1311, - 0xB1E1: 1312, - 0xB1F6: 1313, - 0xB241: 1314, - 0xB245: 1315, - 0xB249: 1316, - 0xB251: 1317, - 0xB253: 1318, - 0xB261: 1319, - 0xB281: 1320, - 0xB282: 1321, - 0xB285: 1322, - 0xB289: 1323, - 0xB291: 1324, - 0xB293: 1325, - 0xB297: 1326, - 0xB2A1: 1327, - 0xB2B6: 1328, - 0xB2C1: 1329, - 0xB2E1: 1330, - 0xB2E5: 1331, - 0xB357: 1332, - 0xB361: 1333, - 0xB362: 1334, - 0xB365: 1335, - 0xB369: 1336, - 0xB36B: 1337, - 0xB370: 1338, - 0xB371: 1339, - 0xB373: 1340, - 0xB381: 1341, - 0xB385: 1342, - 0xB389: 1343, - 0xB391: 1344, - 0xB3A1: 1345, - 0xB3A2: 1346, - 0xB3A5: 1347, - 0xB3A9: 1348, - 0xB3B1: 1349, - 0xB3B3: 1350, - 0xB3B5: 1351, - 0xB3B7: 1352, - 0xB461: 1353, - 0xB462: 1354, - 0xB465: 1355, - 0xB466: 1356, - 0xB467: 1357, - 0xB469: 1358, - 0xB46A: 1359, - 0xB46B: 1360, - 0xB470: 1361, - 0xB471: 1362, - 0xB473: 1363, - 0xB475: 1364, - 0xB476: 1365, - 0xB477: 1366, - 0xB47B: 1367, - 0xB47C: 1368, - 0xB481: 1369, - 0xB482: 1370, - 0xB485: 1371, - 0xB489: 1372, - 0xB491: 1373, - 0xB493: 1374, - 0xB495: 1375, - 0xB496: 1376, - 0xB497: 1377, - 0xB4A1: 1378, - 0xB4A2: 1379, - 0xB4A5: 1380, - 0xB4A9: 1381, - 0xB4AC: 1382, - 0xB4B1: 1383, - 0xB4B3: 1384, - 0xB4B5: 1385, - 0xB4B7: 1386, - 0xB4BB: 1387, - 0xB4BD: 1388, - 0xB4C1: 1389, - 0xB4C5: 1390, - 0xB4C9: 1391, - 0xB4D3: 1392, - 0xB4E1: 1393, - 0xB4E2: 1394, - 0xB4E5: 1395, - 0xB4E6: 1396, - 0xB4E8: 1397, - 0xB4E9: 1398, - 0xB4EA: 1399, - 0xB4EB: 1400, - 0xB4F1: 1401, - 0xB4F3: 1402, - 0xB4F4: 1403, - 0xB4F5: 1404, - 0xB4F6: 1405, - 0xB4F7: 1406, - 0xB4F8: 1407, - 0xB4FA: 1408, - 0xB4FC: 1409, - 0xB541: 1410, - 0xB542: 1411, - 0xB545: 1412, - 0xB549: 1413, - 0xB551: 1414, - 0xB553: 1415, - 0xB555: 1416, - 0xB557: 1417, - 0xB561: 1418, - 0xB562: 1419, - 0xB563: 1420, - 0xB565: 1421, - 0xB569: 1422, - 0xB56B: 1423, - 0xB56C: 1424, - 0xB571: 1425, - 0xB573: 1426, - 0xB574: 1427, - 0xB575: 1428, - 0xB576: 1429, - 0xB577: 1430, - 0xB57B: 1431, - 0xB57C: 1432, - 0xB57D: 1433, - 0xB581: 1434, - 0xB585: 1435, - 0xB589: 1436, - 0xB591: 1437, - 0xB593: 1438, - 0xB595: 1439, - 0xB596: 1440, - 0xB5A1: 1441, - 0xB5A2: 1442, - 0xB5A5: 1443, - 0xB5A9: 1444, - 0xB5AA: 1445, - 0xB5AB: 1446, - 0xB5AD: 1447, - 0xB5B0: 1448, - 0xB5B1: 1449, - 0xB5B3: 1450, - 0xB5B5: 1451, - 0xB5B7: 1452, - 0xB5B9: 1453, - 0xB5C1: 1454, - 0xB5C2: 1455, - 0xB5C5: 1456, - 0xB5C9: 1457, - 0xB5D1: 1458, - 0xB5D3: 1459, - 0xB5D5: 1460, - 0xB5D6: 1461, - 0xB5D7: 1462, - 0xB5E1: 1463, - 0xB5E2: 1464, - 0xB5E5: 1465, - 0xB5F1: 1466, - 0xB5F5: 1467, - 0xB5F7: 1468, - 0xB641: 1469, - 0xB642: 1470, - 0xB645: 1471, - 0xB649: 1472, - 0xB651: 1473, - 0xB653: 1474, - 0xB655: 1475, - 0xB657: 1476, - 0xB661: 1477, - 0xB662: 1478, - 0xB665: 1479, - 0xB669: 1480, - 0xB671: 1481, - 0xB673: 1482, - 0xB675: 1483, - 0xB677: 1484, - 0xB681: 1485, - 0xB682: 1486, - 0xB685: 1487, - 0xB689: 1488, - 0xB68A: 1489, - 0xB68B: 1490, - 0xB691: 1491, - 0xB693: 1492, - 0xB695: 1493, - 0xB697: 1494, - 0xB6A1: 1495, - 0xB6A2: 1496, - 0xB6A5: 1497, - 0xB6A9: 1498, - 0xB6B1: 1499, - 0xB6B3: 1500, - 0xB6B6: 1501, - 0xB6B7: 1502, - 0xB6C1: 1503, - 0xB6C2: 1504, - 0xB6C5: 1505, - 0xB6C9: 1506, - 0xB6D1: 1507, - 0xB6D3: 1508, - 0xB6D7: 1509, - 0xB6E1: 1510, - 0xB6E2: 1511, - 0xB6E5: 1512, - 0xB6E9: 1513, - 0xB6F1: 1514, - 0xB6F3: 1515, - 0xB6F5: 1516, - 0xB6F7: 1517, - 0xB741: 1518, - 0xB742: 1519, - 0xB745: 1520, - 0xB749: 1521, - 0xB751: 1522, - 0xB753: 1523, - 0xB755: 1524, - 0xB757: 1525, - 0xB759: 1526, - 0xB761: 1527, - 0xB762: 1528, - 0xB765: 1529, - 0xB769: 1530, - 0xB76F: 1531, - 0xB771: 1532, - 0xB773: 1533, - 0xB775: 1534, - 0xB777: 1535, - 0xB778: 1536, - 0xB779: 1537, - 0xB77A: 1538, - 0xB77B: 1539, - 0xB77C: 1540, - 0xB77D: 1541, - 0xB781: 1542, - 0xB785: 1543, - 0xB789: 1544, - 0xB791: 1545, - 0xB795: 1546, - 0xB7A1: 1547, - 0xB7A2: 1548, - 0xB7A5: 1549, - 0xB7A9: 1550, - 0xB7AA: 1551, - 0xB7AB: 1552, - 0xB7B0: 1553, - 0xB7B1: 1554, - 0xB7B3: 1555, - 0xB7B5: 1556, - 0xB7B6: 1557, - 0xB7B7: 1558, - 0xB7B8: 1559, - 0xB7BC: 1560, - 0xB861: 1561, - 0xB862: 1562, - 0xB865: 1563, - 0xB867: 1564, - 0xB868: 1565, - 0xB869: 1566, - 0xB86B: 1567, - 0xB871: 1568, - 0xB873: 1569, - 0xB875: 1570, - 0xB876: 1571, - 0xB877: 1572, - 0xB878: 1573, - 0xB881: 1574, - 0xB882: 1575, - 0xB885: 1576, - 0xB889: 1577, - 0xB891: 1578, - 0xB893: 1579, - 0xB895: 1580, - 0xB896: 1581, - 0xB897: 1582, - 0xB8A1: 1583, - 0xB8A2: 1584, - 0xB8A5: 1585, - 0xB8A7: 1586, - 0xB8A9: 1587, - 0xB8B1: 1588, - 0xB8B7: 1589, - 0xB8C1: 1590, - 0xB8C5: 1591, - 0xB8C9: 1592, - 0xB8E1: 1593, - 0xB8E2: 1594, - 0xB8E5: 1595, - 0xB8E9: 1596, - 0xB8EB: 1597, - 0xB8F1: 1598, - 0xB8F3: 1599, - 0xB8F5: 1600, - 0xB8F7: 1601, - 0xB8F8: 1602, - 0xB941: 1603, - 0xB942: 1604, - 0xB945: 1605, - 0xB949: 1606, - 0xB951: 1607, - 0xB953: 1608, - 0xB955: 1609, - 0xB957: 1610, - 0xB961: 1611, - 0xB965: 1612, - 0xB969: 1613, - 0xB971: 1614, - 0xB973: 1615, - 0xB976: 1616, - 0xB977: 1617, - 0xB981: 1618, - 0xB9A1: 1619, - 0xB9A2: 1620, - 0xB9A5: 1621, - 0xB9A9: 1622, - 0xB9AB: 1623, - 0xB9B1: 1624, - 0xB9B3: 1625, - 0xB9B5: 1626, - 0xB9B7: 1627, - 0xB9B8: 1628, - 0xB9B9: 1629, - 0xB9BD: 1630, - 0xB9C1: 1631, - 0xB9C2: 1632, - 0xB9C9: 1633, - 0xB9D3: 1634, - 0xB9D5: 1635, - 0xB9D7: 1636, - 0xB9E1: 1637, - 0xB9F6: 1638, - 0xB9F7: 1639, - 0xBA41: 1640, - 0xBA45: 1641, - 0xBA49: 1642, - 0xBA51: 1643, - 0xBA53: 1644, - 0xBA55: 1645, - 0xBA57: 1646, - 0xBA61: 1647, - 0xBA62: 1648, - 0xBA65: 1649, - 0xBA77: 1650, - 0xBA81: 1651, - 0xBA82: 1652, - 0xBA85: 1653, - 0xBA89: 1654, - 0xBA8A: 1655, - 0xBA8B: 1656, - 0xBA91: 1657, - 0xBA93: 1658, - 0xBA95: 1659, - 0xBA97: 1660, - 0xBAA1: 1661, - 0xBAB6: 1662, - 0xBAC1: 1663, - 0xBAE1: 1664, - 0xBAE2: 1665, - 0xBAE5: 1666, - 0xBAE9: 1667, - 0xBAF1: 1668, - 0xBAF3: 1669, - 0xBAF5: 1670, - 0xBB41: 1671, - 0xBB45: 1672, - 0xBB49: 1673, - 0xBB51: 1674, - 0xBB61: 1675, - 0xBB62: 1676, - 0xBB65: 1677, - 0xBB69: 1678, - 0xBB71: 1679, - 0xBB73: 1680, - 0xBB75: 1681, - 0xBB77: 1682, - 0xBBA1: 1683, - 0xBBA2: 1684, - 0xBBA5: 1685, - 0xBBA8: 1686, - 0xBBA9: 1687, - 0xBBAB: 1688, - 0xBBB1: 1689, - 0xBBB3: 1690, - 0xBBB5: 1691, - 0xBBB7: 1692, - 0xBBB8: 1693, - 0xBBBB: 1694, - 0xBBBC: 1695, - 0xBC61: 1696, - 0xBC62: 1697, - 0xBC65: 1698, - 0xBC67: 1699, - 0xBC69: 1700, - 0xBC6C: 1701, - 0xBC71: 1702, - 0xBC73: 1703, - 0xBC75: 1704, - 0xBC76: 1705, - 0xBC77: 1706, - 0xBC81: 1707, - 0xBC82: 1708, - 0xBC85: 1709, - 0xBC89: 1710, - 0xBC91: 1711, - 0xBC93: 1712, - 0xBC95: 1713, - 0xBC96: 1714, - 0xBC97: 1715, - 0xBCA1: 1716, - 0xBCA5: 1717, - 0xBCB7: 1718, - 0xBCE1: 1719, - 0xBCE2: 1720, - 0xBCE5: 1721, - 0xBCE9: 1722, - 0xBCF1: 1723, - 0xBCF3: 1724, - 0xBCF5: 1725, - 0xBCF6: 1726, - 0xBCF7: 1727, - 0xBD41: 1728, - 0xBD57: 1729, - 0xBD61: 1730, - 0xBD76: 1731, - 0xBDA1: 1732, - 0xBDA2: 1733, - 0xBDA5: 1734, - 0xBDA9: 1735, - 0xBDB1: 1736, - 0xBDB3: 1737, - 0xBDB5: 1738, - 0xBDB7: 1739, - 0xBDB9: 1740, - 0xBDC1: 1741, - 0xBDC2: 1742, - 0xBDC9: 1743, - 0xBDD6: 1744, - 0xBDE1: 1745, - 0xBDF6: 1746, - 0xBE41: 1747, - 0xBE45: 1748, - 0xBE49: 1749, - 0xBE51: 1750, - 0xBE53: 1751, - 0xBE77: 1752, - 0xBE81: 1753, - 0xBE82: 1754, - 0xBE85: 1755, - 0xBE89: 1756, - 0xBE91: 1757, - 0xBE93: 1758, - 0xBE97: 1759, - 0xBEA1: 1760, - 0xBEB6: 1761, - 0xBEB7: 1762, - 0xBEE1: 1763, - 0xBF41: 1764, - 0xBF61: 1765, - 0xBF71: 1766, - 0xBF75: 1767, - 0xBF77: 1768, - 0xBFA1: 1769, - 0xBFA2: 1770, - 0xBFA5: 1771, - 0xBFA9: 1772, - 0xBFB1: 1773, - 0xBFB3: 1774, - 0xBFB7: 1775, - 0xBFB8: 1776, - 0xBFBD: 1777, - 0xC061: 1778, - 0xC062: 1779, - 0xC065: 1780, - 0xC067: 1781, - 0xC069: 1782, - 0xC071: 1783, - 0xC073: 1784, - 0xC075: 1785, - 0xC076: 1786, - 0xC077: 1787, - 0xC078: 1788, - 0xC081: 1789, - 0xC082: 1790, - 0xC085: 1791, - 0xC089: 1792, - 0xC091: 1793, - 0xC093: 1794, - 0xC095: 1795, - 0xC096: 1796, - 0xC097: 1797, - 0xC0A1: 1798, - 0xC0A5: 1799, - 0xC0A7: 1800, - 0xC0A9: 1801, - 0xC0B1: 1802, - 0xC0B7: 1803, - 0xC0E1: 1804, - 0xC0E2: 1805, - 0xC0E5: 1806, - 0xC0E9: 1807, - 0xC0F1: 1808, - 0xC0F3: 1809, - 0xC0F5: 1810, - 0xC0F6: 1811, - 0xC0F7: 1812, - 0xC141: 1813, - 0xC142: 1814, - 0xC145: 1815, - 0xC149: 1816, - 0xC151: 1817, - 0xC153: 1818, - 0xC155: 1819, - 0xC157: 1820, - 0xC161: 1821, - 0xC165: 1822, - 0xC176: 1823, - 0xC181: 1824, - 0xC185: 1825, - 0xC197: 1826, - 0xC1A1: 1827, - 0xC1A2: 1828, - 0xC1A5: 1829, - 0xC1A9: 1830, - 0xC1B1: 1831, - 0xC1B3: 1832, - 0xC1B5: 1833, - 0xC1B7: 1834, - 0xC1C1: 1835, - 0xC1C5: 1836, - 0xC1C9: 1837, - 0xC1D7: 1838, - 0xC241: 1839, - 0xC245: 1840, - 0xC249: 1841, - 0xC251: 1842, - 0xC253: 1843, - 0xC255: 1844, - 0xC257: 1845, - 0xC261: 1846, - 0xC271: 1847, - 0xC281: 1848, - 0xC282: 1849, - 0xC285: 1850, - 0xC289: 1851, - 0xC291: 1852, - 0xC293: 1853, - 0xC295: 1854, - 0xC297: 1855, - 0xC2A1: 1856, - 0xC2B6: 1857, - 0xC2C1: 1858, - 0xC2C5: 1859, - 0xC2E1: 1860, - 0xC2E5: 1861, - 0xC2E9: 1862, - 0xC2F1: 1863, - 0xC2F3: 1864, - 0xC2F5: 1865, - 0xC2F7: 1866, - 0xC341: 1867, - 0xC345: 1868, - 0xC349: 1869, - 0xC351: 1870, - 0xC357: 1871, - 0xC361: 1872, - 0xC362: 1873, - 0xC365: 1874, - 0xC369: 1875, - 0xC371: 1876, - 0xC373: 1877, - 0xC375: 1878, - 0xC377: 1879, - 0xC3A1: 1880, - 0xC3A2: 1881, - 0xC3A5: 1882, - 0xC3A8: 1883, - 0xC3A9: 1884, - 0xC3AA: 1885, - 0xC3B1: 1886, - 0xC3B3: 1887, - 0xC3B5: 1888, - 0xC3B7: 1889, - 0xC461: 1890, - 0xC462: 1891, - 0xC465: 1892, - 0xC469: 1893, - 0xC471: 1894, - 0xC473: 1895, - 0xC475: 1896, - 0xC477: 1897, - 0xC481: 1898, - 0xC482: 1899, - 0xC485: 1900, - 0xC489: 1901, - 0xC491: 1902, - 0xC493: 1903, - 0xC495: 1904, - 0xC496: 1905, - 0xC497: 1906, - 0xC4A1: 1907, - 0xC4A2: 1908, - 0xC4B7: 1909, - 0xC4E1: 1910, - 0xC4E2: 1911, - 0xC4E5: 1912, - 0xC4E8: 1913, - 0xC4E9: 1914, - 0xC4F1: 1915, - 0xC4F3: 1916, - 0xC4F5: 1917, - 0xC4F6: 1918, - 0xC4F7: 1919, - 0xC541: 1920, - 0xC542: 1921, - 0xC545: 1922, - 0xC549: 1923, - 0xC551: 1924, - 0xC553: 1925, - 0xC555: 1926, - 0xC557: 1927, - 0xC561: 1928, - 0xC565: 1929, - 0xC569: 1930, - 0xC571: 1931, - 0xC573: 1932, - 0xC575: 1933, - 0xC576: 1934, - 0xC577: 1935, - 0xC581: 1936, - 0xC5A1: 1937, - 0xC5A2: 1938, - 0xC5A5: 1939, - 0xC5A9: 1940, - 0xC5B1: 1941, - 0xC5B3: 1942, - 0xC5B5: 1943, - 0xC5B7: 1944, - 0xC5C1: 1945, - 0xC5C2: 1946, - 0xC5C5: 1947, - 0xC5C9: 1948, - 0xC5D1: 1949, - 0xC5D7: 1950, - 0xC5E1: 1951, - 0xC5F7: 1952, - 0xC641: 1953, - 0xC649: 1954, - 0xC661: 1955, - 0xC681: 1956, - 0xC682: 1957, - 0xC685: 1958, - 0xC689: 1959, - 0xC691: 1960, - 0xC693: 1961, - 0xC695: 1962, - 0xC697: 1963, - 0xC6A1: 1964, - 0xC6A5: 1965, - 0xC6A9: 1966, - 0xC6B7: 1967, - 0xC6C1: 1968, - 0xC6D7: 1969, - 0xC6E1: 1970, - 0xC6E2: 1971, - 0xC6E5: 1972, - 0xC6E9: 1973, - 0xC6F1: 1974, - 0xC6F3: 1975, - 0xC6F5: 1976, - 0xC6F7: 1977, - 0xC741: 1978, - 0xC745: 1979, - 0xC749: 1980, - 0xC751: 1981, - 0xC761: 1982, - 0xC762: 1983, - 0xC765: 1984, - 0xC769: 1985, - 0xC771: 1986, - 0xC773: 1987, - 0xC777: 1988, - 0xC7A1: 1989, - 0xC7A2: 1990, - 0xC7A5: 1991, - 0xC7A9: 1992, - 0xC7B1: 1993, - 0xC7B3: 1994, - 0xC7B5: 1995, - 0xC7B7: 1996, - 0xC861: 1997, - 0xC862: 1998, - 0xC865: 1999, - 0xC869: 2000, - 0xC86A: 2001, - 0xC871: 2002, - 0xC873: 2003, - 0xC875: 2004, - 0xC876: 2005, - 0xC877: 2006, - 0xC881: 2007, - 0xC882: 2008, - 0xC885: 2009, - 0xC889: 2010, - 0xC891: 2011, - 0xC893: 2012, - 0xC895: 2013, - 0xC896: 2014, - 0xC897: 2015, - 0xC8A1: 2016, - 0xC8B7: 2017, - 0xC8E1: 2018, - 0xC8E2: 2019, - 0xC8E5: 2020, - 0xC8E9: 2021, - 0xC8EB: 2022, - 0xC8F1: 2023, - 0xC8F3: 2024, - 0xC8F5: 2025, - 0xC8F6: 2026, - 0xC8F7: 2027, - 0xC941: 2028, - 0xC942: 2029, - 0xC945: 2030, - 0xC949: 2031, - 0xC951: 2032, - 0xC953: 2033, - 0xC955: 2034, - 0xC957: 2035, - 0xC961: 2036, - 0xC965: 2037, - 0xC976: 2038, - 0xC981: 2039, - 0xC985: 2040, - 0xC9A1: 2041, - 0xC9A2: 2042, - 0xC9A5: 2043, - 0xC9A9: 2044, - 0xC9B1: 2045, - 0xC9B3: 2046, - 0xC9B5: 2047, - 0xC9B7: 2048, - 0xC9BC: 2049, - 0xC9C1: 2050, - 0xC9C5: 2051, - 0xC9E1: 2052, - 0xCA41: 2053, - 0xCA45: 2054, - 0xCA55: 2055, - 0xCA57: 2056, - 0xCA61: 2057, - 0xCA81: 2058, - 0xCA82: 2059, - 0xCA85: 2060, - 0xCA89: 2061, - 0xCA91: 2062, - 0xCA93: 2063, - 0xCA95: 2064, - 0xCA97: 2065, - 0xCAA1: 2066, - 0xCAB6: 2067, - 0xCAC1: 2068, - 0xCAE1: 2069, - 0xCAE2: 2070, - 0xCAE5: 2071, - 0xCAE9: 2072, - 0xCAF1: 2073, - 0xCAF3: 2074, - 0xCAF7: 2075, - 0xCB41: 2076, - 0xCB45: 2077, - 0xCB49: 2078, - 0xCB51: 2079, - 0xCB57: 2080, - 0xCB61: 2081, - 0xCB62: 2082, - 0xCB65: 2083, - 0xCB68: 2084, - 0xCB69: 2085, - 0xCB6B: 2086, - 0xCB71: 2087, - 0xCB73: 2088, - 0xCB75: 2089, - 0xCB81: 2090, - 0xCB85: 2091, - 0xCB89: 2092, - 0xCB91: 2093, - 0xCB93: 2094, - 0xCBA1: 2095, - 0xCBA2: 2096, - 0xCBA5: 2097, - 0xCBA9: 2098, - 0xCBB1: 2099, - 0xCBB3: 2100, - 0xCBB5: 2101, - 0xCBB7: 2102, - 0xCC61: 2103, - 0xCC62: 2104, - 0xCC63: 2105, - 0xCC65: 2106, - 0xCC69: 2107, - 0xCC6B: 2108, - 0xCC71: 2109, - 0xCC73: 2110, - 0xCC75: 2111, - 0xCC76: 2112, - 0xCC77: 2113, - 0xCC7B: 2114, - 0xCC81: 2115, - 0xCC82: 2116, - 0xCC85: 2117, - 0xCC89: 2118, - 0xCC91: 2119, - 0xCC93: 2120, - 0xCC95: 2121, - 0xCC96: 2122, - 0xCC97: 2123, - 0xCCA1: 2124, - 0xCCA2: 2125, - 0xCCE1: 2126, - 0xCCE2: 2127, - 0xCCE5: 2128, - 0xCCE9: 2129, - 0xCCF1: 2130, - 0xCCF3: 2131, - 0xCCF5: 2132, - 0xCCF6: 2133, - 0xCCF7: 2134, - 0xCD41: 2135, - 0xCD42: 2136, - 0xCD45: 2137, - 0xCD49: 2138, - 0xCD51: 2139, - 0xCD53: 2140, - 0xCD55: 2141, - 0xCD57: 2142, - 0xCD61: 2143, - 0xCD65: 2144, - 0xCD69: 2145, - 0xCD71: 2146, - 0xCD73: 2147, - 0xCD76: 2148, - 0xCD77: 2149, - 0xCD81: 2150, - 0xCD89: 2151, - 0xCD93: 2152, - 0xCD95: 2153, - 0xCDA1: 2154, - 0xCDA2: 2155, - 0xCDA5: 2156, - 0xCDA9: 2157, - 0xCDB1: 2158, - 0xCDB3: 2159, - 0xCDB5: 2160, - 0xCDB7: 2161, - 0xCDC1: 2162, - 0xCDD7: 2163, - 0xCE41: 2164, - 0xCE45: 2165, - 0xCE61: 2166, - 0xCE65: 2167, - 0xCE69: 2168, - 0xCE73: 2169, - 0xCE75: 2170, - 0xCE81: 2171, - 0xCE82: 2172, - 0xCE85: 2173, - 0xCE88: 2174, - 0xCE89: 2175, - 0xCE8B: 2176, - 0xCE91: 2177, - 0xCE93: 2178, - 0xCE95: 2179, - 0xCE97: 2180, - 0xCEA1: 2181, - 0xCEB7: 2182, - 0xCEE1: 2183, - 0xCEE5: 2184, - 0xCEE9: 2185, - 0xCEF1: 2186, - 0xCEF5: 2187, - 0xCF41: 2188, - 0xCF45: 2189, - 0xCF49: 2190, - 0xCF51: 2191, - 0xCF55: 2192, - 0xCF57: 2193, - 0xCF61: 2194, - 0xCF65: 2195, - 0xCF69: 2196, - 0xCF71: 2197, - 0xCF73: 2198, - 0xCF75: 2199, - 0xCFA1: 2200, - 0xCFA2: 2201, - 0xCFA5: 2202, - 0xCFA9: 2203, - 0xCFB1: 2204, - 0xCFB3: 2205, - 0xCFB5: 2206, - 0xCFB7: 2207, - 0xD061: 2208, - 0xD062: 2209, - 0xD065: 2210, - 0xD069: 2211, - 0xD06E: 2212, - 0xD071: 2213, - 0xD073: 2214, - 0xD075: 2215, - 0xD077: 2216, - 0xD081: 2217, - 0xD082: 2218, - 0xD085: 2219, - 0xD089: 2220, - 0xD091: 2221, - 0xD093: 2222, - 0xD095: 2223, - 0xD096: 2224, - 0xD097: 2225, - 0xD0A1: 2226, - 0xD0B7: 2227, - 0xD0E1: 2228, - 0xD0E2: 2229, - 0xD0E5: 2230, - 0xD0E9: 2231, - 0xD0EB: 2232, - 0xD0F1: 2233, - 0xD0F3: 2234, - 0xD0F5: 2235, - 0xD0F7: 2236, - 0xD141: 2237, - 0xD142: 2238, - 0xD145: 2239, - 0xD149: 2240, - 0xD151: 2241, - 0xD153: 2242, - 0xD155: 2243, - 0xD157: 2244, - 0xD161: 2245, - 0xD162: 2246, - 0xD165: 2247, - 0xD169: 2248, - 0xD171: 2249, - 0xD173: 2250, - 0xD175: 2251, - 0xD176: 2252, - 0xD177: 2253, - 0xD181: 2254, - 0xD185: 2255, - 0xD189: 2256, - 0xD193: 2257, - 0xD1A1: 2258, - 0xD1A2: 2259, - 0xD1A5: 2260, - 0xD1A9: 2261, - 0xD1AE: 2262, - 0xD1B1: 2263, - 0xD1B3: 2264, - 0xD1B5: 2265, - 0xD1B7: 2266, - 0xD1BB: 2267, - 0xD1C1: 2268, - 0xD1C2: 2269, - 0xD1C5: 2270, - 0xD1C9: 2271, - 0xD1D5: 2272, - 0xD1D7: 2273, - 0xD1E1: 2274, - 0xD1E2: 2275, - 0xD1E5: 2276, - 0xD1F5: 2277, - 0xD1F7: 2278, - 0xD241: 2279, - 0xD242: 2280, - 0xD245: 2281, - 0xD249: 2282, - 0xD253: 2283, - 0xD255: 2284, - 0xD257: 2285, - 0xD261: 2286, - 0xD265: 2287, - 0xD269: 2288, - 0xD273: 2289, - 0xD275: 2290, - 0xD281: 2291, - 0xD282: 2292, - 0xD285: 2293, - 0xD289: 2294, - 0xD28E: 2295, - 0xD291: 2296, - 0xD295: 2297, - 0xD297: 2298, - 0xD2A1: 2299, - 0xD2A5: 2300, - 0xD2A9: 2301, - 0xD2B1: 2302, - 0xD2B7: 2303, - 0xD2C1: 2304, - 0xD2C2: 2305, - 0xD2C5: 2306, - 0xD2C9: 2307, - 0xD2D7: 2308, - 0xD2E1: 2309, - 0xD2E2: 2310, - 0xD2E5: 2311, - 0xD2E9: 2312, - 0xD2F1: 2313, - 0xD2F3: 2314, - 0xD2F5: 2315, - 0xD2F7: 2316, - 0xD341: 2317, - 0xD342: 2318, - 0xD345: 2319, - 0xD349: 2320, - 0xD351: 2321, - 0xD355: 2322, - 0xD357: 2323, - 0xD361: 2324, - 0xD362: 2325, - 0xD365: 2326, - 0xD367: 2327, - 0xD368: 2328, - 0xD369: 2329, - 0xD36A: 2330, - 0xD371: 2331, - 0xD373: 2332, - 0xD375: 2333, - 0xD377: 2334, - 0xD37B: 2335, - 0xD381: 2336, - 0xD385: 2337, - 0xD389: 2338, - 0xD391: 2339, - 0xD393: 2340, - 0xD397: 2341, - 0xD3A1: 2342, - 0xD3A2: 2343, - 0xD3A5: 2344, - 0xD3A9: 2345, - 0xD3B1: 2346, - 0xD3B3: 2347, - 0xD3B5: 2348, - 0xD3B7: 2349, -} diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/johabprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/johabprober.py deleted file mode 100644 index d7364ba..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/johabprober.py +++ /dev/null @@ -1,47 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 .chardistribution import JOHABDistributionAnalysis -from .codingstatemachine import CodingStateMachine -from .mbcharsetprober import MultiByteCharSetProber -from .mbcssm import JOHAB_SM_MODEL - - -class JOHABProber(MultiByteCharSetProber): - def __init__(self) -> None: - super().__init__() - self.coding_sm = CodingStateMachine(JOHAB_SM_MODEL) - self.distribution_analyzer = JOHABDistributionAnalysis() - self.reset() - - @property - def charset_name(self) -> str: - return "Johab" - - @property - def language(self) -> str: - return "Korean" diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/jpcntx.py b/myenv/Lib/site-packages/pip/_vendor/chardet/jpcntx.py deleted file mode 100644 index 2f53bdd..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/jpcntx.py +++ /dev/null @@ -1,238 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Communicator client code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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, Tuple, Union - -# This is hiragana 2-char sequence table, the number in each cell represents its frequency category -# fmt: off -jp2_char_context = ( - (0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1), - (2, 4, 0, 4, 0, 3, 0, 4, 0, 3, 4, 4, 4, 2, 4, 3, 3, 4, 3, 2, 3, 3, 4, 2, 3, 3, 3, 2, 4, 1, 4, 3, 3, 1, 5, 4, 3, 4, 3, 4, 3, 5, 3, 0, 3, 5, 4, 2, 0, 3, 1, 0, 3, 3, 0, 3, 3, 0, 1, 1, 0, 4, 3, 0, 3, 3, 0, 4, 0, 2, 0, 3, 5, 5, 5, 5, 4, 0, 4, 1, 0, 3, 4), - (0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2), - (0, 4, 0, 5, 0, 5, 0, 4, 0, 4, 5, 4, 4, 3, 5, 3, 5, 1, 5, 3, 4, 3, 4, 4, 3, 4, 3, 3, 4, 3, 5, 4, 4, 3, 5, 5, 3, 5, 5, 5, 3, 5, 5, 3, 4, 5, 5, 3, 1, 3, 2, 0, 3, 4, 0, 4, 2, 0, 4, 2, 1, 5, 3, 2, 3, 5, 0, 4, 0, 2, 0, 5, 4, 4, 5, 4, 5, 0, 4, 0, 0, 4, 4), - (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0), - (0, 3, 0, 4, 0, 3, 0, 3, 0, 4, 5, 4, 3, 3, 3, 3, 4, 3, 5, 4, 4, 3, 5, 4, 4, 3, 4, 3, 4, 4, 4, 4, 5, 3, 4, 4, 3, 4, 5, 5, 4, 5, 5, 1, 4, 5, 4, 3, 0, 3, 3, 1, 3, 3, 0, 4, 4, 0, 3, 3, 1, 5, 3, 3, 3, 5, 0, 4, 0, 3, 0, 4, 4, 3, 4, 3, 3, 0, 4, 1, 1, 3, 4), - (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0), - (0, 4, 0, 3, 0, 3, 0, 4, 0, 3, 4, 4, 3, 2, 2, 1, 2, 1, 3, 1, 3, 3, 3, 3, 3, 4, 3, 1, 3, 3, 5, 3, 3, 0, 4, 3, 0, 5, 4, 3, 3, 5, 4, 4, 3, 4, 4, 5, 0, 1, 2, 0, 1, 2, 0, 2, 2, 0, 1, 0, 0, 5, 2, 2, 1, 4, 0, 3, 0, 1, 0, 4, 4, 3, 5, 4, 3, 0, 2, 1, 0, 4, 3), - (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0), - (0, 3, 0, 5, 0, 4, 0, 2, 1, 4, 4, 2, 4, 1, 4, 2, 4, 2, 4, 3, 3, 3, 4, 3, 3, 3, 3, 1, 4, 2, 3, 3, 3, 1, 4, 4, 1, 1, 1, 4, 3, 3, 2, 0, 2, 4, 3, 2, 0, 3, 3, 0, 3, 1, 1, 0, 0, 0, 3, 3, 0, 4, 2, 2, 3, 4, 0, 4, 0, 3, 0, 4, 4, 5, 3, 4, 4, 0, 3, 0, 0, 1, 4), - (1, 4, 0, 4, 0, 4, 0, 4, 0, 3, 5, 4, 4, 3, 4, 3, 5, 4, 3, 3, 4, 3, 5, 4, 4, 4, 4, 3, 4, 2, 4, 3, 3, 1, 5, 4, 3, 2, 4, 5, 4, 5, 5, 4, 4, 5, 4, 4, 0, 3, 2, 2, 3, 3, 0, 4, 3, 1, 3, 2, 1, 4, 3, 3, 4, 5, 0, 3, 0, 2, 0, 4, 5, 5, 4, 5, 4, 0, 4, 0, 0, 5, 4), - (0, 5, 0, 5, 0, 4, 0, 3, 0, 4, 4, 3, 4, 3, 3, 3, 4, 0, 4, 4, 4, 3, 4, 3, 4, 3, 3, 1, 4, 2, 4, 3, 4, 0, 5, 4, 1, 4, 5, 4, 4, 5, 3, 2, 4, 3, 4, 3, 2, 4, 1, 3, 3, 3, 2, 3, 2, 0, 4, 3, 3, 4, 3, 3, 3, 4, 0, 4, 0, 3, 0, 4, 5, 4, 4, 4, 3, 0, 4, 1, 0, 1, 3), - (0, 3, 1, 4, 0, 3, 0, 2, 0, 3, 4, 4, 3, 1, 4, 2, 3, 3, 4, 3, 4, 3, 4, 3, 4, 4, 3, 2, 3, 1, 5, 4, 4, 1, 4, 4, 3, 5, 4, 4, 3, 5, 5, 4, 3, 4, 4, 3, 1, 2, 3, 1, 2, 2, 0, 3, 2, 0, 3, 1, 0, 5, 3, 3, 3, 4, 3, 3, 3, 3, 4, 4, 4, 4, 5, 4, 2, 0, 3, 3, 2, 4, 3), - (0, 2, 0, 3, 0, 1, 0, 1, 0, 0, 3, 2, 0, 0, 2, 0, 1, 0, 2, 1, 3, 3, 3, 1, 2, 3, 1, 0, 1, 0, 4, 2, 1, 1, 3, 3, 0, 4, 3, 3, 1, 4, 3, 3, 0, 3, 3, 2, 0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 0, 0, 0, 4, 1, 0, 2, 3, 2, 2, 2, 1, 3, 3, 3, 4, 4, 3, 2, 0, 3, 1, 0, 3, 3), - (0, 4, 0, 4, 0, 3, 0, 3, 0, 4, 4, 4, 3, 3, 3, 3, 3, 3, 4, 3, 4, 2, 4, 3, 4, 3, 3, 2, 4, 3, 4, 5, 4, 1, 4, 5, 3, 5, 4, 5, 3, 5, 4, 0, 3, 5, 5, 3, 1, 3, 3, 2, 2, 3, 0, 3, 4, 1, 3, 3, 2, 4, 3, 3, 3, 4, 0, 4, 0, 3, 0, 4, 5, 4, 4, 5, 3, 0, 4, 1, 0, 3, 4), - (0, 2, 0, 3, 0, 3, 0, 0, 0, 2, 2, 2, 1, 0, 1, 0, 0, 0, 3, 0, 3, 0, 3, 0, 1, 3, 1, 0, 3, 1, 3, 3, 3, 1, 3, 3, 3, 0, 1, 3, 1, 3, 4, 0, 0, 3, 1, 1, 0, 3, 2, 0, 0, 0, 0, 1, 3, 0, 1, 0, 0, 3, 3, 2, 0, 3, 0, 0, 0, 0, 0, 3, 4, 3, 4, 3, 3, 0, 3, 0, 0, 2, 3), - (2, 3, 0, 3, 0, 2, 0, 1, 0, 3, 3, 4, 3, 1, 3, 1, 1, 1, 3, 1, 4, 3, 4, 3, 3, 3, 0, 0, 3, 1, 5, 4, 3, 1, 4, 3, 2, 5, 5, 4, 4, 4, 4, 3, 3, 4, 4, 4, 0, 2, 1, 1, 3, 2, 0, 1, 2, 0, 0, 1, 0, 4, 1, 3, 3, 3, 0, 3, 0, 1, 0, 4, 4, 4, 5, 5, 3, 0, 2, 0, 0, 4, 4), - (0, 2, 0, 1, 0, 3, 1, 3, 0, 2, 3, 3, 3, 0, 3, 1, 0, 0, 3, 0, 3, 2, 3, 1, 3, 2, 1, 1, 0, 0, 4, 2, 1, 0, 2, 3, 1, 4, 3, 2, 0, 4, 4, 3, 1, 3, 1, 3, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 4, 1, 1, 1, 2, 0, 3, 0, 0, 0, 3, 4, 2, 4, 3, 2, 0, 1, 0, 0, 3, 3), - (0, 1, 0, 4, 0, 5, 0, 4, 0, 2, 4, 4, 2, 3, 3, 2, 3, 3, 5, 3, 3, 3, 4, 3, 4, 2, 3, 0, 4, 3, 3, 3, 4, 1, 4, 3, 2, 1, 5, 5, 3, 4, 5, 1, 3, 5, 4, 2, 0, 3, 3, 0, 1, 3, 0, 4, 2, 0, 1, 3, 1, 4, 3, 3, 3, 3, 0, 3, 0, 1, 0, 3, 4, 4, 4, 5, 5, 0, 3, 0, 1, 4, 5), - (0, 2, 0, 3, 0, 3, 0, 0, 0, 2, 3, 1, 3, 0, 4, 0, 1, 1, 3, 0, 3, 4, 3, 2, 3, 1, 0, 3, 3, 2, 3, 1, 3, 0, 2, 3, 0, 2, 1, 4, 1, 2, 2, 0, 0, 3, 3, 0, 0, 2, 0, 0, 0, 1, 0, 0, 0, 0, 2, 2, 0, 3, 2, 1, 3, 3, 0, 2, 0, 2, 0, 0, 3, 3, 1, 2, 4, 0, 3, 0, 2, 2, 3), - (2, 4, 0, 5, 0, 4, 0, 4, 0, 2, 4, 4, 4, 3, 4, 3, 3, 3, 1, 2, 4, 3, 4, 3, 4, 4, 5, 0, 3, 3, 3, 3, 2, 0, 4, 3, 1, 4, 3, 4, 1, 4, 4, 3, 3, 4, 4, 3, 1, 2, 3, 0, 4, 2, 0, 4, 1, 0, 3, 3, 0, 4, 3, 3, 3, 4, 0, 4, 0, 2, 0, 3, 5, 3, 4, 5, 2, 0, 3, 0, 0, 4, 5), - (0, 3, 0, 4, 0, 1, 0, 1, 0, 1, 3, 2, 2, 1, 3, 0, 3, 0, 2, 0, 2, 0, 3, 0, 2, 0, 0, 0, 1, 0, 1, 1, 0, 0, 3, 1, 0, 0, 0, 4, 0, 3, 1, 0, 2, 1, 3, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 4, 2, 2, 3, 1, 0, 3, 0, 0, 0, 1, 4, 4, 4, 3, 0, 0, 4, 0, 0, 1, 4), - (1, 4, 1, 5, 0, 3, 0, 3, 0, 4, 5, 4, 4, 3, 5, 3, 3, 4, 4, 3, 4, 1, 3, 3, 3, 3, 2, 1, 4, 1, 5, 4, 3, 1, 4, 4, 3, 5, 4, 4, 3, 5, 4, 3, 3, 4, 4, 4, 0, 3, 3, 1, 2, 3, 0, 3, 1, 0, 3, 3, 0, 5, 4, 4, 4, 4, 4, 4, 3, 3, 5, 4, 4, 3, 3, 5, 4, 0, 3, 2, 0, 4, 4), - (0, 2, 0, 3, 0, 1, 0, 0, 0, 1, 3, 3, 3, 2, 4, 1, 3, 0, 3, 1, 3, 0, 2, 2, 1, 1, 0, 0, 2, 0, 4, 3, 1, 0, 4, 3, 0, 4, 4, 4, 1, 4, 3, 1, 1, 3, 3, 1, 0, 2, 0, 0, 1, 3, 0, 0, 0, 0, 2, 0, 0, 4, 3, 2, 4, 3, 5, 4, 3, 3, 3, 4, 3, 3, 4, 3, 3, 0, 2, 1, 0, 3, 3), - (0, 2, 0, 4, 0, 3, 0, 2, 0, 2, 5, 5, 3, 4, 4, 4, 4, 1, 4, 3, 3, 0, 4, 3, 4, 3, 1, 3, 3, 2, 4, 3, 0, 3, 4, 3, 0, 3, 4, 4, 2, 4, 4, 0, 4, 5, 3, 3, 2, 2, 1, 1, 1, 2, 0, 1, 5, 0, 3, 3, 2, 4, 3, 3, 3, 4, 0, 3, 0, 2, 0, 4, 4, 3, 5, 5, 0, 0, 3, 0, 2, 3, 3), - (0, 3, 0, 4, 0, 3, 0, 1, 0, 3, 4, 3, 3, 1, 3, 3, 3, 0, 3, 1, 3, 0, 4, 3, 3, 1, 1, 0, 3, 0, 3, 3, 0, 0, 4, 4, 0, 1, 5, 4, 3, 3, 5, 0, 3, 3, 4, 3, 0, 2, 0, 1, 1, 1, 0, 1, 3, 0, 1, 2, 1, 3, 3, 2, 3, 3, 0, 3, 0, 1, 0, 1, 3, 3, 4, 4, 1, 0, 1, 2, 2, 1, 3), - (0, 1, 0, 4, 0, 4, 0, 3, 0, 1, 3, 3, 3, 2, 3, 1, 1, 0, 3, 0, 3, 3, 4, 3, 2, 4, 2, 0, 1, 0, 4, 3, 2, 0, 4, 3, 0, 5, 3, 3, 2, 4, 4, 4, 3, 3, 3, 4, 0, 1, 3, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 4, 2, 3, 3, 3, 0, 3, 0, 0, 0, 4, 4, 4, 5, 3, 2, 0, 3, 3, 0, 3, 5), - (0, 2, 0, 3, 0, 0, 0, 3, 0, 1, 3, 0, 2, 0, 0, 0, 1, 0, 3, 1, 1, 3, 3, 0, 0, 3, 0, 0, 3, 0, 2, 3, 1, 0, 3, 1, 0, 3, 3, 2, 0, 4, 2, 2, 0, 2, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 2, 0, 1, 0, 1, 0, 0, 0, 1, 3, 1, 2, 0, 0, 0, 1, 0, 0, 1, 4), - (0, 3, 0, 3, 0, 5, 0, 1, 0, 2, 4, 3, 1, 3, 3, 2, 1, 1, 5, 2, 1, 0, 5, 1, 2, 0, 0, 0, 3, 3, 2, 2, 3, 2, 4, 3, 0, 0, 3, 3, 1, 3, 3, 0, 2, 5, 3, 4, 0, 3, 3, 0, 1, 2, 0, 2, 2, 0, 3, 2, 0, 2, 2, 3, 3, 3, 0, 2, 0, 1, 0, 3, 4, 4, 2, 5, 4, 0, 3, 0, 0, 3, 5), - (0, 3, 0, 3, 0, 3, 0, 1, 0, 3, 3, 3, 3, 0, 3, 0, 2, 0, 2, 1, 1, 0, 2, 0, 1, 0, 0, 0, 2, 1, 0, 0, 1, 0, 3, 2, 0, 0, 3, 3, 1, 2, 3, 1, 0, 3, 3, 0, 0, 1, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 2, 3, 1, 2, 3, 0, 3, 0, 1, 0, 3, 2, 1, 0, 4, 3, 0, 1, 1, 0, 3, 3), - (0, 4, 0, 5, 0, 3, 0, 3, 0, 4, 5, 5, 4, 3, 5, 3, 4, 3, 5, 3, 3, 2, 5, 3, 4, 4, 4, 3, 4, 3, 4, 5, 5, 3, 4, 4, 3, 4, 4, 5, 4, 4, 4, 3, 4, 5, 5, 4, 2, 3, 4, 2, 3, 4, 0, 3, 3, 1, 4, 3, 2, 4, 3, 3, 5, 5, 0, 3, 0, 3, 0, 5, 5, 5, 5, 4, 4, 0, 4, 0, 1, 4, 4), - (0, 4, 0, 4, 0, 3, 0, 3, 0, 3, 5, 4, 4, 2, 3, 2, 5, 1, 3, 2, 5, 1, 4, 2, 3, 2, 3, 3, 4, 3, 3, 3, 3, 2, 5, 4, 1, 3, 3, 5, 3, 4, 4, 0, 4, 4, 3, 1, 1, 3, 1, 0, 2, 3, 0, 2, 3, 0, 3, 0, 0, 4, 3, 1, 3, 4, 0, 3, 0, 2, 0, 4, 4, 4, 3, 4, 5, 0, 4, 0, 0, 3, 4), - (0, 3, 0, 3, 0, 3, 1, 2, 0, 3, 4, 4, 3, 3, 3, 0, 2, 2, 4, 3, 3, 1, 3, 3, 3, 1, 1, 0, 3, 1, 4, 3, 2, 3, 4, 4, 2, 4, 4, 4, 3, 4, 4, 3, 2, 4, 4, 3, 1, 3, 3, 1, 3, 3, 0, 4, 1, 0, 2, 2, 1, 4, 3, 2, 3, 3, 5, 4, 3, 3, 5, 4, 4, 3, 3, 0, 4, 0, 3, 2, 2, 4, 4), - (0, 2, 0, 1, 0, 0, 0, 0, 0, 1, 2, 1, 3, 0, 0, 0, 0, 0, 2, 0, 1, 2, 1, 0, 0, 1, 0, 0, 0, 0, 3, 0, 0, 1, 0, 1, 1, 3, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 2, 2, 0, 3, 4, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1), - (0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 4, 0, 4, 1, 4, 0, 3, 0, 4, 0, 3, 0, 4, 0, 3, 0, 3, 0, 4, 1, 5, 1, 4, 0, 0, 3, 0, 5, 0, 5, 2, 0, 1, 0, 0, 0, 2, 1, 4, 0, 1, 3, 0, 0, 3, 0, 0, 3, 1, 1, 4, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0), - (1, 4, 0, 5, 0, 3, 0, 2, 0, 3, 5, 4, 4, 3, 4, 3, 5, 3, 4, 3, 3, 0, 4, 3, 3, 3, 3, 3, 3, 2, 4, 4, 3, 1, 3, 4, 4, 5, 4, 4, 3, 4, 4, 1, 3, 5, 4, 3, 3, 3, 1, 2, 2, 3, 3, 1, 3, 1, 3, 3, 3, 5, 3, 3, 4, 5, 0, 3, 0, 3, 0, 3, 4, 3, 4, 4, 3, 0, 3, 0, 2, 4, 3), - (0, 1, 0, 4, 0, 0, 0, 0, 0, 1, 4, 0, 4, 1, 4, 2, 4, 0, 3, 0, 1, 0, 1, 0, 0, 0, 0, 0, 2, 0, 3, 1, 1, 1, 0, 3, 0, 0, 0, 1, 2, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 3, 0, 0, 0, 0, 3, 2, 0, 2, 2, 0, 1, 0, 0, 0, 2, 3, 2, 3, 3, 0, 0, 0, 0, 2, 1, 0), - (0, 5, 1, 5, 0, 3, 0, 3, 0, 5, 4, 4, 5, 1, 5, 3, 3, 0, 4, 3, 4, 3, 5, 3, 4, 3, 3, 2, 4, 3, 4, 3, 3, 0, 3, 3, 1, 4, 4, 3, 4, 4, 4, 3, 4, 5, 5, 3, 2, 3, 1, 1, 3, 3, 1, 3, 1, 1, 3, 3, 2, 4, 5, 3, 3, 5, 0, 4, 0, 3, 0, 4, 4, 3, 5, 3, 3, 0, 3, 4, 0, 4, 3), - (0, 5, 0, 5, 0, 3, 0, 2, 0, 4, 4, 3, 5, 2, 4, 3, 3, 3, 4, 4, 4, 3, 5, 3, 5, 3, 3, 1, 4, 0, 4, 3, 3, 0, 3, 3, 0, 4, 4, 4, 4, 5, 4, 3, 3, 5, 5, 3, 2, 3, 1, 2, 3, 2, 0, 1, 0, 0, 3, 2, 2, 4, 4, 3, 1, 5, 0, 4, 0, 3, 0, 4, 3, 1, 3, 2, 1, 0, 3, 3, 0, 3, 3), - (0, 4, 0, 5, 0, 5, 0, 4, 0, 4, 5, 5, 5, 3, 4, 3, 3, 2, 5, 4, 4, 3, 5, 3, 5, 3, 4, 0, 4, 3, 4, 4, 3, 2, 4, 4, 3, 4, 5, 4, 4, 5, 5, 0, 3, 5, 5, 4, 1, 3, 3, 2, 3, 3, 1, 3, 1, 0, 4, 3, 1, 4, 4, 3, 4, 5, 0, 4, 0, 2, 0, 4, 3, 4, 4, 3, 3, 0, 4, 0, 0, 5, 5), - (0, 4, 0, 4, 0, 5, 0, 1, 1, 3, 3, 4, 4, 3, 4, 1, 3, 0, 5, 1, 3, 0, 3, 1, 3, 1, 1, 0, 3, 0, 3, 3, 4, 0, 4, 3, 0, 4, 4, 4, 3, 4, 4, 0, 3, 5, 4, 1, 0, 3, 0, 0, 2, 3, 0, 3, 1, 0, 3, 1, 0, 3, 2, 1, 3, 5, 0, 3, 0, 1, 0, 3, 2, 3, 3, 4, 4, 0, 2, 2, 0, 4, 4), - (2, 4, 0, 5, 0, 4, 0, 3, 0, 4, 5, 5, 4, 3, 5, 3, 5, 3, 5, 3, 5, 2, 5, 3, 4, 3, 3, 4, 3, 4, 5, 3, 2, 1, 5, 4, 3, 2, 3, 4, 5, 3, 4, 1, 2, 5, 4, 3, 0, 3, 3, 0, 3, 2, 0, 2, 3, 0, 4, 1, 0, 3, 4, 3, 3, 5, 0, 3, 0, 1, 0, 4, 5, 5, 5, 4, 3, 0, 4, 2, 0, 3, 5), - (0, 5, 0, 4, 0, 4, 0, 2, 0, 5, 4, 3, 4, 3, 4, 3, 3, 3, 4, 3, 4, 2, 5, 3, 5, 3, 4, 1, 4, 3, 4, 4, 4, 0, 3, 5, 0, 4, 4, 4, 4, 5, 3, 1, 3, 4, 5, 3, 3, 3, 3, 3, 3, 3, 0, 2, 2, 0, 3, 3, 2, 4, 3, 3, 3, 5, 3, 4, 1, 3, 3, 5, 3, 2, 0, 0, 0, 0, 4, 3, 1, 3, 3), - (0, 1, 0, 3, 0, 3, 0, 1, 0, 1, 3, 3, 3, 2, 3, 3, 3, 0, 3, 0, 0, 0, 3, 1, 3, 0, 0, 0, 2, 2, 2, 3, 0, 0, 3, 2, 0, 1, 2, 4, 1, 3, 3, 0, 0, 3, 3, 3, 0, 1, 0, 0, 2, 1, 0, 0, 3, 0, 3, 1, 0, 3, 0, 0, 1, 3, 0, 2, 0, 1, 0, 3, 3, 1, 3, 3, 0, 0, 1, 1, 0, 3, 3), - (0, 2, 0, 3, 0, 2, 1, 4, 0, 2, 2, 3, 1, 1, 3, 1, 1, 0, 2, 0, 3, 1, 2, 3, 1, 3, 0, 0, 1, 0, 4, 3, 2, 3, 3, 3, 1, 4, 2, 3, 3, 3, 3, 1, 0, 3, 1, 4, 0, 1, 1, 0, 1, 2, 0, 1, 1, 0, 1, 1, 0, 3, 1, 3, 2, 2, 0, 1, 0, 0, 0, 2, 3, 3, 3, 1, 0, 0, 0, 0, 0, 2, 3), - (0, 5, 0, 4, 0, 5, 0, 2, 0, 4, 5, 5, 3, 3, 4, 3, 3, 1, 5, 4, 4, 2, 4, 4, 4, 3, 4, 2, 4, 3, 5, 5, 4, 3, 3, 4, 3, 3, 5, 5, 4, 5, 5, 1, 3, 4, 5, 3, 1, 4, 3, 1, 3, 3, 0, 3, 3, 1, 4, 3, 1, 4, 5, 3, 3, 5, 0, 4, 0, 3, 0, 5, 3, 3, 1, 4, 3, 0, 4, 0, 1, 5, 3), - (0, 5, 0, 5, 0, 4, 0, 2, 0, 4, 4, 3, 4, 3, 3, 3, 3, 3, 5, 4, 4, 4, 4, 4, 4, 5, 3, 3, 5, 2, 4, 4, 4, 3, 4, 4, 3, 3, 4, 4, 5, 5, 3, 3, 4, 3, 4, 3, 3, 4, 3, 3, 3, 3, 1, 2, 2, 1, 4, 3, 3, 5, 4, 4, 3, 4, 0, 4, 0, 3, 0, 4, 4, 4, 4, 4, 1, 0, 4, 2, 0, 2, 4), - (0, 4, 0, 4, 0, 3, 0, 1, 0, 3, 5, 2, 3, 0, 3, 0, 2, 1, 4, 2, 3, 3, 4, 1, 4, 3, 3, 2, 4, 1, 3, 3, 3, 0, 3, 3, 0, 0, 3, 3, 3, 5, 3, 3, 3, 3, 3, 2, 0, 2, 0, 0, 2, 0, 0, 2, 0, 0, 1, 0, 0, 3, 1, 2, 2, 3, 0, 3, 0, 2, 0, 4, 4, 3, 3, 4, 1, 0, 3, 0, 0, 2, 4), - (0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 2, 0, 0, 0, 0, 0, 1, 0, 2, 0, 1, 0, 0, 0, 0, 0, 3, 1, 3, 0, 3, 2, 0, 0, 0, 1, 0, 3, 2, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 4, 0, 2, 0, 0, 0, 0, 0, 0, 2), - (0, 2, 1, 3, 0, 2, 0, 2, 0, 3, 3, 3, 3, 1, 3, 1, 3, 3, 3, 3, 3, 3, 4, 2, 2, 1, 2, 1, 4, 0, 4, 3, 1, 3, 3, 3, 2, 4, 3, 5, 4, 3, 3, 3, 3, 3, 3, 3, 0, 1, 3, 0, 2, 0, 0, 1, 0, 0, 1, 0, 0, 4, 2, 0, 2, 3, 0, 3, 3, 0, 3, 3, 4, 2, 3, 1, 4, 0, 1, 2, 0, 2, 3), - (0, 3, 0, 3, 0, 1, 0, 3, 0, 2, 3, 3, 3, 0, 3, 1, 2, 0, 3, 3, 2, 3, 3, 2, 3, 2, 3, 1, 3, 0, 4, 3, 2, 0, 3, 3, 1, 4, 3, 3, 2, 3, 4, 3, 1, 3, 3, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 4, 1, 1, 0, 3, 0, 3, 1, 0, 2, 3, 3, 3, 3, 3, 1, 0, 0, 2, 0, 3, 3), - (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 2, 0, 3, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 3, 0, 3, 0, 3, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 2, 0, 2, 3, 0, 0, 0, 0, 0, 0, 0, 0, 3), - (0, 2, 0, 3, 1, 3, 0, 3, 0, 2, 3, 3, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 1, 3, 0, 2, 3, 1, 1, 4, 3, 3, 2, 3, 3, 1, 2, 2, 4, 1, 3, 3, 0, 1, 4, 2, 3, 0, 1, 3, 0, 3, 0, 0, 1, 3, 0, 2, 0, 0, 3, 3, 2, 1, 3, 0, 3, 0, 2, 0, 3, 4, 4, 4, 3, 1, 0, 3, 0, 0, 3, 3), - (0, 2, 0, 1, 0, 2, 0, 0, 0, 1, 3, 2, 2, 1, 3, 0, 1, 1, 3, 0, 3, 2, 3, 1, 2, 0, 2, 0, 1, 1, 3, 3, 3, 0, 3, 3, 1, 1, 2, 3, 2, 3, 3, 1, 2, 3, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 3, 0, 1, 0, 0, 2, 1, 2, 1, 3, 0, 3, 0, 0, 0, 3, 4, 4, 4, 3, 2, 0, 2, 0, 0, 2, 4), - (0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 3, 1, 0, 0, 0, 0, 0, 0, 0, 3), - (0, 3, 0, 3, 0, 2, 0, 3, 0, 3, 3, 3, 2, 3, 2, 2, 2, 0, 3, 1, 3, 3, 3, 2, 3, 3, 0, 0, 3, 0, 3, 2, 2, 0, 2, 3, 1, 4, 3, 4, 3, 3, 2, 3, 1, 5, 4, 4, 0, 3, 1, 2, 1, 3, 0, 3, 1, 1, 2, 0, 2, 3, 1, 3, 1, 3, 0, 3, 0, 1, 0, 3, 3, 4, 4, 2, 1, 0, 2, 1, 0, 2, 4), - (0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 4, 2, 5, 1, 4, 0, 2, 0, 2, 1, 3, 1, 4, 0, 2, 1, 0, 0, 2, 1, 4, 1, 1, 0, 3, 3, 0, 5, 1, 3, 2, 3, 3, 1, 0, 3, 2, 3, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 4, 0, 1, 0, 3, 0, 2, 0, 1, 0, 3, 3, 3, 4, 3, 3, 0, 0, 0, 0, 2, 3), - (0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 2, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 0, 1, 0, 0, 0, 0, 0, 3), - (0, 1, 0, 3, 0, 4, 0, 3, 0, 2, 4, 3, 1, 0, 3, 2, 2, 1, 3, 1, 2, 2, 3, 1, 1, 1, 2, 1, 3, 0, 1, 2, 0, 1, 3, 2, 1, 3, 0, 5, 5, 1, 0, 0, 1, 3, 2, 1, 0, 3, 0, 0, 1, 0, 0, 0, 0, 0, 3, 4, 0, 1, 1, 1, 3, 2, 0, 2, 0, 1, 0, 2, 3, 3, 1, 2, 3, 0, 1, 0, 1, 0, 4), - (0, 0, 0, 1, 0, 3, 0, 3, 0, 2, 2, 1, 0, 0, 4, 0, 3, 0, 3, 1, 3, 0, 3, 0, 3, 0, 1, 0, 3, 0, 3, 1, 3, 0, 3, 3, 0, 0, 1, 2, 1, 1, 1, 0, 1, 2, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 1, 2, 0, 0, 2, 0, 0, 0, 0, 2, 3, 3, 3, 3, 0, 0, 0, 0, 1, 4), - (0, 0, 0, 3, 0, 3, 0, 0, 0, 0, 3, 1, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 0, 2, 0, 2, 3, 0, 0, 2, 2, 3, 1, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 2, 3), - (2, 4, 0, 5, 0, 5, 0, 4, 0, 3, 4, 3, 3, 3, 4, 3, 3, 3, 4, 3, 4, 4, 5, 4, 5, 5, 5, 2, 3, 0, 5, 5, 4, 1, 5, 4, 3, 1, 5, 4, 3, 4, 4, 3, 3, 4, 3, 3, 0, 3, 2, 0, 2, 3, 0, 3, 0, 0, 3, 3, 0, 5, 3, 2, 3, 3, 0, 3, 0, 3, 0, 3, 4, 5, 4, 5, 3, 0, 4, 3, 0, 3, 4), - (0, 3, 0, 3, 0, 3, 0, 3, 0, 3, 3, 4, 3, 2, 3, 2, 3, 0, 4, 3, 3, 3, 3, 3, 3, 3, 3, 0, 3, 2, 4, 3, 3, 1, 3, 4, 3, 4, 4, 4, 3, 4, 4, 3, 2, 4, 4, 1, 0, 2, 0, 0, 1, 1, 0, 2, 0, 0, 3, 1, 0, 5, 3, 2, 1, 3, 0, 3, 0, 1, 2, 4, 3, 2, 4, 3, 3, 0, 3, 2, 0, 4, 4), - (0, 3, 0, 3, 0, 1, 0, 0, 0, 1, 4, 3, 3, 2, 3, 1, 3, 1, 4, 2, 3, 2, 4, 2, 3, 4, 3, 0, 2, 2, 3, 3, 3, 0, 3, 3, 3, 0, 3, 4, 1, 3, 3, 0, 3, 4, 3, 3, 0, 1, 1, 0, 1, 0, 0, 0, 4, 0, 3, 0, 0, 3, 1, 2, 1, 3, 0, 4, 0, 1, 0, 4, 3, 3, 4, 3, 3, 0, 2, 0, 0, 3, 3), - (0, 3, 0, 4, 0, 1, 0, 3, 0, 3, 4, 3, 3, 0, 3, 3, 3, 1, 3, 1, 3, 3, 4, 3, 3, 3, 0, 0, 3, 1, 5, 3, 3, 1, 3, 3, 2, 5, 4, 3, 3, 4, 5, 3, 2, 5, 3, 4, 0, 1, 0, 0, 0, 0, 0, 2, 0, 0, 1, 1, 0, 4, 2, 2, 1, 3, 0, 3, 0, 2, 0, 4, 4, 3, 5, 3, 2, 0, 1, 1, 0, 3, 4), - (0, 5, 0, 4, 0, 5, 0, 2, 0, 4, 4, 3, 3, 2, 3, 3, 3, 1, 4, 3, 4, 1, 5, 3, 4, 3, 4, 0, 4, 2, 4, 3, 4, 1, 5, 4, 0, 4, 4, 4, 4, 5, 4, 1, 3, 5, 4, 2, 1, 4, 1, 1, 3, 2, 0, 3, 1, 0, 3, 2, 1, 4, 3, 3, 3, 4, 0, 4, 0, 3, 0, 4, 4, 4, 3, 3, 3, 0, 4, 2, 0, 3, 4), - (1, 4, 0, 4, 0, 3, 0, 1, 0, 3, 3, 3, 1, 1, 3, 3, 2, 2, 3, 3, 1, 0, 3, 2, 2, 1, 2, 0, 3, 1, 2, 1, 2, 0, 3, 2, 0, 2, 2, 3, 3, 4, 3, 0, 3, 3, 1, 2, 0, 1, 1, 3, 1, 2, 0, 0, 3, 0, 1, 1, 0, 3, 2, 2, 3, 3, 0, 3, 0, 0, 0, 2, 3, 3, 4, 3, 3, 0, 1, 0, 0, 1, 4), - (0, 4, 0, 4, 0, 4, 0, 0, 0, 3, 4, 4, 3, 1, 4, 2, 3, 2, 3, 3, 3, 1, 4, 3, 4, 0, 3, 0, 4, 2, 3, 3, 2, 2, 5, 4, 2, 1, 3, 4, 3, 4, 3, 1, 3, 3, 4, 2, 0, 2, 1, 0, 3, 3, 0, 0, 2, 0, 3, 1, 0, 4, 4, 3, 4, 3, 0, 4, 0, 1, 0, 2, 4, 4, 4, 4, 4, 0, 3, 2, 0, 3, 3), - (0, 0, 0, 1, 0, 4, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 2, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 2), - (0, 2, 0, 3, 0, 4, 0, 4, 0, 1, 3, 3, 3, 0, 4, 0, 2, 1, 2, 1, 1, 1, 2, 0, 3, 1, 1, 0, 1, 0, 3, 1, 0, 0, 3, 3, 2, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 2, 0, 2, 2, 0, 3, 1, 0, 0, 1, 0, 1, 1, 0, 1, 2, 0, 3, 0, 0, 0, 0, 1, 0, 0, 3, 3, 4, 3, 1, 0, 1, 0, 3, 0, 2), - (0, 0, 0, 3, 0, 5, 0, 0, 0, 0, 1, 0, 2, 0, 3, 1, 0, 1, 3, 0, 0, 0, 2, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 4, 0, 0, 0, 2, 3, 0, 1, 4, 1, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 3, 0, 0, 0, 0, 0, 3), - (0, 2, 0, 5, 0, 5, 0, 1, 0, 2, 4, 3, 3, 2, 5, 1, 3, 2, 3, 3, 3, 0, 4, 1, 2, 0, 3, 0, 4, 0, 2, 2, 1, 1, 5, 3, 0, 0, 1, 4, 2, 3, 2, 0, 3, 3, 3, 2, 0, 2, 4, 1, 1, 2, 0, 1, 1, 0, 3, 1, 0, 1, 3, 1, 2, 3, 0, 2, 0, 0, 0, 1, 3, 5, 4, 4, 4, 0, 3, 0, 0, 1, 3), - (0, 4, 0, 5, 0, 4, 0, 4, 0, 4, 5, 4, 3, 3, 4, 3, 3, 3, 4, 3, 4, 4, 5, 3, 4, 5, 4, 2, 4, 2, 3, 4, 3, 1, 4, 4, 1, 3, 5, 4, 4, 5, 5, 4, 4, 5, 5, 5, 2, 3, 3, 1, 4, 3, 1, 3, 3, 0, 3, 3, 1, 4, 3, 4, 4, 4, 0, 3, 0, 4, 0, 3, 3, 4, 4, 5, 0, 0, 4, 3, 0, 4, 5), - (0, 4, 0, 4, 0, 3, 0, 3, 0, 3, 4, 4, 4, 3, 3, 2, 4, 3, 4, 3, 4, 3, 5, 3, 4, 3, 2, 1, 4, 2, 4, 4, 3, 1, 3, 4, 2, 4, 5, 5, 3, 4, 5, 4, 1, 5, 4, 3, 0, 3, 2, 2, 3, 2, 1, 3, 1, 0, 3, 3, 3, 5, 3, 3, 3, 5, 4, 4, 2, 3, 3, 4, 3, 3, 3, 2, 1, 0, 3, 2, 1, 4, 3), - (0, 4, 0, 5, 0, 4, 0, 3, 0, 3, 5, 5, 3, 2, 4, 3, 4, 0, 5, 4, 4, 1, 4, 4, 4, 3, 3, 3, 4, 3, 5, 5, 2, 3, 3, 4, 1, 2, 5, 5, 3, 5, 5, 2, 3, 5, 5, 4, 0, 3, 2, 0, 3, 3, 1, 1, 5, 1, 4, 1, 0, 4, 3, 2, 3, 5, 0, 4, 0, 3, 0, 5, 4, 3, 4, 3, 0, 0, 4, 1, 0, 4, 4), - (1, 3, 0, 4, 0, 2, 0, 2, 0, 2, 5, 5, 3, 3, 3, 3, 3, 0, 4, 2, 3, 4, 4, 4, 3, 4, 0, 0, 3, 4, 5, 4, 3, 3, 3, 3, 2, 5, 5, 4, 5, 5, 5, 4, 3, 5, 5, 5, 1, 3, 1, 0, 1, 0, 0, 3, 2, 0, 4, 2, 0, 5, 2, 3, 2, 4, 1, 3, 0, 3, 0, 4, 5, 4, 5, 4, 3, 0, 4, 2, 0, 5, 4), - (0, 3, 0, 4, 0, 5, 0, 3, 0, 3, 4, 4, 3, 2, 3, 2, 3, 3, 3, 3, 3, 2, 4, 3, 3, 2, 2, 0, 3, 3, 3, 3, 3, 1, 3, 3, 3, 0, 4, 4, 3, 4, 4, 1, 1, 4, 4, 2, 0, 3, 1, 0, 1, 1, 0, 4, 1, 0, 2, 3, 1, 3, 3, 1, 3, 4, 0, 3, 0, 1, 0, 3, 1, 3, 0, 0, 1, 0, 2, 0, 0, 4, 4), - (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0), - (0, 3, 0, 3, 0, 2, 0, 3, 0, 1, 5, 4, 3, 3, 3, 1, 4, 2, 1, 2, 3, 4, 4, 2, 4, 4, 5, 0, 3, 1, 4, 3, 4, 0, 4, 3, 3, 3, 2, 3, 2, 5, 3, 4, 3, 2, 2, 3, 0, 0, 3, 0, 2, 1, 0, 1, 2, 0, 0, 0, 0, 2, 1, 1, 3, 1, 0, 2, 0, 4, 0, 3, 4, 4, 4, 5, 2, 0, 2, 0, 0, 1, 3), - (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 4, 2, 1, 1, 0, 1, 0, 3, 2, 0, 0, 3, 1, 1, 1, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 1, 0, 0, 0, 2, 0, 0, 0, 1, 4, 0, 4, 2, 1, 0, 0, 0, 0, 0, 1), - (0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 3, 1, 0, 0, 0, 2, 0, 2, 1, 0, 0, 1, 2, 1, 0, 1, 1, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 3, 1, 0, 0, 0, 0, 0, 1, 0, 0, 2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2), - (0, 4, 0, 4, 0, 4, 0, 3, 0, 4, 4, 3, 4, 2, 4, 3, 2, 0, 4, 4, 4, 3, 5, 3, 5, 3, 3, 2, 4, 2, 4, 3, 4, 3, 1, 4, 0, 2, 3, 4, 4, 4, 3, 3, 3, 4, 4, 4, 3, 4, 1, 3, 4, 3, 2, 1, 2, 1, 3, 3, 3, 4, 4, 3, 3, 5, 0, 4, 0, 3, 0, 4, 3, 3, 3, 2, 1, 0, 3, 0, 0, 3, 3), - (0, 4, 0, 3, 0, 3, 0, 3, 0, 3, 5, 5, 3, 3, 3, 3, 4, 3, 4, 3, 3, 3, 4, 4, 4, 3, 3, 3, 3, 4, 3, 5, 3, 3, 1, 3, 2, 4, 5, 5, 5, 5, 4, 3, 4, 5, 5, 3, 2, 2, 3, 3, 3, 3, 2, 3, 3, 1, 2, 3, 2, 4, 3, 3, 3, 4, 0, 4, 0, 2, 0, 4, 3, 2, 2, 1, 2, 0, 3, 0, 0, 4, 1), -) -# fmt: on - - -class JapaneseContextAnalysis: - NUM_OF_CATEGORY = 6 - DONT_KNOW = -1 - ENOUGH_REL_THRESHOLD = 100 - MAX_REL_THRESHOLD = 1000 - MINIMUM_DATA_THRESHOLD = 4 - - def __init__(self) -> None: - self._total_rel = 0 - self._rel_sample: List[int] = [] - self._need_to_skip_char_num = 0 - self._last_char_order = -1 - self._done = False - self.reset() - - def reset(self) -> None: - self._total_rel = 0 # total sequence received - # category counters, each integer counts sequence in its category - self._rel_sample = [0] * self.NUM_OF_CATEGORY - # if last byte in current buffer is not the last byte of a character, - # we need to know how many bytes to skip in next buffer - self._need_to_skip_char_num = 0 - self._last_char_order = -1 # The order of previous char - # If this flag is set to True, detection is done and conclusion has - # been made - self._done = False - - def feed(self, byte_str: Union[bytes, bytearray], num_bytes: int) -> None: - if self._done: - return - - # The buffer we got is byte oriented, and a character may span in more than one - # buffers. In case the last one or two byte in last buffer is not - # complete, we record how many byte needed to complete that character - # and skip these bytes here. We can choose to record those bytes as - # well and analyse the character once it is complete, but since a - # character will not make much difference, by simply skipping - # this character will simply our logic and improve performance. - i = self._need_to_skip_char_num - while i < num_bytes: - order, char_len = self.get_order(byte_str[i : i + 2]) - i += char_len - if i > num_bytes: - self._need_to_skip_char_num = i - num_bytes - self._last_char_order = -1 - else: - if (order != -1) and (self._last_char_order != -1): - self._total_rel += 1 - if self._total_rel > self.MAX_REL_THRESHOLD: - self._done = True - break - self._rel_sample[ - jp2_char_context[self._last_char_order][order] - ] += 1 - self._last_char_order = order - - def got_enough_data(self) -> bool: - return self._total_rel > self.ENOUGH_REL_THRESHOLD - - def get_confidence(self) -> float: - # This is just one way to calculate confidence. It works well for me. - if self._total_rel > self.MINIMUM_DATA_THRESHOLD: - return (self._total_rel - self._rel_sample[0]) / self._total_rel - return self.DONT_KNOW - - def get_order(self, _: Union[bytes, bytearray]) -> Tuple[int, int]: - return -1, 1 - - -class SJISContextAnalysis(JapaneseContextAnalysis): - def __init__(self) -> None: - super().__init__() - self._charset_name = "SHIFT_JIS" - - @property - def charset_name(self) -> str: - return self._charset_name - - def get_order(self, byte_str: Union[bytes, bytearray]) -> Tuple[int, int]: - if not byte_str: - return -1, 1 - # find out current char's byte length - first_char = byte_str[0] - if (0x81 <= first_char <= 0x9F) or (0xE0 <= first_char <= 0xFC): - char_len = 2 - if (first_char == 0x87) or (0xFA <= first_char <= 0xFC): - self._charset_name = "CP932" - else: - char_len = 1 - - # return its order if it is hiragana - if len(byte_str) > 1: - second_char = byte_str[1] - if (first_char == 202) and (0x9F <= second_char <= 0xF1): - return second_char - 0x9F, char_len - - return -1, char_len - - -class EUCJPContextAnalysis(JapaneseContextAnalysis): - def get_order(self, byte_str: Union[bytes, bytearray]) -> Tuple[int, int]: - if not byte_str: - return -1, 1 - # find out current char's byte length - first_char = byte_str[0] - if (first_char == 0x8E) or (0xA1 <= first_char <= 0xFE): - char_len = 2 - elif first_char == 0x8F: - char_len = 3 - else: - char_len = 1 - - # return its order if it is hiragana - if len(byte_str) > 1: - second_char = byte_str[1] - if (first_char == 0xA4) and (0xA1 <= second_char <= 0xF3): - return second_char - 0xA1, char_len - - return -1, char_len diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py b/myenv/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py deleted file mode 100644 index 9946682..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py +++ /dev/null @@ -1,4649 +0,0 @@ -from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - -# 3: Positive -# 2: Likely -# 1: Unlikely -# 0: Negative - -BULGARIAN_LANG_MODEL = { - 63: { # 'e' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 0, # 'а' - 18: 1, # 'б' - 9: 1, # 'в' - 20: 1, # 'г' - 11: 1, # 'д' - 3: 1, # 'е' - 23: 1, # 'ж' - 15: 1, # 'з' - 2: 0, # 'и' - 26: 1, # 'й' - 12: 1, # 'к' - 10: 1, # 'л' - 14: 1, # 'м' - 6: 1, # 'н' - 4: 1, # 'о' - 13: 1, # 'п' - 7: 1, # 'р' - 8: 1, # 'с' - 5: 1, # 'т' - 19: 0, # 'у' - 29: 1, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 1, # 'ч' - 27: 1, # 'ш' - 24: 1, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 45: { # '\xad' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 0, # 'Г' - 37: 1, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 0, # 'Л' - 38: 1, # 'М' - 36: 0, # 'Н' - 41: 1, # 'О' - 30: 1, # 'П' - 39: 1, # 'Р' - 28: 1, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 1, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 0, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 0, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 0, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 0, # 'о' - 13: 0, # 'п' - 7: 0, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 0, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 31: { # 'А' - 63: 0, # 'e' - 45: 1, # '\xad' - 31: 1, # 'А' - 32: 1, # 'Б' - 35: 2, # 'В' - 43: 1, # 'Г' - 37: 2, # 'Д' - 44: 2, # 'Е' - 55: 1, # 'Ж' - 47: 2, # 'З' - 40: 1, # 'И' - 59: 1, # 'Й' - 33: 1, # 'К' - 46: 2, # 'Л' - 38: 1, # 'М' - 36: 2, # 'Н' - 41: 1, # 'О' - 30: 2, # 'П' - 39: 2, # 'Р' - 28: 2, # 'С' - 34: 2, # 'Т' - 51: 1, # 'У' - 48: 2, # 'Ф' - 49: 1, # 'Х' - 53: 1, # 'Ц' - 50: 1, # 'Ч' - 54: 1, # 'Ш' - 57: 2, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 1, # 'Я' - 1: 1, # 'а' - 18: 2, # 'б' - 9: 2, # 'в' - 20: 2, # 'г' - 11: 2, # 'д' - 3: 1, # 'е' - 23: 1, # 'ж' - 15: 2, # 'з' - 2: 0, # 'и' - 26: 2, # 'й' - 12: 2, # 'к' - 10: 3, # 'л' - 14: 2, # 'м' - 6: 3, # 'н' - 4: 0, # 'о' - 13: 2, # 'п' - 7: 2, # 'р' - 8: 2, # 'с' - 5: 2, # 'т' - 19: 1, # 'у' - 29: 2, # 'ф' - 25: 1, # 'х' - 22: 1, # 'ц' - 21: 1, # 'ч' - 27: 1, # 'ш' - 24: 0, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 32: { # 'Б' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 2, # 'Б' - 35: 1, # 'В' - 43: 1, # 'Г' - 37: 2, # 'Д' - 44: 1, # 'Е' - 55: 1, # 'Ж' - 47: 2, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 2, # 'Н' - 41: 2, # 'О' - 30: 1, # 'П' - 39: 1, # 'Р' - 28: 2, # 'С' - 34: 2, # 'Т' - 51: 1, # 'У' - 48: 2, # 'Ф' - 49: 1, # 'Х' - 53: 1, # 'Ц' - 50: 1, # 'Ч' - 54: 0, # 'Ш' - 57: 1, # 'Щ' - 61: 2, # 'Ъ' - 60: 1, # 'Ю' - 56: 1, # 'Я' - 1: 3, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 1, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 2, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 2, # 'р' - 8: 1, # 'с' - 5: 0, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 3, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 2, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 35: { # 'В' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 0, # 'Г' - 37: 1, # 'Д' - 44: 2, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 1, # 'О' - 30: 1, # 'П' - 39: 2, # 'Р' - 28: 2, # 'С' - 34: 1, # 'Т' - 51: 1, # 'У' - 48: 2, # 'Ф' - 49: 0, # 'Х' - 53: 1, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 1, # 'Ю' - 56: 2, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 1, # 'д' - 3: 3, # 'е' - 23: 1, # 'ж' - 15: 2, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 2, # 'л' - 14: 1, # 'м' - 6: 2, # 'н' - 4: 2, # 'о' - 13: 1, # 'п' - 7: 2, # 'р' - 8: 2, # 'с' - 5: 2, # 'т' - 19: 1, # 'у' - 29: 0, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 2, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 43: { # 'Г' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 1, # 'Д' - 44: 2, # 'Е' - 55: 0, # 'Ж' - 47: 1, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 0, # 'М' - 36: 1, # 'Н' - 41: 1, # 'О' - 30: 0, # 'П' - 39: 1, # 'Р' - 28: 1, # 'С' - 34: 0, # 'Т' - 51: 1, # 'У' - 48: 1, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 1, # 'Щ' - 61: 1, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 2, # 'а' - 18: 1, # 'б' - 9: 1, # 'в' - 20: 0, # 'г' - 11: 1, # 'д' - 3: 3, # 'е' - 23: 1, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 2, # 'л' - 14: 1, # 'м' - 6: 1, # 'н' - 4: 2, # 'о' - 13: 0, # 'п' - 7: 2, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 1, # 'щ' - 17: 2, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 37: { # 'Д' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 2, # 'В' - 43: 1, # 'Г' - 37: 2, # 'Д' - 44: 2, # 'Е' - 55: 2, # 'Ж' - 47: 1, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 2, # 'О' - 30: 2, # 'П' - 39: 1, # 'Р' - 28: 2, # 'С' - 34: 1, # 'Т' - 51: 1, # 'У' - 48: 1, # 'Ф' - 49: 0, # 'Х' - 53: 1, # 'Ц' - 50: 1, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 1, # 'Ю' - 56: 1, # 'Я' - 1: 3, # 'а' - 18: 0, # 'б' - 9: 2, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 3, # 'е' - 23: 3, # 'ж' - 15: 1, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 1, # 'л' - 14: 1, # 'м' - 6: 2, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 2, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 1, # 'ь' - 42: 2, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 44: { # 'Е' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 1, # 'А' - 32: 1, # 'Б' - 35: 2, # 'В' - 43: 1, # 'Г' - 37: 1, # 'Д' - 44: 1, # 'Е' - 55: 1, # 'Ж' - 47: 1, # 'З' - 40: 1, # 'И' - 59: 1, # 'Й' - 33: 2, # 'К' - 46: 2, # 'Л' - 38: 1, # 'М' - 36: 2, # 'Н' - 41: 2, # 'О' - 30: 1, # 'П' - 39: 2, # 'Р' - 28: 2, # 'С' - 34: 2, # 'Т' - 51: 1, # 'У' - 48: 2, # 'Ф' - 49: 1, # 'Х' - 53: 2, # 'Ц' - 50: 1, # 'Ч' - 54: 1, # 'Ш' - 57: 1, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 1, # 'Я' - 1: 0, # 'а' - 18: 1, # 'б' - 9: 2, # 'в' - 20: 1, # 'г' - 11: 2, # 'д' - 3: 0, # 'е' - 23: 1, # 'ж' - 15: 1, # 'з' - 2: 0, # 'и' - 26: 1, # 'й' - 12: 2, # 'к' - 10: 2, # 'л' - 14: 2, # 'м' - 6: 2, # 'н' - 4: 0, # 'о' - 13: 1, # 'п' - 7: 2, # 'р' - 8: 2, # 'с' - 5: 1, # 'т' - 19: 1, # 'у' - 29: 1, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 1, # 'ч' - 27: 1, # 'ш' - 24: 1, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 55: { # 'Ж' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 1, # 'А' - 32: 0, # 'Б' - 35: 1, # 'В' - 43: 0, # 'Г' - 37: 1, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 1, # 'Н' - 41: 1, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 1, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 2, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 1, # 'д' - 3: 2, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 2, # 'о' - 13: 1, # 'п' - 7: 1, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 1, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 47: { # 'З' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 1, # 'Г' - 37: 1, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 1, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 2, # 'Н' - 41: 1, # 'О' - 30: 1, # 'П' - 39: 1, # 'Р' - 28: 1, # 'С' - 34: 1, # 'Т' - 51: 1, # 'У' - 48: 0, # 'Ф' - 49: 1, # 'Х' - 53: 1, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 0, # 'Ю' - 56: 1, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 2, # 'в' - 20: 1, # 'г' - 11: 2, # 'д' - 3: 2, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 1, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 2, # 'л' - 14: 1, # 'м' - 6: 1, # 'н' - 4: 1, # 'о' - 13: 0, # 'п' - 7: 1, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 1, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 40: { # 'И' - 63: 0, # 'e' - 45: 1, # '\xad' - 31: 1, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 1, # 'Г' - 37: 1, # 'Д' - 44: 2, # 'Е' - 55: 1, # 'Ж' - 47: 2, # 'З' - 40: 1, # 'И' - 59: 1, # 'Й' - 33: 2, # 'К' - 46: 2, # 'Л' - 38: 2, # 'М' - 36: 2, # 'Н' - 41: 1, # 'О' - 30: 1, # 'П' - 39: 2, # 'Р' - 28: 2, # 'С' - 34: 2, # 'Т' - 51: 0, # 'У' - 48: 1, # 'Ф' - 49: 1, # 'Х' - 53: 1, # 'Ц' - 50: 1, # 'Ч' - 54: 1, # 'Ш' - 57: 1, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 2, # 'Я' - 1: 1, # 'а' - 18: 1, # 'б' - 9: 3, # 'в' - 20: 2, # 'г' - 11: 1, # 'д' - 3: 1, # 'е' - 23: 0, # 'ж' - 15: 3, # 'з' - 2: 0, # 'и' - 26: 1, # 'й' - 12: 1, # 'к' - 10: 2, # 'л' - 14: 2, # 'м' - 6: 2, # 'н' - 4: 0, # 'о' - 13: 1, # 'п' - 7: 2, # 'р' - 8: 2, # 'с' - 5: 2, # 'т' - 19: 0, # 'у' - 29: 1, # 'ф' - 25: 1, # 'х' - 22: 1, # 'ц' - 21: 1, # 'ч' - 27: 1, # 'ш' - 24: 1, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 59: { # 'Й' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 1, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 1, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 1, # 'С' - 34: 1, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 1, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 1, # 'Я' - 1: 0, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 1, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 0, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 2, # 'о' - 13: 0, # 'п' - 7: 0, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 0, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 33: { # 'К' - 63: 0, # 'e' - 45: 1, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 1, # 'Г' - 37: 1, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 1, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 0, # 'М' - 36: 2, # 'Н' - 41: 2, # 'О' - 30: 2, # 'П' - 39: 1, # 'Р' - 28: 2, # 'С' - 34: 1, # 'Т' - 51: 1, # 'У' - 48: 1, # 'Ф' - 49: 1, # 'Х' - 53: 1, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 1, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 0, # 'б' - 9: 1, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 2, # 'е' - 23: 1, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 2, # 'л' - 14: 1, # 'м' - 6: 2, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 3, # 'р' - 8: 1, # 'с' - 5: 0, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 1, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 1, # 'ь' - 42: 2, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 46: { # 'Л' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 2, # 'Г' - 37: 1, # 'Д' - 44: 2, # 'Е' - 55: 0, # 'Ж' - 47: 1, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 0, # 'М' - 36: 1, # 'Н' - 41: 2, # 'О' - 30: 1, # 'П' - 39: 0, # 'Р' - 28: 1, # 'С' - 34: 1, # 'Т' - 51: 1, # 'У' - 48: 0, # 'Ф' - 49: 1, # 'Х' - 53: 1, # 'Ц' - 50: 1, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 1, # 'Ю' - 56: 1, # 'Я' - 1: 2, # 'а' - 18: 0, # 'б' - 9: 1, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 2, # 'о' - 13: 0, # 'п' - 7: 0, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 1, # 'ь' - 42: 2, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 38: { # 'М' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 2, # 'В' - 43: 0, # 'Г' - 37: 1, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 1, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 2, # 'О' - 30: 1, # 'П' - 39: 1, # 'Р' - 28: 2, # 'С' - 34: 1, # 'Т' - 51: 1, # 'У' - 48: 1, # 'Ф' - 49: 0, # 'Х' - 53: 1, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 0, # 'Ю' - 56: 1, # 'Я' - 1: 3, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 2, # 'л' - 14: 0, # 'м' - 6: 2, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 1, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 1, # 'ь' - 42: 2, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 36: { # 'Н' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 2, # 'Б' - 35: 1, # 'В' - 43: 1, # 'Г' - 37: 2, # 'Д' - 44: 2, # 'Е' - 55: 1, # 'Ж' - 47: 1, # 'З' - 40: 2, # 'И' - 59: 1, # 'Й' - 33: 2, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 2, # 'О' - 30: 1, # 'П' - 39: 1, # 'Р' - 28: 2, # 'С' - 34: 2, # 'Т' - 51: 1, # 'У' - 48: 1, # 'Ф' - 49: 1, # 'Х' - 53: 1, # 'Ц' - 50: 1, # 'Ч' - 54: 1, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 1, # 'Ю' - 56: 1, # 'Я' - 1: 3, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 1, # 'г' - 11: 0, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 0, # 'р' - 8: 0, # 'с' - 5: 1, # 'т' - 19: 1, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 1, # 'ш' - 24: 0, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 2, # 'ю' - 16: 2, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 41: { # 'О' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 1, # 'А' - 32: 1, # 'Б' - 35: 2, # 'В' - 43: 1, # 'Г' - 37: 2, # 'Д' - 44: 1, # 'Е' - 55: 1, # 'Ж' - 47: 1, # 'З' - 40: 1, # 'И' - 59: 1, # 'Й' - 33: 2, # 'К' - 46: 2, # 'Л' - 38: 2, # 'М' - 36: 2, # 'Н' - 41: 2, # 'О' - 30: 1, # 'П' - 39: 2, # 'Р' - 28: 2, # 'С' - 34: 2, # 'Т' - 51: 1, # 'У' - 48: 1, # 'Ф' - 49: 1, # 'Х' - 53: 0, # 'Ц' - 50: 1, # 'Ч' - 54: 1, # 'Ш' - 57: 1, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 1, # 'Я' - 1: 1, # 'а' - 18: 2, # 'б' - 9: 2, # 'в' - 20: 2, # 'г' - 11: 1, # 'д' - 3: 1, # 'е' - 23: 1, # 'ж' - 15: 1, # 'з' - 2: 0, # 'и' - 26: 1, # 'й' - 12: 2, # 'к' - 10: 2, # 'л' - 14: 1, # 'м' - 6: 1, # 'н' - 4: 0, # 'о' - 13: 2, # 'п' - 7: 2, # 'р' - 8: 2, # 'с' - 5: 3, # 'т' - 19: 1, # 'у' - 29: 1, # 'ф' - 25: 1, # 'х' - 22: 1, # 'ц' - 21: 2, # 'ч' - 27: 0, # 'ш' - 24: 2, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 30: { # 'П' - 63: 0, # 'e' - 45: 1, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 1, # 'Г' - 37: 1, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 1, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 2, # 'О' - 30: 2, # 'П' - 39: 2, # 'Р' - 28: 2, # 'С' - 34: 1, # 'Т' - 51: 2, # 'У' - 48: 1, # 'Ф' - 49: 0, # 'Х' - 53: 1, # 'Ц' - 50: 1, # 'Ч' - 54: 1, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 1, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 2, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 3, # 'л' - 14: 0, # 'м' - 6: 1, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 3, # 'р' - 8: 1, # 'с' - 5: 1, # 'т' - 19: 2, # 'у' - 29: 1, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 1, # 'ч' - 27: 1, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 39: { # 'Р' - 63: 0, # 'e' - 45: 1, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 2, # 'Г' - 37: 2, # 'Д' - 44: 2, # 'Е' - 55: 0, # 'Ж' - 47: 1, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 0, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 2, # 'О' - 30: 2, # 'П' - 39: 1, # 'Р' - 28: 1, # 'С' - 34: 1, # 'Т' - 51: 1, # 'У' - 48: 1, # 'Ф' - 49: 1, # 'Х' - 53: 1, # 'Ц' - 50: 1, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 1, # 'Ю' - 56: 1, # 'Я' - 1: 3, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 2, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 1, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 0, # 'р' - 8: 1, # 'с' - 5: 0, # 'т' - 19: 3, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 28: { # 'С' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 3, # 'А' - 32: 2, # 'Б' - 35: 2, # 'В' - 43: 1, # 'Г' - 37: 2, # 'Д' - 44: 2, # 'Е' - 55: 1, # 'Ж' - 47: 1, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 2, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 2, # 'О' - 30: 2, # 'П' - 39: 1, # 'Р' - 28: 2, # 'С' - 34: 2, # 'Т' - 51: 1, # 'У' - 48: 1, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 1, # 'Ю' - 56: 1, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 2, # 'в' - 20: 1, # 'г' - 11: 1, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 2, # 'к' - 10: 3, # 'л' - 14: 2, # 'м' - 6: 1, # 'н' - 4: 3, # 'о' - 13: 3, # 'п' - 7: 2, # 'р' - 8: 0, # 'с' - 5: 3, # 'т' - 19: 2, # 'у' - 29: 2, # 'ф' - 25: 1, # 'х' - 22: 1, # 'ц' - 21: 1, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 3, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 34: { # 'Т' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 2, # 'Б' - 35: 1, # 'В' - 43: 0, # 'Г' - 37: 1, # 'Д' - 44: 2, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 2, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 2, # 'О' - 30: 1, # 'П' - 39: 2, # 'Р' - 28: 2, # 'С' - 34: 1, # 'Т' - 51: 1, # 'У' - 48: 1, # 'Ф' - 49: 0, # 'Х' - 53: 1, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 1, # 'Ъ' - 60: 0, # 'Ю' - 56: 1, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 1, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 1, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 3, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 2, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 51: { # 'У' - 63: 0, # 'e' - 45: 1, # '\xad' - 31: 1, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 1, # 'Г' - 37: 1, # 'Д' - 44: 2, # 'Е' - 55: 1, # 'Ж' - 47: 1, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 0, # 'О' - 30: 1, # 'П' - 39: 1, # 'Р' - 28: 1, # 'С' - 34: 2, # 'Т' - 51: 0, # 'У' - 48: 1, # 'Ф' - 49: 1, # 'Х' - 53: 1, # 'Ц' - 50: 1, # 'Ч' - 54: 1, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 1, # 'а' - 18: 1, # 'б' - 9: 2, # 'в' - 20: 1, # 'г' - 11: 1, # 'д' - 3: 2, # 'е' - 23: 1, # 'ж' - 15: 1, # 'з' - 2: 2, # 'и' - 26: 1, # 'й' - 12: 2, # 'к' - 10: 1, # 'л' - 14: 1, # 'м' - 6: 2, # 'н' - 4: 2, # 'о' - 13: 1, # 'п' - 7: 1, # 'р' - 8: 2, # 'с' - 5: 1, # 'т' - 19: 1, # 'у' - 29: 0, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 2, # 'ч' - 27: 1, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 48: { # 'Ф' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 0, # 'М' - 36: 1, # 'Н' - 41: 1, # 'О' - 30: 2, # 'П' - 39: 1, # 'Р' - 28: 2, # 'С' - 34: 1, # 'Т' - 51: 1, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 2, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 2, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 2, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 2, # 'о' - 13: 0, # 'п' - 7: 2, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 1, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 49: { # 'Х' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 1, # 'А' - 32: 0, # 'Б' - 35: 1, # 'В' - 43: 1, # 'Г' - 37: 1, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 1, # 'О' - 30: 1, # 'П' - 39: 1, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 1, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 2, # 'а' - 18: 0, # 'б' - 9: 1, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 2, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 1, # 'л' - 14: 1, # 'м' - 6: 0, # 'н' - 4: 2, # 'о' - 13: 0, # 'п' - 7: 2, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 53: { # 'Ц' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 1, # 'А' - 32: 0, # 'Б' - 35: 1, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 2, # 'И' - 59: 0, # 'Й' - 33: 2, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 1, # 'Р' - 28: 2, # 'С' - 34: 0, # 'Т' - 51: 1, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 2, # 'а' - 18: 0, # 'б' - 9: 2, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 2, # 'е' - 23: 0, # 'ж' - 15: 1, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 1, # 'о' - 13: 0, # 'п' - 7: 1, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 1, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 50: { # 'Ч' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 2, # 'А' - 32: 1, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 1, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 0, # 'М' - 36: 1, # 'Н' - 41: 1, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 1, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 2, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 3, # 'е' - 23: 1, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 1, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 2, # 'о' - 13: 0, # 'п' - 7: 1, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 1, # 'ь' - 42: 0, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 54: { # 'Ш' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 1, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 1, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 1, # 'Н' - 41: 1, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 1, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 2, # 'а' - 18: 0, # 'б' - 9: 2, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 2, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 2, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 1, # 'л' - 14: 1, # 'м' - 6: 1, # 'н' - 4: 2, # 'о' - 13: 1, # 'п' - 7: 1, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 1, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 1, # 'ь' - 42: 0, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 57: { # 'Щ' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 1, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 1, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 2, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 2, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 1, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 1, # 'о' - 13: 0, # 'п' - 7: 1, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 1, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 61: { # 'Ъ' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 0, # 'Г' - 37: 1, # 'Д' - 44: 0, # 'Е' - 55: 1, # 'Ж' - 47: 1, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 2, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 0, # 'О' - 30: 1, # 'П' - 39: 2, # 'Р' - 28: 1, # 'С' - 34: 1, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 1, # 'Х' - 53: 1, # 'Ц' - 50: 1, # 'Ч' - 54: 1, # 'Ш' - 57: 1, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 0, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 0, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 0, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 1, # 'л' - 14: 0, # 'м' - 6: 1, # 'н' - 4: 0, # 'о' - 13: 0, # 'п' - 7: 1, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 0, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 60: { # 'Ю' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 1, # 'А' - 32: 1, # 'Б' - 35: 0, # 'В' - 43: 1, # 'Г' - 37: 1, # 'Д' - 44: 0, # 'Е' - 55: 1, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 0, # 'М' - 36: 1, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 1, # 'Р' - 28: 1, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 0, # 'а' - 18: 1, # 'б' - 9: 1, # 'в' - 20: 2, # 'г' - 11: 1, # 'д' - 3: 0, # 'е' - 23: 2, # 'ж' - 15: 1, # 'з' - 2: 1, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 1, # 'л' - 14: 1, # 'м' - 6: 1, # 'н' - 4: 0, # 'о' - 13: 1, # 'п' - 7: 1, # 'р' - 8: 1, # 'с' - 5: 1, # 'т' - 19: 0, # 'у' - 29: 0, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 56: { # 'Я' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 1, # 'Б' - 35: 1, # 'В' - 43: 1, # 'Г' - 37: 1, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 1, # 'Л' - 38: 1, # 'М' - 36: 1, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 1, # 'С' - 34: 2, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 0, # 'а' - 18: 1, # 'б' - 9: 1, # 'в' - 20: 1, # 'г' - 11: 1, # 'д' - 3: 0, # 'е' - 23: 0, # 'ж' - 15: 1, # 'з' - 2: 1, # 'и' - 26: 1, # 'й' - 12: 1, # 'к' - 10: 1, # 'л' - 14: 2, # 'м' - 6: 2, # 'н' - 4: 0, # 'о' - 13: 2, # 'п' - 7: 1, # 'р' - 8: 1, # 'с' - 5: 1, # 'т' - 19: 0, # 'у' - 29: 0, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 1, # 'ш' - 24: 0, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 1: { # 'а' - 63: 1, # 'e' - 45: 1, # '\xad' - 31: 1, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 1, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 1, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 3, # 'г' - 11: 3, # 'д' - 3: 3, # 'е' - 23: 3, # 'ж' - 15: 3, # 'з' - 2: 3, # 'и' - 26: 3, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 2, # 'о' - 13: 3, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 3, # 'у' - 29: 3, # 'ф' - 25: 3, # 'х' - 22: 3, # 'ц' - 21: 3, # 'ч' - 27: 3, # 'ш' - 24: 3, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 18: { # 'б' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 0, # 'б' - 9: 3, # 'в' - 20: 1, # 'г' - 11: 2, # 'д' - 3: 3, # 'е' - 23: 1, # 'ж' - 15: 1, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 3, # 'л' - 14: 2, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 1, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 0, # 'т' - 19: 3, # 'у' - 29: 0, # 'ф' - 25: 2, # 'х' - 22: 1, # 'ц' - 21: 1, # 'ч' - 27: 1, # 'ш' - 24: 3, # 'щ' - 17: 3, # 'ъ' - 52: 1, # 'ь' - 42: 2, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 9: { # 'в' - 63: 1, # 'e' - 45: 1, # '\xad' - 31: 0, # 'А' - 32: 1, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 1, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 0, # 'в' - 20: 2, # 'г' - 11: 3, # 'д' - 3: 3, # 'е' - 23: 1, # 'ж' - 15: 3, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 2, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 2, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 2, # 'х' - 22: 2, # 'ц' - 21: 3, # 'ч' - 27: 2, # 'ш' - 24: 1, # 'щ' - 17: 3, # 'ъ' - 52: 1, # 'ь' - 42: 2, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 20: { # 'г' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 2, # 'в' - 20: 1, # 'г' - 11: 2, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 1, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 3, # 'л' - 14: 1, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 1, # 'п' - 7: 3, # 'р' - 8: 2, # 'с' - 5: 2, # 'т' - 19: 3, # 'у' - 29: 1, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 1, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 3, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 11: { # 'д' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 2, # 'б' - 9: 3, # 'в' - 20: 2, # 'г' - 11: 2, # 'д' - 3: 3, # 'е' - 23: 3, # 'ж' - 15: 2, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 3, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 1, # 'т' - 19: 3, # 'у' - 29: 1, # 'ф' - 25: 2, # 'х' - 22: 2, # 'ц' - 21: 2, # 'ч' - 27: 1, # 'ш' - 24: 1, # 'щ' - 17: 3, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 3: { # 'е' - 63: 0, # 'e' - 45: 1, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 2, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 3, # 'г' - 11: 3, # 'д' - 3: 2, # 'е' - 23: 3, # 'ж' - 15: 3, # 'з' - 2: 2, # 'и' - 26: 3, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 3, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 2, # 'у' - 29: 3, # 'ф' - 25: 3, # 'х' - 22: 3, # 'ц' - 21: 3, # 'ч' - 27: 3, # 'ш' - 24: 3, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 23: { # 'ж' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 3, # 'б' - 9: 2, # 'в' - 20: 1, # 'г' - 11: 3, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 2, # 'к' - 10: 1, # 'л' - 14: 1, # 'м' - 6: 3, # 'н' - 4: 2, # 'о' - 13: 1, # 'п' - 7: 1, # 'р' - 8: 1, # 'с' - 5: 1, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 1, # 'ц' - 21: 1, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 15: { # 'з' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 3, # 'г' - 11: 3, # 'д' - 3: 3, # 'е' - 23: 1, # 'ж' - 15: 1, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 3, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 3, # 'у' - 29: 1, # 'ф' - 25: 2, # 'х' - 22: 2, # 'ц' - 21: 2, # 'ч' - 27: 2, # 'ш' - 24: 1, # 'щ' - 17: 2, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 2, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 2: { # 'и' - 63: 1, # 'e' - 45: 1, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 1, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 1, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 1, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 1, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 3, # 'г' - 11: 3, # 'д' - 3: 3, # 'е' - 23: 3, # 'ж' - 15: 3, # 'з' - 2: 3, # 'и' - 26: 3, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 3, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 2, # 'у' - 29: 3, # 'ф' - 25: 3, # 'х' - 22: 3, # 'ц' - 21: 3, # 'ч' - 27: 3, # 'ш' - 24: 3, # 'щ' - 17: 2, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 26: { # 'й' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 1, # 'а' - 18: 2, # 'б' - 9: 2, # 'в' - 20: 1, # 'г' - 11: 2, # 'д' - 3: 2, # 'е' - 23: 0, # 'ж' - 15: 2, # 'з' - 2: 1, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 2, # 'л' - 14: 2, # 'м' - 6: 3, # 'н' - 4: 2, # 'о' - 13: 1, # 'п' - 7: 2, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 1, # 'у' - 29: 2, # 'ф' - 25: 1, # 'х' - 22: 2, # 'ц' - 21: 2, # 'ч' - 27: 1, # 'ш' - 24: 1, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 12: { # 'к' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 1, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 1, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 3, # 'в' - 20: 2, # 'г' - 11: 1, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 2, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 3, # 'л' - 14: 2, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 1, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 3, # 'у' - 29: 1, # 'ф' - 25: 1, # 'х' - 22: 3, # 'ц' - 21: 2, # 'ч' - 27: 1, # 'ш' - 24: 0, # 'щ' - 17: 3, # 'ъ' - 52: 1, # 'ь' - 42: 2, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 10: { # 'л' - 63: 1, # 'e' - 45: 1, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 1, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 3, # 'г' - 11: 2, # 'д' - 3: 3, # 'е' - 23: 3, # 'ж' - 15: 2, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 1, # 'л' - 14: 2, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 2, # 'п' - 7: 2, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 3, # 'у' - 29: 2, # 'ф' - 25: 2, # 'х' - 22: 2, # 'ц' - 21: 2, # 'ч' - 27: 2, # 'ш' - 24: 1, # 'щ' - 17: 3, # 'ъ' - 52: 2, # 'ь' - 42: 3, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 14: { # 'м' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 1, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 1, # 'г' - 11: 1, # 'д' - 3: 3, # 'е' - 23: 1, # 'ж' - 15: 1, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 2, # 'к' - 10: 3, # 'л' - 14: 1, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 3, # 'п' - 7: 2, # 'р' - 8: 2, # 'с' - 5: 1, # 'т' - 19: 3, # 'у' - 29: 2, # 'ф' - 25: 1, # 'х' - 22: 2, # 'ц' - 21: 2, # 'ч' - 27: 2, # 'ш' - 24: 1, # 'щ' - 17: 3, # 'ъ' - 52: 1, # 'ь' - 42: 2, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 6: { # 'н' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 1, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 2, # 'б' - 9: 2, # 'в' - 20: 3, # 'г' - 11: 3, # 'д' - 3: 3, # 'е' - 23: 2, # 'ж' - 15: 2, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 2, # 'л' - 14: 1, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 1, # 'п' - 7: 2, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 3, # 'у' - 29: 3, # 'ф' - 25: 2, # 'х' - 22: 3, # 'ц' - 21: 3, # 'ч' - 27: 2, # 'ш' - 24: 1, # 'щ' - 17: 3, # 'ъ' - 52: 2, # 'ь' - 42: 2, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 4: { # 'о' - 63: 0, # 'e' - 45: 1, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 2, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 3, # 'г' - 11: 3, # 'д' - 3: 3, # 'е' - 23: 3, # 'ж' - 15: 3, # 'з' - 2: 3, # 'и' - 26: 3, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 2, # 'о' - 13: 3, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 2, # 'у' - 29: 3, # 'ф' - 25: 3, # 'х' - 22: 3, # 'ц' - 21: 3, # 'ч' - 27: 3, # 'ш' - 24: 3, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 13: { # 'п' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 2, # 'в' - 20: 1, # 'г' - 11: 1, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 1, # 'з' - 2: 3, # 'и' - 26: 1, # 'й' - 12: 2, # 'к' - 10: 3, # 'л' - 14: 1, # 'м' - 6: 2, # 'н' - 4: 3, # 'о' - 13: 1, # 'п' - 7: 3, # 'р' - 8: 2, # 'с' - 5: 2, # 'т' - 19: 3, # 'у' - 29: 1, # 'ф' - 25: 1, # 'х' - 22: 2, # 'ц' - 21: 2, # 'ч' - 27: 1, # 'ш' - 24: 1, # 'щ' - 17: 3, # 'ъ' - 52: 1, # 'ь' - 42: 2, # 'ю' - 16: 2, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 7: { # 'р' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 3, # 'г' - 11: 3, # 'д' - 3: 3, # 'е' - 23: 3, # 'ж' - 15: 2, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 2, # 'п' - 7: 1, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 3, # 'у' - 29: 2, # 'ф' - 25: 3, # 'х' - 22: 3, # 'ц' - 21: 2, # 'ч' - 27: 3, # 'ш' - 24: 1, # 'щ' - 17: 3, # 'ъ' - 52: 1, # 'ь' - 42: 2, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 8: { # 'с' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 2, # 'б' - 9: 3, # 'в' - 20: 2, # 'г' - 11: 2, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 1, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 3, # 'п' - 7: 3, # 'р' - 8: 1, # 'с' - 5: 3, # 'т' - 19: 3, # 'у' - 29: 2, # 'ф' - 25: 2, # 'х' - 22: 2, # 'ц' - 21: 2, # 'ч' - 27: 2, # 'ш' - 24: 0, # 'щ' - 17: 3, # 'ъ' - 52: 2, # 'ь' - 42: 2, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 5: { # 'т' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 2, # 'г' - 11: 2, # 'д' - 3: 3, # 'е' - 23: 1, # 'ж' - 15: 1, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 2, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 2, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 3, # 'у' - 29: 1, # 'ф' - 25: 2, # 'х' - 22: 2, # 'ц' - 21: 2, # 'ч' - 27: 1, # 'ш' - 24: 1, # 'щ' - 17: 3, # 'ъ' - 52: 2, # 'ь' - 42: 2, # 'ю' - 16: 3, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 19: { # 'у' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 3, # 'г' - 11: 3, # 'д' - 3: 2, # 'е' - 23: 3, # 'ж' - 15: 3, # 'з' - 2: 2, # 'и' - 26: 2, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 2, # 'о' - 13: 3, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 1, # 'у' - 29: 2, # 'ф' - 25: 2, # 'х' - 22: 2, # 'ц' - 21: 3, # 'ч' - 27: 3, # 'ш' - 24: 2, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 29: { # 'ф' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 1, # 'в' - 20: 1, # 'г' - 11: 0, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 2, # 'к' - 10: 2, # 'л' - 14: 1, # 'м' - 6: 1, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 2, # 'р' - 8: 2, # 'с' - 5: 2, # 'т' - 19: 2, # 'у' - 29: 0, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 1, # 'ч' - 27: 1, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 2, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 25: { # 'х' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 3, # 'в' - 20: 0, # 'г' - 11: 1, # 'д' - 3: 2, # 'е' - 23: 0, # 'ж' - 15: 1, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 2, # 'л' - 14: 2, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 1, # 'п' - 7: 3, # 'р' - 8: 1, # 'с' - 5: 2, # 'т' - 19: 3, # 'у' - 29: 0, # 'ф' - 25: 1, # 'х' - 22: 0, # 'ц' - 21: 1, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 22: { # 'ц' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 2, # 'в' - 20: 1, # 'г' - 11: 1, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 1, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 2, # 'к' - 10: 1, # 'л' - 14: 1, # 'м' - 6: 1, # 'н' - 4: 2, # 'о' - 13: 1, # 'п' - 7: 1, # 'р' - 8: 1, # 'с' - 5: 1, # 'т' - 19: 2, # 'у' - 29: 1, # 'ф' - 25: 1, # 'х' - 22: 1, # 'ц' - 21: 1, # 'ч' - 27: 1, # 'ш' - 24: 1, # 'щ' - 17: 2, # 'ъ' - 52: 1, # 'ь' - 42: 0, # 'ю' - 16: 2, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 21: { # 'ч' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 1, # 'б' - 9: 3, # 'в' - 20: 1, # 'г' - 11: 0, # 'д' - 3: 3, # 'е' - 23: 1, # 'ж' - 15: 0, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 2, # 'л' - 14: 2, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 2, # 'р' - 8: 0, # 'с' - 5: 2, # 'т' - 19: 3, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 1, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 27: { # 'ш' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 0, # 'б' - 9: 2, # 'в' - 20: 0, # 'г' - 11: 1, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 3, # 'к' - 10: 2, # 'л' - 14: 1, # 'м' - 6: 3, # 'н' - 4: 2, # 'о' - 13: 2, # 'п' - 7: 1, # 'р' - 8: 0, # 'с' - 5: 1, # 'т' - 19: 2, # 'у' - 29: 1, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 1, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 2, # 'ъ' - 52: 1, # 'ь' - 42: 1, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 24: { # 'щ' - 63: 1, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 3, # 'а' - 18: 0, # 'б' - 9: 1, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 3, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 3, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 2, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 1, # 'р' - 8: 0, # 'с' - 5: 2, # 'т' - 19: 3, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 1, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 2, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 17: { # 'ъ' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 1, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 3, # 'г' - 11: 3, # 'д' - 3: 2, # 'е' - 23: 3, # 'ж' - 15: 3, # 'з' - 2: 1, # 'и' - 26: 2, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 3, # 'о' - 13: 3, # 'п' - 7: 3, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 1, # 'у' - 29: 1, # 'ф' - 25: 2, # 'х' - 22: 2, # 'ц' - 21: 3, # 'ч' - 27: 2, # 'ш' - 24: 3, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 2, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 52: { # 'ь' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 0, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 1, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 0, # 'и' - 26: 0, # 'й' - 12: 1, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 1, # 'н' - 4: 3, # 'о' - 13: 0, # 'п' - 7: 0, # 'р' - 8: 0, # 'с' - 5: 1, # 'т' - 19: 0, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 1, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 1, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 42: { # 'ю' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 1, # 'а' - 18: 2, # 'б' - 9: 1, # 'в' - 20: 2, # 'г' - 11: 2, # 'д' - 3: 1, # 'е' - 23: 2, # 'ж' - 15: 2, # 'з' - 2: 1, # 'и' - 26: 1, # 'й' - 12: 2, # 'к' - 10: 2, # 'л' - 14: 2, # 'м' - 6: 2, # 'н' - 4: 1, # 'о' - 13: 1, # 'п' - 7: 2, # 'р' - 8: 2, # 'с' - 5: 2, # 'т' - 19: 1, # 'у' - 29: 1, # 'ф' - 25: 1, # 'х' - 22: 2, # 'ц' - 21: 3, # 'ч' - 27: 1, # 'ш' - 24: 1, # 'щ' - 17: 1, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 16: { # 'я' - 63: 0, # 'e' - 45: 1, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 0, # 'а' - 18: 3, # 'б' - 9: 3, # 'в' - 20: 2, # 'г' - 11: 3, # 'д' - 3: 2, # 'е' - 23: 1, # 'ж' - 15: 2, # 'з' - 2: 1, # 'и' - 26: 2, # 'й' - 12: 3, # 'к' - 10: 3, # 'л' - 14: 3, # 'м' - 6: 3, # 'н' - 4: 1, # 'о' - 13: 2, # 'п' - 7: 2, # 'р' - 8: 3, # 'с' - 5: 3, # 'т' - 19: 1, # 'у' - 29: 1, # 'ф' - 25: 3, # 'х' - 22: 2, # 'ц' - 21: 1, # 'ч' - 27: 1, # 'ш' - 24: 2, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 1, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 58: { # 'є' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 0, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 0, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 0, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 0, # 'о' - 13: 0, # 'п' - 7: 0, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 0, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, - 62: { # '№' - 63: 0, # 'e' - 45: 0, # '\xad' - 31: 0, # 'А' - 32: 0, # 'Б' - 35: 0, # 'В' - 43: 0, # 'Г' - 37: 0, # 'Д' - 44: 0, # 'Е' - 55: 0, # 'Ж' - 47: 0, # 'З' - 40: 0, # 'И' - 59: 0, # 'Й' - 33: 0, # 'К' - 46: 0, # 'Л' - 38: 0, # 'М' - 36: 0, # 'Н' - 41: 0, # 'О' - 30: 0, # 'П' - 39: 0, # 'Р' - 28: 0, # 'С' - 34: 0, # 'Т' - 51: 0, # 'У' - 48: 0, # 'Ф' - 49: 0, # 'Х' - 53: 0, # 'Ц' - 50: 0, # 'Ч' - 54: 0, # 'Ш' - 57: 0, # 'Щ' - 61: 0, # 'Ъ' - 60: 0, # 'Ю' - 56: 0, # 'Я' - 1: 0, # 'а' - 18: 0, # 'б' - 9: 0, # 'в' - 20: 0, # 'г' - 11: 0, # 'д' - 3: 0, # 'е' - 23: 0, # 'ж' - 15: 0, # 'з' - 2: 0, # 'и' - 26: 0, # 'й' - 12: 0, # 'к' - 10: 0, # 'л' - 14: 0, # 'м' - 6: 0, # 'н' - 4: 0, # 'о' - 13: 0, # 'п' - 7: 0, # 'р' - 8: 0, # 'с' - 5: 0, # 'т' - 19: 0, # 'у' - 29: 0, # 'ф' - 25: 0, # 'х' - 22: 0, # 'ц' - 21: 0, # 'ч' - 27: 0, # 'ш' - 24: 0, # 'щ' - 17: 0, # 'ъ' - 52: 0, # 'ь' - 42: 0, # 'ю' - 16: 0, # 'я' - 58: 0, # 'є' - 62: 0, # '№' - }, -} - -# 255: Undefined characters that did not exist in training text -# 254: Carriage/Return -# 253: symbol (punctuation) that does not belong to word -# 252: 0 - 9 -# 251: Control characters - -# Character Mapping Table(s): -ISO_8859_5_BULGARIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 77, # 'A' - 66: 90, # 'B' - 67: 99, # 'C' - 68: 100, # 'D' - 69: 72, # 'E' - 70: 109, # 'F' - 71: 107, # 'G' - 72: 101, # 'H' - 73: 79, # 'I' - 74: 185, # 'J' - 75: 81, # 'K' - 76: 102, # 'L' - 77: 76, # 'M' - 78: 94, # 'N' - 79: 82, # 'O' - 80: 110, # 'P' - 81: 186, # 'Q' - 82: 108, # 'R' - 83: 91, # 'S' - 84: 74, # 'T' - 85: 119, # 'U' - 86: 84, # 'V' - 87: 96, # 'W' - 88: 111, # 'X' - 89: 187, # 'Y' - 90: 115, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 65, # 'a' - 98: 69, # 'b' - 99: 70, # 'c' - 100: 66, # 'd' - 101: 63, # 'e' - 102: 68, # 'f' - 103: 112, # 'g' - 104: 103, # 'h' - 105: 92, # 'i' - 106: 194, # 'j' - 107: 104, # 'k' - 108: 95, # 'l' - 109: 86, # 'm' - 110: 87, # 'n' - 111: 71, # 'o' - 112: 116, # 'p' - 113: 195, # 'q' - 114: 85, # 'r' - 115: 93, # 's' - 116: 97, # 't' - 117: 113, # 'u' - 118: 196, # 'v' - 119: 197, # 'w' - 120: 198, # 'x' - 121: 199, # 'y' - 122: 200, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 194, # '\x80' - 129: 195, # '\x81' - 130: 196, # '\x82' - 131: 197, # '\x83' - 132: 198, # '\x84' - 133: 199, # '\x85' - 134: 200, # '\x86' - 135: 201, # '\x87' - 136: 202, # '\x88' - 137: 203, # '\x89' - 138: 204, # '\x8a' - 139: 205, # '\x8b' - 140: 206, # '\x8c' - 141: 207, # '\x8d' - 142: 208, # '\x8e' - 143: 209, # '\x8f' - 144: 210, # '\x90' - 145: 211, # '\x91' - 146: 212, # '\x92' - 147: 213, # '\x93' - 148: 214, # '\x94' - 149: 215, # '\x95' - 150: 216, # '\x96' - 151: 217, # '\x97' - 152: 218, # '\x98' - 153: 219, # '\x99' - 154: 220, # '\x9a' - 155: 221, # '\x9b' - 156: 222, # '\x9c' - 157: 223, # '\x9d' - 158: 224, # '\x9e' - 159: 225, # '\x9f' - 160: 81, # '\xa0' - 161: 226, # 'Ё' - 162: 227, # 'Ђ' - 163: 228, # 'Ѓ' - 164: 229, # 'Є' - 165: 230, # 'Ѕ' - 166: 105, # 'І' - 167: 231, # 'Ї' - 168: 232, # 'Ј' - 169: 233, # 'Љ' - 170: 234, # 'Њ' - 171: 235, # 'Ћ' - 172: 236, # 'Ќ' - 173: 45, # '\xad' - 174: 237, # 'Ў' - 175: 238, # 'Џ' - 176: 31, # 'А' - 177: 32, # 'Б' - 178: 35, # 'В' - 179: 43, # 'Г' - 180: 37, # 'Д' - 181: 44, # 'Е' - 182: 55, # 'Ж' - 183: 47, # 'З' - 184: 40, # 'И' - 185: 59, # 'Й' - 186: 33, # 'К' - 187: 46, # 'Л' - 188: 38, # 'М' - 189: 36, # 'Н' - 190: 41, # 'О' - 191: 30, # 'П' - 192: 39, # 'Р' - 193: 28, # 'С' - 194: 34, # 'Т' - 195: 51, # 'У' - 196: 48, # 'Ф' - 197: 49, # 'Х' - 198: 53, # 'Ц' - 199: 50, # 'Ч' - 200: 54, # 'Ш' - 201: 57, # 'Щ' - 202: 61, # 'Ъ' - 203: 239, # 'Ы' - 204: 67, # 'Ь' - 205: 240, # 'Э' - 206: 60, # 'Ю' - 207: 56, # 'Я' - 208: 1, # 'а' - 209: 18, # 'б' - 210: 9, # 'в' - 211: 20, # 'г' - 212: 11, # 'д' - 213: 3, # 'е' - 214: 23, # 'ж' - 215: 15, # 'з' - 216: 2, # 'и' - 217: 26, # 'й' - 218: 12, # 'к' - 219: 10, # 'л' - 220: 14, # 'м' - 221: 6, # 'н' - 222: 4, # 'о' - 223: 13, # 'п' - 224: 7, # 'р' - 225: 8, # 'с' - 226: 5, # 'т' - 227: 19, # 'у' - 228: 29, # 'ф' - 229: 25, # 'х' - 230: 22, # 'ц' - 231: 21, # 'ч' - 232: 27, # 'ш' - 233: 24, # 'щ' - 234: 17, # 'ъ' - 235: 75, # 'ы' - 236: 52, # 'ь' - 237: 241, # 'э' - 238: 42, # 'ю' - 239: 16, # 'я' - 240: 62, # '№' - 241: 242, # 'ё' - 242: 243, # 'ђ' - 243: 244, # 'ѓ' - 244: 58, # 'є' - 245: 245, # 'ѕ' - 246: 98, # 'і' - 247: 246, # 'ї' - 248: 247, # 'ј' - 249: 248, # 'љ' - 250: 249, # 'њ' - 251: 250, # 'ћ' - 252: 251, # 'ќ' - 253: 91, # '§' - 254: 252, # 'ў' - 255: 253, # 'џ' -} - -ISO_8859_5_BULGARIAN_MODEL = SingleByteCharSetModel( - charset_name="ISO-8859-5", - language="Bulgarian", - char_to_order_map=ISO_8859_5_BULGARIAN_CHAR_TO_ORDER, - language_model=BULGARIAN_LANG_MODEL, - typical_positive_ratio=0.969392, - keep_ascii_letters=False, - alphabet="АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя", -) - -WINDOWS_1251_BULGARIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 77, # 'A' - 66: 90, # 'B' - 67: 99, # 'C' - 68: 100, # 'D' - 69: 72, # 'E' - 70: 109, # 'F' - 71: 107, # 'G' - 72: 101, # 'H' - 73: 79, # 'I' - 74: 185, # 'J' - 75: 81, # 'K' - 76: 102, # 'L' - 77: 76, # 'M' - 78: 94, # 'N' - 79: 82, # 'O' - 80: 110, # 'P' - 81: 186, # 'Q' - 82: 108, # 'R' - 83: 91, # 'S' - 84: 74, # 'T' - 85: 119, # 'U' - 86: 84, # 'V' - 87: 96, # 'W' - 88: 111, # 'X' - 89: 187, # 'Y' - 90: 115, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 65, # 'a' - 98: 69, # 'b' - 99: 70, # 'c' - 100: 66, # 'd' - 101: 63, # 'e' - 102: 68, # 'f' - 103: 112, # 'g' - 104: 103, # 'h' - 105: 92, # 'i' - 106: 194, # 'j' - 107: 104, # 'k' - 108: 95, # 'l' - 109: 86, # 'm' - 110: 87, # 'n' - 111: 71, # 'o' - 112: 116, # 'p' - 113: 195, # 'q' - 114: 85, # 'r' - 115: 93, # 's' - 116: 97, # 't' - 117: 113, # 'u' - 118: 196, # 'v' - 119: 197, # 'w' - 120: 198, # 'x' - 121: 199, # 'y' - 122: 200, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 206, # 'Ђ' - 129: 207, # 'Ѓ' - 130: 208, # '‚' - 131: 209, # 'ѓ' - 132: 210, # '„' - 133: 211, # '…' - 134: 212, # '†' - 135: 213, # '‡' - 136: 120, # '€' - 137: 214, # '‰' - 138: 215, # 'Љ' - 139: 216, # '‹' - 140: 217, # 'Њ' - 141: 218, # 'Ќ' - 142: 219, # 'Ћ' - 143: 220, # 'Џ' - 144: 221, # 'ђ' - 145: 78, # '‘' - 146: 64, # '’' - 147: 83, # '“' - 148: 121, # '”' - 149: 98, # '•' - 150: 117, # '–' - 151: 105, # '—' - 152: 222, # None - 153: 223, # '™' - 154: 224, # 'љ' - 155: 225, # '›' - 156: 226, # 'њ' - 157: 227, # 'ќ' - 158: 228, # 'ћ' - 159: 229, # 'џ' - 160: 88, # '\xa0' - 161: 230, # 'Ў' - 162: 231, # 'ў' - 163: 232, # 'Ј' - 164: 233, # '¤' - 165: 122, # 'Ґ' - 166: 89, # '¦' - 167: 106, # '§' - 168: 234, # 'Ё' - 169: 235, # '©' - 170: 236, # 'Є' - 171: 237, # '«' - 172: 238, # '¬' - 173: 45, # '\xad' - 174: 239, # '®' - 175: 240, # 'Ї' - 176: 73, # '°' - 177: 80, # '±' - 178: 118, # 'І' - 179: 114, # 'і' - 180: 241, # 'ґ' - 181: 242, # 'µ' - 182: 243, # '¶' - 183: 244, # '·' - 184: 245, # 'ё' - 185: 62, # '№' - 186: 58, # 'є' - 187: 246, # '»' - 188: 247, # 'ј' - 189: 248, # 'Ѕ' - 190: 249, # 'ѕ' - 191: 250, # 'ї' - 192: 31, # 'А' - 193: 32, # 'Б' - 194: 35, # 'В' - 195: 43, # 'Г' - 196: 37, # 'Д' - 197: 44, # 'Е' - 198: 55, # 'Ж' - 199: 47, # 'З' - 200: 40, # 'И' - 201: 59, # 'Й' - 202: 33, # 'К' - 203: 46, # 'Л' - 204: 38, # 'М' - 205: 36, # 'Н' - 206: 41, # 'О' - 207: 30, # 'П' - 208: 39, # 'Р' - 209: 28, # 'С' - 210: 34, # 'Т' - 211: 51, # 'У' - 212: 48, # 'Ф' - 213: 49, # 'Х' - 214: 53, # 'Ц' - 215: 50, # 'Ч' - 216: 54, # 'Ш' - 217: 57, # 'Щ' - 218: 61, # 'Ъ' - 219: 251, # 'Ы' - 220: 67, # 'Ь' - 221: 252, # 'Э' - 222: 60, # 'Ю' - 223: 56, # 'Я' - 224: 1, # 'а' - 225: 18, # 'б' - 226: 9, # 'в' - 227: 20, # 'г' - 228: 11, # 'д' - 229: 3, # 'е' - 230: 23, # 'ж' - 231: 15, # 'з' - 232: 2, # 'и' - 233: 26, # 'й' - 234: 12, # 'к' - 235: 10, # 'л' - 236: 14, # 'м' - 237: 6, # 'н' - 238: 4, # 'о' - 239: 13, # 'п' - 240: 7, # 'р' - 241: 8, # 'с' - 242: 5, # 'т' - 243: 19, # 'у' - 244: 29, # 'ф' - 245: 25, # 'х' - 246: 22, # 'ц' - 247: 21, # 'ч' - 248: 27, # 'ш' - 249: 24, # 'щ' - 250: 17, # 'ъ' - 251: 75, # 'ы' - 252: 52, # 'ь' - 253: 253, # 'э' - 254: 42, # 'ю' - 255: 16, # 'я' -} - -WINDOWS_1251_BULGARIAN_MODEL = SingleByteCharSetModel( - charset_name="windows-1251", - language="Bulgarian", - char_to_order_map=WINDOWS_1251_BULGARIAN_CHAR_TO_ORDER, - language_model=BULGARIAN_LANG_MODEL, - typical_positive_ratio=0.969392, - keep_ascii_letters=False, - alphabet="АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя", -) diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py b/myenv/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py deleted file mode 100644 index cfb8639..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py +++ /dev/null @@ -1,4397 +0,0 @@ -from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - -# 3: Positive -# 2: Likely -# 1: Unlikely -# 0: Negative - -GREEK_LANG_MODEL = { - 60: { # 'e' - 60: 2, # 'e' - 55: 1, # 'o' - 58: 2, # 't' - 36: 1, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 1, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 55: { # 'o' - 60: 0, # 'e' - 55: 2, # 'o' - 58: 2, # 't' - 36: 1, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 1, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 1, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 58: { # 't' - 60: 2, # 'e' - 55: 1, # 'o' - 58: 1, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 2, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 1, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 36: { # '·' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 61: { # 'Ά' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 1, # 'γ' - 21: 2, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 1, # 'π' - 8: 2, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 46: { # 'Έ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 2, # 'β' - 20: 2, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 2, # 'κ' - 16: 2, # 'λ' - 10: 0, # 'μ' - 6: 3, # 'ν' - 30: 2, # 'ξ' - 4: 0, # 'ο' - 9: 2, # 'π' - 8: 2, # 'ρ' - 14: 0, # 'ς' - 7: 1, # 'σ' - 2: 2, # 'τ' - 12: 0, # 'υ' - 28: 2, # 'φ' - 23: 3, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 54: { # 'Ό' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 2, # 'μ' - 6: 2, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 2, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 2, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 2, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 31: { # 'Α' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 2, # 'Β' - 43: 2, # 'Γ' - 41: 1, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 2, # 'Θ' - 47: 2, # 'Ι' - 44: 2, # 'Κ' - 53: 2, # 'Λ' - 38: 2, # 'Μ' - 49: 2, # 'Ν' - 59: 1, # 'Ξ' - 39: 0, # 'Ο' - 35: 2, # 'Π' - 48: 2, # 'Ρ' - 37: 2, # 'Σ' - 33: 2, # 'Τ' - 45: 2, # 'Υ' - 56: 2, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 2, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 1, # 'θ' - 5: 0, # 'ι' - 11: 2, # 'κ' - 16: 3, # 'λ' - 10: 2, # 'μ' - 6: 3, # 'ν' - 30: 2, # 'ξ' - 4: 0, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 2, # 'ς' - 7: 2, # 'σ' - 2: 0, # 'τ' - 12: 3, # 'υ' - 28: 2, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 2, # 'ύ' - 27: 0, # 'ώ' - }, - 51: { # 'Β' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 1, # 'Ε' - 40: 1, # 'Η' - 52: 0, # 'Θ' - 47: 1, # 'Ι' - 44: 0, # 'Κ' - 53: 1, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 2, # 'ά' - 18: 2, # 'έ' - 22: 2, # 'ή' - 15: 0, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 2, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 2, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 0, # 'π' - 8: 2, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 43: { # 'Γ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 1, # 'Α' - 51: 0, # 'Β' - 43: 2, # 'Γ' - 41: 0, # 'Δ' - 34: 2, # 'Ε' - 40: 1, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 1, # 'Κ' - 53: 1, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 1, # 'Ο' - 35: 0, # 'Π' - 48: 2, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 2, # 'Υ' - 56: 0, # 'Φ' - 50: 1, # 'Χ' - 57: 2, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 2, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 2, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 0, # 'μ' - 6: 2, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 0, # 'π' - 8: 2, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 41: { # 'Δ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 2, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 2, # 'ή' - 15: 2, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 2, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 0, # 'π' - 8: 2, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 2, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 2, # 'ω' - 19: 1, # 'ό' - 26: 2, # 'ύ' - 27: 2, # 'ώ' - }, - 34: { # 'Ε' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 0, # 'Β' - 43: 2, # 'Γ' - 41: 2, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 2, # 'Κ' - 53: 2, # 'Λ' - 38: 2, # 'Μ' - 49: 2, # 'Ν' - 59: 1, # 'Ξ' - 39: 0, # 'Ο' - 35: 2, # 'Π' - 48: 2, # 'Ρ' - 37: 2, # 'Σ' - 33: 2, # 'Τ' - 45: 2, # 'Υ' - 56: 0, # 'Φ' - 50: 2, # 'Χ' - 57: 2, # 'Ω' - 17: 3, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 3, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 3, # 'γ' - 21: 2, # 'δ' - 3: 1, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 1, # 'θ' - 5: 2, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 2, # 'μ' - 6: 3, # 'ν' - 30: 2, # 'ξ' - 4: 0, # 'ο' - 9: 3, # 'π' - 8: 2, # 'ρ' - 14: 0, # 'ς' - 7: 2, # 'σ' - 2: 2, # 'τ' - 12: 2, # 'υ' - 28: 2, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 1, # 'ύ' - 27: 0, # 'ώ' - }, - 40: { # 'Η' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 1, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 2, # 'Θ' - 47: 0, # 'Ι' - 44: 2, # 'Κ' - 53: 0, # 'Λ' - 38: 2, # 'Μ' - 49: 2, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 2, # 'Π' - 48: 2, # 'Ρ' - 37: 2, # 'Σ' - 33: 2, # 'Τ' - 45: 1, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 0, # 'μ' - 6: 1, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 1, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 52: { # 'Θ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 1, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 1, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 2, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 2, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 2, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 2, # 'ύ' - 27: 0, # 'ώ' - }, - 47: { # 'Ι' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 1, # 'Β' - 43: 1, # 'Γ' - 41: 2, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 2, # 'Κ' - 53: 2, # 'Λ' - 38: 2, # 'Μ' - 49: 2, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 2, # 'Ρ' - 37: 2, # 'Σ' - 33: 2, # 'Τ' - 45: 0, # 'Υ' - 56: 2, # 'Φ' - 50: 0, # 'Χ' - 57: 2, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 2, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 1, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 2, # 'σ' - 2: 1, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 1, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 44: { # 'Κ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 1, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 1, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 2, # 'Ρ' - 37: 0, # 'Σ' - 33: 1, # 'Τ' - 45: 2, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 1, # 'Ω' - 17: 3, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 2, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 2, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 0, # 'π' - 8: 2, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 2, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 2, # 'ό' - 26: 2, # 'ύ' - 27: 2, # 'ώ' - }, - 53: { # 'Λ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 0, # 'Κ' - 53: 2, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 2, # 'Σ' - 33: 0, # 'Τ' - 45: 2, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 2, # 'Ω' - 17: 2, # 'ά' - 18: 2, # 'έ' - 22: 0, # 'ή' - 15: 2, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 2, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 1, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 2, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 2, # 'ό' - 26: 2, # 'ύ' - 27: 0, # 'ώ' - }, - 38: { # 'Μ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 2, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 2, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 2, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 2, # 'ά' - 18: 2, # 'έ' - 22: 2, # 'ή' - 15: 2, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 2, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 3, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 2, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 2, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 49: { # 'Ν' - 60: 2, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 2, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 2, # 'Ω' - 17: 0, # 'ά' - 18: 2, # 'έ' - 22: 0, # 'ή' - 15: 2, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 1, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 1, # 'ω' - 19: 2, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 59: { # 'Ξ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 1, # 'Ε' - 40: 1, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 1, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 2, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 2, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 39: { # 'Ο' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 1, # 'Β' - 43: 2, # 'Γ' - 41: 2, # 'Δ' - 34: 2, # 'Ε' - 40: 1, # 'Η' - 52: 2, # 'Θ' - 47: 2, # 'Ι' - 44: 2, # 'Κ' - 53: 2, # 'Λ' - 38: 2, # 'Μ' - 49: 2, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 2, # 'Π' - 48: 2, # 'Ρ' - 37: 2, # 'Σ' - 33: 2, # 'Τ' - 45: 2, # 'Υ' - 56: 2, # 'Φ' - 50: 2, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 2, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 2, # 'κ' - 16: 2, # 'λ' - 10: 2, # 'μ' - 6: 2, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 2, # 'π' - 8: 2, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 2, # 'τ' - 12: 2, # 'υ' - 28: 1, # 'φ' - 23: 1, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 2, # 'ύ' - 27: 0, # 'ώ' - }, - 35: { # 'Π' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 2, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 0, # 'Κ' - 53: 2, # 'Λ' - 38: 1, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 2, # 'Ρ' - 37: 0, # 'Σ' - 33: 1, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 1, # 'Χ' - 57: 2, # 'Ω' - 17: 2, # 'ά' - 18: 1, # 'έ' - 22: 1, # 'ή' - 15: 2, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 2, # 'η' - 25: 0, # 'θ' - 5: 2, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 0, # 'μ' - 6: 2, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 3, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 2, # 'υ' - 28: 0, # 'φ' - 23: 2, # 'χ' - 42: 0, # 'ψ' - 24: 2, # 'ω' - 19: 2, # 'ό' - 26: 0, # 'ύ' - 27: 3, # 'ώ' - }, - 48: { # 'Ρ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 0, # 'Β' - 43: 1, # 'Γ' - 41: 1, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 2, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 2, # 'Ρ' - 37: 0, # 'Σ' - 33: 1, # 'Τ' - 45: 1, # 'Υ' - 56: 0, # 'Φ' - 50: 1, # 'Χ' - 57: 1, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 2, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 1, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 3, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 2, # 'ω' - 19: 0, # 'ό' - 26: 2, # 'ύ' - 27: 0, # 'ώ' - }, - 37: { # 'Σ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 1, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 2, # 'Κ' - 53: 0, # 'Λ' - 38: 2, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 2, # 'Σ' - 33: 2, # 'Τ' - 45: 2, # 'Υ' - 56: 0, # 'Φ' - 50: 2, # 'Χ' - 57: 2, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 2, # 'ή' - 15: 2, # 'ί' - 1: 2, # 'α' - 29: 2, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 0, # 'θ' - 5: 2, # 'ι' - 11: 2, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 2, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 0, # 'φ' - 23: 2, # 'χ' - 42: 0, # 'ψ' - 24: 2, # 'ω' - 19: 0, # 'ό' - 26: 2, # 'ύ' - 27: 2, # 'ώ' - }, - 33: { # 'Τ' - 60: 0, # 'e' - 55: 1, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 2, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 2, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 2, # 'Ρ' - 37: 0, # 'Σ' - 33: 1, # 'Τ' - 45: 1, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 2, # 'Ω' - 17: 2, # 'ά' - 18: 2, # 'έ' - 22: 0, # 'ή' - 15: 2, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 2, # 'ε' - 32: 0, # 'ζ' - 13: 2, # 'η' - 25: 0, # 'θ' - 5: 2, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 2, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 2, # 'ρ' - 14: 0, # 'ς' - 7: 2, # 'σ' - 2: 0, # 'τ' - 12: 2, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 2, # 'ό' - 26: 2, # 'ύ' - 27: 3, # 'ώ' - }, - 45: { # 'Υ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 2, # 'Γ' - 41: 0, # 'Δ' - 34: 1, # 'Ε' - 40: 2, # 'Η' - 52: 2, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 1, # 'Λ' - 38: 2, # 'Μ' - 49: 2, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 2, # 'Π' - 48: 1, # 'Ρ' - 37: 2, # 'Σ' - 33: 2, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 1, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 3, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 56: { # 'Φ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 1, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 1, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 2, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 2, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 2, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 2, # 'τ' - 12: 2, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 1, # 'ύ' - 27: 1, # 'ώ' - }, - 50: { # 'Χ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 1, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 2, # 'Ε' - 40: 2, # 'Η' - 52: 0, # 'Θ' - 47: 2, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 1, # 'Ν' - 59: 0, # 'Ξ' - 39: 1, # 'Ο' - 35: 0, # 'Π' - 48: 2, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 1, # 'Χ' - 57: 1, # 'Ω' - 17: 2, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 2, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 0, # 'π' - 8: 3, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 2, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 2, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 57: { # 'Ω' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 1, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 1, # 'Λ' - 38: 0, # 'Μ' - 49: 2, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 2, # 'Ρ' - 37: 2, # 'Σ' - 33: 2, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 0, # 'π' - 8: 2, # 'ρ' - 14: 2, # 'ς' - 7: 2, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 1, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 17: { # 'ά' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 2, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 3, # 'β' - 20: 3, # 'γ' - 21: 3, # 'δ' - 3: 3, # 'ε' - 32: 3, # 'ζ' - 13: 0, # 'η' - 25: 3, # 'θ' - 5: 2, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 3, # 'ξ' - 4: 0, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 3, # 'φ' - 23: 3, # 'χ' - 42: 3, # 'ψ' - 24: 2, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 18: { # 'έ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 3, # 'α' - 29: 2, # 'β' - 20: 3, # 'γ' - 21: 2, # 'δ' - 3: 3, # 'ε' - 32: 2, # 'ζ' - 13: 0, # 'η' - 25: 3, # 'θ' - 5: 0, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 3, # 'ξ' - 4: 3, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 3, # 'φ' - 23: 3, # 'χ' - 42: 3, # 'ψ' - 24: 2, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 22: { # 'ή' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 1, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 3, # 'γ' - 21: 3, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 3, # 'θ' - 5: 0, # 'ι' - 11: 3, # 'κ' - 16: 2, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 2, # 'ξ' - 4: 0, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 2, # 'φ' - 23: 3, # 'χ' - 42: 2, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 15: { # 'ί' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 3, # 'α' - 29: 2, # 'β' - 20: 3, # 'γ' - 21: 3, # 'δ' - 3: 3, # 'ε' - 32: 3, # 'ζ' - 13: 3, # 'η' - 25: 3, # 'θ' - 5: 0, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 3, # 'ξ' - 4: 3, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 1, # 'φ' - 23: 3, # 'χ' - 42: 2, # 'ψ' - 24: 3, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 1: { # 'α' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 2, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 2, # 'έ' - 22: 0, # 'ή' - 15: 3, # 'ί' - 1: 0, # 'α' - 29: 3, # 'β' - 20: 3, # 'γ' - 21: 3, # 'δ' - 3: 2, # 'ε' - 32: 3, # 'ζ' - 13: 1, # 'η' - 25: 3, # 'θ' - 5: 3, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 3, # 'ξ' - 4: 2, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 3, # 'φ' - 23: 3, # 'χ' - 42: 2, # 'ψ' - 24: 0, # 'ω' - 19: 2, # 'ό' - 26: 2, # 'ύ' - 27: 0, # 'ώ' - }, - 29: { # 'β' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 2, # 'έ' - 22: 3, # 'ή' - 15: 2, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 2, # 'γ' - 21: 2, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 2, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 3, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 3, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 2, # 'ω' - 19: 2, # 'ό' - 26: 2, # 'ύ' - 27: 2, # 'ώ' - }, - 20: { # 'γ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 3, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 3, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 3, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 2, # 'υ' - 28: 0, # 'φ' - 23: 3, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 2, # 'ύ' - 27: 3, # 'ώ' - }, - 21: { # 'δ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 2, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 3, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 3, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 3, # 'ύ' - 27: 3, # 'ώ' - }, - 3: { # 'ε' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 2, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 3, # 'ί' - 1: 2, # 'α' - 29: 3, # 'β' - 20: 3, # 'γ' - 21: 3, # 'δ' - 3: 2, # 'ε' - 32: 2, # 'ζ' - 13: 0, # 'η' - 25: 3, # 'θ' - 5: 3, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 3, # 'ξ' - 4: 2, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 3, # 'φ' - 23: 3, # 'χ' - 42: 2, # 'ψ' - 24: 3, # 'ω' - 19: 2, # 'ό' - 26: 3, # 'ύ' - 27: 2, # 'ώ' - }, - 32: { # 'ζ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 2, # 'ά' - 18: 2, # 'έ' - 22: 2, # 'ή' - 15: 2, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 0, # 'θ' - 5: 2, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 1, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 2, # 'ό' - 26: 0, # 'ύ' - 27: 2, # 'ώ' - }, - 13: { # 'η' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 2, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 3, # 'γ' - 21: 2, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 3, # 'θ' - 5: 0, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 2, # 'ξ' - 4: 0, # 'ο' - 9: 2, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 2, # 'φ' - 23: 3, # 'χ' - 42: 2, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 25: { # 'θ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 2, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 2, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 1, # 'λ' - 10: 3, # 'μ' - 6: 2, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 3, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 3, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 3, # 'ύ' - 27: 3, # 'ώ' - }, - 5: { # 'ι' - 60: 0, # 'e' - 55: 1, # 'o' - 58: 0, # 't' - 36: 2, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 1, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 0, # 'ί' - 1: 3, # 'α' - 29: 3, # 'β' - 20: 3, # 'γ' - 21: 3, # 'δ' - 3: 3, # 'ε' - 32: 2, # 'ζ' - 13: 3, # 'η' - 25: 3, # 'θ' - 5: 0, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 3, # 'ξ' - 4: 3, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 2, # 'φ' - 23: 3, # 'χ' - 42: 2, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 0, # 'ύ' - 27: 3, # 'ώ' - }, - 11: { # 'κ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 3, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 2, # 'θ' - 5: 3, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 2, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 2, # 'π' - 8: 3, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 2, # 'φ' - 23: 2, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 3, # 'ύ' - 27: 3, # 'ώ' - }, - 16: { # 'λ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 1, # 'β' - 20: 2, # 'γ' - 21: 1, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 2, # 'θ' - 5: 3, # 'ι' - 11: 2, # 'κ' - 16: 3, # 'λ' - 10: 2, # 'μ' - 6: 2, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 3, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 2, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 3, # 'ύ' - 27: 3, # 'ώ' - }, - 10: { # 'μ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 1, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 3, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 3, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 2, # 'υ' - 28: 3, # 'φ' - 23: 0, # 'χ' - 42: 2, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 2, # 'ύ' - 27: 2, # 'ώ' - }, - 6: { # 'ν' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 2, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 3, # 'δ' - 3: 3, # 'ε' - 32: 2, # 'ζ' - 13: 3, # 'η' - 25: 3, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 1, # 'λ' - 10: 0, # 'μ' - 6: 2, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 3, # 'ύ' - 27: 3, # 'ώ' - }, - 30: { # 'ξ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 2, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 2, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 0, # 'θ' - 5: 2, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 3, # 'τ' - 12: 2, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 2, # 'ό' - 26: 3, # 'ύ' - 27: 1, # 'ώ' - }, - 4: { # 'ο' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 2, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 2, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 2, # 'α' - 29: 3, # 'β' - 20: 3, # 'γ' - 21: 3, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 3, # 'θ' - 5: 3, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 2, # 'ξ' - 4: 2, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 3, # 'φ' - 23: 3, # 'χ' - 42: 2, # 'ψ' - 24: 2, # 'ω' - 19: 1, # 'ό' - 26: 3, # 'ύ' - 27: 2, # 'ώ' - }, - 9: { # 'π' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 3, # 'λ' - 10: 0, # 'μ' - 6: 2, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 3, # 'ρ' - 14: 2, # 'ς' - 7: 0, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 0, # 'φ' - 23: 2, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 2, # 'ύ' - 27: 3, # 'ώ' - }, - 8: { # 'ρ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 2, # 'β' - 20: 3, # 'γ' - 21: 2, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 3, # 'θ' - 5: 3, # 'ι' - 11: 3, # 'κ' - 16: 1, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 2, # 'ξ' - 4: 3, # 'ο' - 9: 2, # 'π' - 8: 2, # 'ρ' - 14: 0, # 'ς' - 7: 2, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 3, # 'φ' - 23: 3, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 3, # 'ύ' - 27: 3, # 'ώ' - }, - 14: { # 'ς' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 2, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 0, # 'θ' - 5: 0, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 0, # 'τ' - 12: 0, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 7: { # 'σ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 2, # 'ά' - 18: 2, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 3, # 'β' - 20: 0, # 'γ' - 21: 2, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 3, # 'θ' - 5: 3, # 'ι' - 11: 3, # 'κ' - 16: 2, # 'λ' - 10: 3, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 3, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 3, # 'φ' - 23: 3, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 3, # 'ύ' - 27: 2, # 'ώ' - }, - 2: { # 'τ' - 60: 0, # 'e' - 55: 2, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 2, # 'ζ' - 13: 3, # 'η' - 25: 0, # 'θ' - 5: 3, # 'ι' - 11: 2, # 'κ' - 16: 2, # 'λ' - 10: 3, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 3, # 'ρ' - 14: 0, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 2, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 3, # 'ύ' - 27: 3, # 'ώ' - }, - 12: { # 'υ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 2, # 'ά' - 18: 2, # 'έ' - 22: 3, # 'ή' - 15: 2, # 'ί' - 1: 3, # 'α' - 29: 2, # 'β' - 20: 3, # 'γ' - 21: 2, # 'δ' - 3: 2, # 'ε' - 32: 2, # 'ζ' - 13: 2, # 'η' - 25: 3, # 'θ' - 5: 2, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 3, # 'ξ' - 4: 3, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 2, # 'φ' - 23: 3, # 'χ' - 42: 2, # 'ψ' - 24: 2, # 'ω' - 19: 2, # 'ό' - 26: 0, # 'ύ' - 27: 2, # 'ώ' - }, - 28: { # 'φ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 3, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 2, # 'η' - 25: 2, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 0, # 'μ' - 6: 1, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 3, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 1, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 2, # 'ύ' - 27: 2, # 'ώ' - }, - 23: { # 'χ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 3, # 'ά' - 18: 2, # 'έ' - 22: 3, # 'ή' - 15: 3, # 'ί' - 1: 3, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 2, # 'η' - 25: 2, # 'θ' - 5: 3, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 2, # 'μ' - 6: 3, # 'ν' - 30: 0, # 'ξ' - 4: 3, # 'ο' - 9: 0, # 'π' - 8: 3, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 3, # 'τ' - 12: 3, # 'υ' - 28: 0, # 'φ' - 23: 2, # 'χ' - 42: 0, # 'ψ' - 24: 3, # 'ω' - 19: 3, # 'ό' - 26: 3, # 'ύ' - 27: 3, # 'ώ' - }, - 42: { # 'ψ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 2, # 'ά' - 18: 2, # 'έ' - 22: 1, # 'ή' - 15: 2, # 'ί' - 1: 2, # 'α' - 29: 0, # 'β' - 20: 0, # 'γ' - 21: 0, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 3, # 'η' - 25: 0, # 'θ' - 5: 2, # 'ι' - 11: 0, # 'κ' - 16: 0, # 'λ' - 10: 0, # 'μ' - 6: 0, # 'ν' - 30: 0, # 'ξ' - 4: 2, # 'ο' - 9: 0, # 'π' - 8: 0, # 'ρ' - 14: 0, # 'ς' - 7: 0, # 'σ' - 2: 2, # 'τ' - 12: 1, # 'υ' - 28: 0, # 'φ' - 23: 0, # 'χ' - 42: 0, # 'ψ' - 24: 2, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 24: { # 'ω' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 1, # 'ά' - 18: 0, # 'έ' - 22: 2, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 2, # 'β' - 20: 3, # 'γ' - 21: 2, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 0, # 'η' - 25: 3, # 'θ' - 5: 2, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 0, # 'ξ' - 4: 0, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 2, # 'φ' - 23: 2, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 19: { # 'ό' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 3, # 'β' - 20: 3, # 'γ' - 21: 3, # 'δ' - 3: 1, # 'ε' - 32: 2, # 'ζ' - 13: 2, # 'η' - 25: 2, # 'θ' - 5: 2, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 1, # 'ξ' - 4: 2, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 2, # 'φ' - 23: 3, # 'χ' - 42: 2, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 26: { # 'ύ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 2, # 'α' - 29: 2, # 'β' - 20: 2, # 'γ' - 21: 1, # 'δ' - 3: 3, # 'ε' - 32: 0, # 'ζ' - 13: 2, # 'η' - 25: 3, # 'θ' - 5: 0, # 'ι' - 11: 3, # 'κ' - 16: 3, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 2, # 'ξ' - 4: 3, # 'ο' - 9: 3, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 2, # 'φ' - 23: 2, # 'χ' - 42: 2, # 'ψ' - 24: 2, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, - 27: { # 'ώ' - 60: 0, # 'e' - 55: 0, # 'o' - 58: 0, # 't' - 36: 0, # '·' - 61: 0, # 'Ά' - 46: 0, # 'Έ' - 54: 0, # 'Ό' - 31: 0, # 'Α' - 51: 0, # 'Β' - 43: 0, # 'Γ' - 41: 0, # 'Δ' - 34: 0, # 'Ε' - 40: 0, # 'Η' - 52: 0, # 'Θ' - 47: 0, # 'Ι' - 44: 0, # 'Κ' - 53: 0, # 'Λ' - 38: 0, # 'Μ' - 49: 0, # 'Ν' - 59: 0, # 'Ξ' - 39: 0, # 'Ο' - 35: 0, # 'Π' - 48: 0, # 'Ρ' - 37: 0, # 'Σ' - 33: 0, # 'Τ' - 45: 0, # 'Υ' - 56: 0, # 'Φ' - 50: 0, # 'Χ' - 57: 0, # 'Ω' - 17: 0, # 'ά' - 18: 0, # 'έ' - 22: 0, # 'ή' - 15: 0, # 'ί' - 1: 0, # 'α' - 29: 1, # 'β' - 20: 0, # 'γ' - 21: 3, # 'δ' - 3: 0, # 'ε' - 32: 0, # 'ζ' - 13: 1, # 'η' - 25: 2, # 'θ' - 5: 2, # 'ι' - 11: 0, # 'κ' - 16: 2, # 'λ' - 10: 3, # 'μ' - 6: 3, # 'ν' - 30: 1, # 'ξ' - 4: 0, # 'ο' - 9: 2, # 'π' - 8: 3, # 'ρ' - 14: 3, # 'ς' - 7: 3, # 'σ' - 2: 3, # 'τ' - 12: 0, # 'υ' - 28: 1, # 'φ' - 23: 1, # 'χ' - 42: 0, # 'ψ' - 24: 0, # 'ω' - 19: 0, # 'ό' - 26: 0, # 'ύ' - 27: 0, # 'ώ' - }, -} - -# 255: Undefined characters that did not exist in training text -# 254: Carriage/Return -# 253: symbol (punctuation) that does not belong to word -# 252: 0 - 9 -# 251: Control characters - -# Character Mapping Table(s): -WINDOWS_1253_GREEK_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 82, # 'A' - 66: 100, # 'B' - 67: 104, # 'C' - 68: 94, # 'D' - 69: 98, # 'E' - 70: 101, # 'F' - 71: 116, # 'G' - 72: 102, # 'H' - 73: 111, # 'I' - 74: 187, # 'J' - 75: 117, # 'K' - 76: 92, # 'L' - 77: 88, # 'M' - 78: 113, # 'N' - 79: 85, # 'O' - 80: 79, # 'P' - 81: 118, # 'Q' - 82: 105, # 'R' - 83: 83, # 'S' - 84: 67, # 'T' - 85: 114, # 'U' - 86: 119, # 'V' - 87: 95, # 'W' - 88: 99, # 'X' - 89: 109, # 'Y' - 90: 188, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 72, # 'a' - 98: 70, # 'b' - 99: 80, # 'c' - 100: 81, # 'd' - 101: 60, # 'e' - 102: 96, # 'f' - 103: 93, # 'g' - 104: 89, # 'h' - 105: 68, # 'i' - 106: 120, # 'j' - 107: 97, # 'k' - 108: 77, # 'l' - 109: 86, # 'm' - 110: 69, # 'n' - 111: 55, # 'o' - 112: 78, # 'p' - 113: 115, # 'q' - 114: 65, # 'r' - 115: 66, # 's' - 116: 58, # 't' - 117: 76, # 'u' - 118: 106, # 'v' - 119: 103, # 'w' - 120: 87, # 'x' - 121: 107, # 'y' - 122: 112, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 255, # '€' - 129: 255, # None - 130: 255, # '‚' - 131: 255, # 'ƒ' - 132: 255, # '„' - 133: 255, # '…' - 134: 255, # '†' - 135: 255, # '‡' - 136: 255, # None - 137: 255, # '‰' - 138: 255, # None - 139: 255, # '‹' - 140: 255, # None - 141: 255, # None - 142: 255, # None - 143: 255, # None - 144: 255, # None - 145: 255, # '‘' - 146: 255, # '’' - 147: 255, # '“' - 148: 255, # '”' - 149: 255, # '•' - 150: 255, # '–' - 151: 255, # '—' - 152: 255, # None - 153: 255, # '™' - 154: 255, # None - 155: 255, # '›' - 156: 255, # None - 157: 255, # None - 158: 255, # None - 159: 255, # None - 160: 253, # '\xa0' - 161: 233, # '΅' - 162: 61, # 'Ά' - 163: 253, # '£' - 164: 253, # '¤' - 165: 253, # '¥' - 166: 253, # '¦' - 167: 253, # '§' - 168: 253, # '¨' - 169: 253, # '©' - 170: 253, # None - 171: 253, # '«' - 172: 253, # '¬' - 173: 74, # '\xad' - 174: 253, # '®' - 175: 253, # '―' - 176: 253, # '°' - 177: 253, # '±' - 178: 253, # '²' - 179: 253, # '³' - 180: 247, # '΄' - 181: 253, # 'µ' - 182: 253, # '¶' - 183: 36, # '·' - 184: 46, # 'Έ' - 185: 71, # 'Ή' - 186: 73, # 'Ί' - 187: 253, # '»' - 188: 54, # 'Ό' - 189: 253, # '½' - 190: 108, # 'Ύ' - 191: 123, # 'Ώ' - 192: 110, # 'ΐ' - 193: 31, # 'Α' - 194: 51, # 'Β' - 195: 43, # 'Γ' - 196: 41, # 'Δ' - 197: 34, # 'Ε' - 198: 91, # 'Ζ' - 199: 40, # 'Η' - 200: 52, # 'Θ' - 201: 47, # 'Ι' - 202: 44, # 'Κ' - 203: 53, # 'Λ' - 204: 38, # 'Μ' - 205: 49, # 'Ν' - 206: 59, # 'Ξ' - 207: 39, # 'Ο' - 208: 35, # 'Π' - 209: 48, # 'Ρ' - 210: 250, # None - 211: 37, # 'Σ' - 212: 33, # 'Τ' - 213: 45, # 'Υ' - 214: 56, # 'Φ' - 215: 50, # 'Χ' - 216: 84, # 'Ψ' - 217: 57, # 'Ω' - 218: 120, # 'Ϊ' - 219: 121, # 'Ϋ' - 220: 17, # 'ά' - 221: 18, # 'έ' - 222: 22, # 'ή' - 223: 15, # 'ί' - 224: 124, # 'ΰ' - 225: 1, # 'α' - 226: 29, # 'β' - 227: 20, # 'γ' - 228: 21, # 'δ' - 229: 3, # 'ε' - 230: 32, # 'ζ' - 231: 13, # 'η' - 232: 25, # 'θ' - 233: 5, # 'ι' - 234: 11, # 'κ' - 235: 16, # 'λ' - 236: 10, # 'μ' - 237: 6, # 'ν' - 238: 30, # 'ξ' - 239: 4, # 'ο' - 240: 9, # 'π' - 241: 8, # 'ρ' - 242: 14, # 'ς' - 243: 7, # 'σ' - 244: 2, # 'τ' - 245: 12, # 'υ' - 246: 28, # 'φ' - 247: 23, # 'χ' - 248: 42, # 'ψ' - 249: 24, # 'ω' - 250: 64, # 'ϊ' - 251: 75, # 'ϋ' - 252: 19, # 'ό' - 253: 26, # 'ύ' - 254: 27, # 'ώ' - 255: 253, # None -} - -WINDOWS_1253_GREEK_MODEL = SingleByteCharSetModel( - charset_name="windows-1253", - language="Greek", - char_to_order_map=WINDOWS_1253_GREEK_CHAR_TO_ORDER, - language_model=GREEK_LANG_MODEL, - typical_positive_ratio=0.982851, - keep_ascii_letters=False, - alphabet="ΆΈΉΊΌΎΏΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩάέήίαβγδεζηθικλμνξοπρςστυφχψωόύώ", -) - -ISO_8859_7_GREEK_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 82, # 'A' - 66: 100, # 'B' - 67: 104, # 'C' - 68: 94, # 'D' - 69: 98, # 'E' - 70: 101, # 'F' - 71: 116, # 'G' - 72: 102, # 'H' - 73: 111, # 'I' - 74: 187, # 'J' - 75: 117, # 'K' - 76: 92, # 'L' - 77: 88, # 'M' - 78: 113, # 'N' - 79: 85, # 'O' - 80: 79, # 'P' - 81: 118, # 'Q' - 82: 105, # 'R' - 83: 83, # 'S' - 84: 67, # 'T' - 85: 114, # 'U' - 86: 119, # 'V' - 87: 95, # 'W' - 88: 99, # 'X' - 89: 109, # 'Y' - 90: 188, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 72, # 'a' - 98: 70, # 'b' - 99: 80, # 'c' - 100: 81, # 'd' - 101: 60, # 'e' - 102: 96, # 'f' - 103: 93, # 'g' - 104: 89, # 'h' - 105: 68, # 'i' - 106: 120, # 'j' - 107: 97, # 'k' - 108: 77, # 'l' - 109: 86, # 'm' - 110: 69, # 'n' - 111: 55, # 'o' - 112: 78, # 'p' - 113: 115, # 'q' - 114: 65, # 'r' - 115: 66, # 's' - 116: 58, # 't' - 117: 76, # 'u' - 118: 106, # 'v' - 119: 103, # 'w' - 120: 87, # 'x' - 121: 107, # 'y' - 122: 112, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 255, # '\x80' - 129: 255, # '\x81' - 130: 255, # '\x82' - 131: 255, # '\x83' - 132: 255, # '\x84' - 133: 255, # '\x85' - 134: 255, # '\x86' - 135: 255, # '\x87' - 136: 255, # '\x88' - 137: 255, # '\x89' - 138: 255, # '\x8a' - 139: 255, # '\x8b' - 140: 255, # '\x8c' - 141: 255, # '\x8d' - 142: 255, # '\x8e' - 143: 255, # '\x8f' - 144: 255, # '\x90' - 145: 255, # '\x91' - 146: 255, # '\x92' - 147: 255, # '\x93' - 148: 255, # '\x94' - 149: 255, # '\x95' - 150: 255, # '\x96' - 151: 255, # '\x97' - 152: 255, # '\x98' - 153: 255, # '\x99' - 154: 255, # '\x9a' - 155: 255, # '\x9b' - 156: 255, # '\x9c' - 157: 255, # '\x9d' - 158: 255, # '\x9e' - 159: 255, # '\x9f' - 160: 253, # '\xa0' - 161: 233, # '‘' - 162: 90, # '’' - 163: 253, # '£' - 164: 253, # '€' - 165: 253, # '₯' - 166: 253, # '¦' - 167: 253, # '§' - 168: 253, # '¨' - 169: 253, # '©' - 170: 253, # 'ͺ' - 171: 253, # '«' - 172: 253, # '¬' - 173: 74, # '\xad' - 174: 253, # None - 175: 253, # '―' - 176: 253, # '°' - 177: 253, # '±' - 178: 253, # '²' - 179: 253, # '³' - 180: 247, # '΄' - 181: 248, # '΅' - 182: 61, # 'Ά' - 183: 36, # '·' - 184: 46, # 'Έ' - 185: 71, # 'Ή' - 186: 73, # 'Ί' - 187: 253, # '»' - 188: 54, # 'Ό' - 189: 253, # '½' - 190: 108, # 'Ύ' - 191: 123, # 'Ώ' - 192: 110, # 'ΐ' - 193: 31, # 'Α' - 194: 51, # 'Β' - 195: 43, # 'Γ' - 196: 41, # 'Δ' - 197: 34, # 'Ε' - 198: 91, # 'Ζ' - 199: 40, # 'Η' - 200: 52, # 'Θ' - 201: 47, # 'Ι' - 202: 44, # 'Κ' - 203: 53, # 'Λ' - 204: 38, # 'Μ' - 205: 49, # 'Ν' - 206: 59, # 'Ξ' - 207: 39, # 'Ο' - 208: 35, # 'Π' - 209: 48, # 'Ρ' - 210: 250, # None - 211: 37, # 'Σ' - 212: 33, # 'Τ' - 213: 45, # 'Υ' - 214: 56, # 'Φ' - 215: 50, # 'Χ' - 216: 84, # 'Ψ' - 217: 57, # 'Ω' - 218: 120, # 'Ϊ' - 219: 121, # 'Ϋ' - 220: 17, # 'ά' - 221: 18, # 'έ' - 222: 22, # 'ή' - 223: 15, # 'ί' - 224: 124, # 'ΰ' - 225: 1, # 'α' - 226: 29, # 'β' - 227: 20, # 'γ' - 228: 21, # 'δ' - 229: 3, # 'ε' - 230: 32, # 'ζ' - 231: 13, # 'η' - 232: 25, # 'θ' - 233: 5, # 'ι' - 234: 11, # 'κ' - 235: 16, # 'λ' - 236: 10, # 'μ' - 237: 6, # 'ν' - 238: 30, # 'ξ' - 239: 4, # 'ο' - 240: 9, # 'π' - 241: 8, # 'ρ' - 242: 14, # 'ς' - 243: 7, # 'σ' - 244: 2, # 'τ' - 245: 12, # 'υ' - 246: 28, # 'φ' - 247: 23, # 'χ' - 248: 42, # 'ψ' - 249: 24, # 'ω' - 250: 64, # 'ϊ' - 251: 75, # 'ϋ' - 252: 19, # 'ό' - 253: 26, # 'ύ' - 254: 27, # 'ώ' - 255: 253, # None -} - -ISO_8859_7_GREEK_MODEL = SingleByteCharSetModel( - charset_name="ISO-8859-7", - language="Greek", - char_to_order_map=ISO_8859_7_GREEK_CHAR_TO_ORDER, - language_model=GREEK_LANG_MODEL, - typical_positive_ratio=0.982851, - keep_ascii_letters=False, - alphabet="ΆΈΉΊΌΎΏΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩάέήίαβγδεζηθικλμνξοπρςστυφχψωόύώ", -) diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py b/myenv/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py deleted file mode 100644 index 56d2975..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py +++ /dev/null @@ -1,4380 +0,0 @@ -from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - -# 3: Positive -# 2: Likely -# 1: Unlikely -# 0: Negative - -HEBREW_LANG_MODEL = { - 50: { # 'a' - 50: 0, # 'a' - 60: 1, # 'c' - 61: 1, # 'd' - 42: 1, # 'e' - 53: 1, # 'i' - 56: 2, # 'l' - 54: 2, # 'n' - 49: 0, # 'o' - 51: 2, # 'r' - 43: 1, # 's' - 44: 2, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 1, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 1, # 'ק' - 7: 0, # 'ר' - 10: 1, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 60: { # 'c' - 50: 1, # 'a' - 60: 1, # 'c' - 61: 0, # 'd' - 42: 1, # 'e' - 53: 1, # 'i' - 56: 1, # 'l' - 54: 0, # 'n' - 49: 1, # 'o' - 51: 1, # 'r' - 43: 1, # 's' - 44: 2, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 1, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 1, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 61: { # 'd' - 50: 1, # 'a' - 60: 0, # 'c' - 61: 1, # 'd' - 42: 1, # 'e' - 53: 1, # 'i' - 56: 1, # 'l' - 54: 1, # 'n' - 49: 2, # 'o' - 51: 1, # 'r' - 43: 1, # 's' - 44: 0, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 1, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 1, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 42: { # 'e' - 50: 1, # 'a' - 60: 1, # 'c' - 61: 2, # 'd' - 42: 1, # 'e' - 53: 1, # 'i' - 56: 2, # 'l' - 54: 2, # 'n' - 49: 1, # 'o' - 51: 2, # 'r' - 43: 2, # 's' - 44: 2, # 't' - 63: 1, # 'u' - 34: 1, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 1, # '–' - 52: 2, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 53: { # 'i' - 50: 1, # 'a' - 60: 2, # 'c' - 61: 1, # 'd' - 42: 1, # 'e' - 53: 0, # 'i' - 56: 1, # 'l' - 54: 2, # 'n' - 49: 2, # 'o' - 51: 1, # 'r' - 43: 2, # 's' - 44: 2, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 56: { # 'l' - 50: 1, # 'a' - 60: 1, # 'c' - 61: 1, # 'd' - 42: 2, # 'e' - 53: 2, # 'i' - 56: 2, # 'l' - 54: 1, # 'n' - 49: 1, # 'o' - 51: 0, # 'r' - 43: 1, # 's' - 44: 1, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 54: { # 'n' - 50: 1, # 'a' - 60: 1, # 'c' - 61: 1, # 'd' - 42: 1, # 'e' - 53: 1, # 'i' - 56: 1, # 'l' - 54: 1, # 'n' - 49: 1, # 'o' - 51: 0, # 'r' - 43: 1, # 's' - 44: 2, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 1, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 2, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 49: { # 'o' - 50: 1, # 'a' - 60: 1, # 'c' - 61: 1, # 'd' - 42: 1, # 'e' - 53: 1, # 'i' - 56: 1, # 'l' - 54: 2, # 'n' - 49: 1, # 'o' - 51: 2, # 'r' - 43: 1, # 's' - 44: 1, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 51: { # 'r' - 50: 2, # 'a' - 60: 1, # 'c' - 61: 1, # 'd' - 42: 2, # 'e' - 53: 1, # 'i' - 56: 1, # 'l' - 54: 1, # 'n' - 49: 2, # 'o' - 51: 1, # 'r' - 43: 1, # 's' - 44: 1, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 2, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 43: { # 's' - 50: 1, # 'a' - 60: 1, # 'c' - 61: 0, # 'd' - 42: 2, # 'e' - 53: 1, # 'i' - 56: 1, # 'l' - 54: 1, # 'n' - 49: 1, # 'o' - 51: 1, # 'r' - 43: 1, # 's' - 44: 2, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 2, # '”' - 58: 0, # '†' - 40: 2, # '…' - }, - 44: { # 't' - 50: 1, # 'a' - 60: 1, # 'c' - 61: 0, # 'd' - 42: 2, # 'e' - 53: 2, # 'i' - 56: 1, # 'l' - 54: 0, # 'n' - 49: 1, # 'o' - 51: 1, # 'r' - 43: 1, # 's' - 44: 1, # 't' - 63: 1, # 'u' - 34: 1, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 2, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 63: { # 'u' - 50: 1, # 'a' - 60: 1, # 'c' - 61: 1, # 'd' - 42: 1, # 'e' - 53: 1, # 'i' - 56: 1, # 'l' - 54: 1, # 'n' - 49: 0, # 'o' - 51: 1, # 'r' - 43: 2, # 's' - 44: 1, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 34: { # '\xa0' - 50: 1, # 'a' - 60: 0, # 'c' - 61: 1, # 'd' - 42: 0, # 'e' - 53: 1, # 'i' - 56: 0, # 'l' - 54: 1, # 'n' - 49: 1, # 'o' - 51: 0, # 'r' - 43: 1, # 's' - 44: 1, # 't' - 63: 0, # 'u' - 34: 2, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 1, # 'ב' - 20: 1, # 'ג' - 16: 1, # 'ד' - 3: 1, # 'ה' - 2: 1, # 'ו' - 24: 1, # 'ז' - 14: 1, # 'ח' - 22: 1, # 'ט' - 1: 2, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 2, # 'מ' - 23: 0, # 'ן' - 12: 1, # 'נ' - 19: 1, # 'ס' - 13: 1, # 'ע' - 26: 0, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 1, # 'צ' - 17: 1, # 'ק' - 7: 1, # 'ר' - 10: 1, # 'ש' - 5: 1, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 55: { # '´' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 1, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 1, # 'ה' - 2: 1, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 2, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 1, # 'ן' - 12: 1, # 'נ' - 19: 1, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 1, # 'ר' - 10: 1, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 48: { # '¼' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 1, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 39: { # '½' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 1, # 'צ' - 17: 1, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 57: { # '¾' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 30: { # 'ְ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 1, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 1, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 2, # 'ב' - 20: 2, # 'ג' - 16: 2, # 'ד' - 3: 2, # 'ה' - 2: 2, # 'ו' - 24: 2, # 'ז' - 14: 2, # 'ח' - 22: 2, # 'ט' - 1: 2, # 'י' - 25: 2, # 'ך' - 15: 2, # 'כ' - 4: 2, # 'ל' - 11: 1, # 'ם' - 6: 2, # 'מ' - 23: 0, # 'ן' - 12: 2, # 'נ' - 19: 2, # 'ס' - 13: 2, # 'ע' - 26: 0, # 'ף' - 18: 2, # 'פ' - 27: 0, # 'ץ' - 21: 2, # 'צ' - 17: 2, # 'ק' - 7: 2, # 'ר' - 10: 2, # 'ש' - 5: 2, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 59: { # 'ֱ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 1, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 1, # 'ב' - 20: 1, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 1, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 1, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 2, # 'ל' - 11: 0, # 'ם' - 6: 2, # 'מ' - 23: 0, # 'ן' - 12: 1, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 1, # 'ר' - 10: 1, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 41: { # 'ֲ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 2, # 'ב' - 20: 1, # 'ג' - 16: 2, # 'ד' - 3: 1, # 'ה' - 2: 1, # 'ו' - 24: 1, # 'ז' - 14: 1, # 'ח' - 22: 1, # 'ט' - 1: 1, # 'י' - 25: 1, # 'ך' - 15: 1, # 'כ' - 4: 2, # 'ל' - 11: 0, # 'ם' - 6: 2, # 'מ' - 23: 0, # 'ן' - 12: 2, # 'נ' - 19: 1, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 2, # 'צ' - 17: 1, # 'ק' - 7: 2, # 'ר' - 10: 2, # 'ש' - 5: 1, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 33: { # 'ִ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 1, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 1, # 'ִ' - 37: 0, # 'ֵ' - 36: 1, # 'ֶ' - 31: 0, # 'ַ' - 29: 1, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 1, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 2, # 'ב' - 20: 2, # 'ג' - 16: 2, # 'ד' - 3: 1, # 'ה' - 2: 1, # 'ו' - 24: 2, # 'ז' - 14: 1, # 'ח' - 22: 1, # 'ט' - 1: 3, # 'י' - 25: 1, # 'ך' - 15: 2, # 'כ' - 4: 2, # 'ל' - 11: 2, # 'ם' - 6: 2, # 'מ' - 23: 2, # 'ן' - 12: 2, # 'נ' - 19: 2, # 'ס' - 13: 1, # 'ע' - 26: 0, # 'ף' - 18: 2, # 'פ' - 27: 1, # 'ץ' - 21: 2, # 'צ' - 17: 2, # 'ק' - 7: 2, # 'ר' - 10: 2, # 'ש' - 5: 2, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 37: { # 'ֵ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 1, # 'ֶ' - 31: 1, # 'ַ' - 29: 1, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 2, # 'ב' - 20: 1, # 'ג' - 16: 2, # 'ד' - 3: 2, # 'ה' - 2: 1, # 'ו' - 24: 1, # 'ז' - 14: 2, # 'ח' - 22: 1, # 'ט' - 1: 3, # 'י' - 25: 2, # 'ך' - 15: 1, # 'כ' - 4: 2, # 'ל' - 11: 2, # 'ם' - 6: 1, # 'מ' - 23: 2, # 'ן' - 12: 2, # 'נ' - 19: 1, # 'ס' - 13: 2, # 'ע' - 26: 1, # 'ף' - 18: 1, # 'פ' - 27: 1, # 'ץ' - 21: 1, # 'צ' - 17: 1, # 'ק' - 7: 2, # 'ר' - 10: 2, # 'ש' - 5: 2, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 36: { # 'ֶ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 1, # 'ֶ' - 31: 1, # 'ַ' - 29: 1, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 2, # 'ב' - 20: 1, # 'ג' - 16: 2, # 'ד' - 3: 2, # 'ה' - 2: 1, # 'ו' - 24: 1, # 'ז' - 14: 2, # 'ח' - 22: 1, # 'ט' - 1: 2, # 'י' - 25: 2, # 'ך' - 15: 1, # 'כ' - 4: 2, # 'ל' - 11: 2, # 'ם' - 6: 2, # 'מ' - 23: 2, # 'ן' - 12: 2, # 'נ' - 19: 2, # 'ס' - 13: 1, # 'ע' - 26: 1, # 'ף' - 18: 1, # 'פ' - 27: 2, # 'ץ' - 21: 1, # 'צ' - 17: 1, # 'ק' - 7: 2, # 'ר' - 10: 2, # 'ש' - 5: 2, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 31: { # 'ַ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 1, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 1, # 'ֶ' - 31: 0, # 'ַ' - 29: 2, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 2, # 'ב' - 20: 2, # 'ג' - 16: 2, # 'ד' - 3: 2, # 'ה' - 2: 1, # 'ו' - 24: 2, # 'ז' - 14: 2, # 'ח' - 22: 2, # 'ט' - 1: 3, # 'י' - 25: 1, # 'ך' - 15: 2, # 'כ' - 4: 2, # 'ל' - 11: 2, # 'ם' - 6: 2, # 'מ' - 23: 2, # 'ן' - 12: 2, # 'נ' - 19: 2, # 'ס' - 13: 2, # 'ע' - 26: 2, # 'ף' - 18: 2, # 'פ' - 27: 1, # 'ץ' - 21: 2, # 'צ' - 17: 2, # 'ק' - 7: 2, # 'ר' - 10: 2, # 'ש' - 5: 2, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 29: { # 'ָ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 1, # 'ַ' - 29: 2, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 1, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 2, # 'ב' - 20: 2, # 'ג' - 16: 2, # 'ד' - 3: 3, # 'ה' - 2: 2, # 'ו' - 24: 2, # 'ז' - 14: 2, # 'ח' - 22: 1, # 'ט' - 1: 2, # 'י' - 25: 2, # 'ך' - 15: 2, # 'כ' - 4: 2, # 'ל' - 11: 2, # 'ם' - 6: 2, # 'מ' - 23: 2, # 'ן' - 12: 2, # 'נ' - 19: 1, # 'ס' - 13: 2, # 'ע' - 26: 1, # 'ף' - 18: 2, # 'פ' - 27: 1, # 'ץ' - 21: 2, # 'צ' - 17: 2, # 'ק' - 7: 2, # 'ר' - 10: 2, # 'ש' - 5: 2, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 35: { # 'ֹ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 1, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 2, # 'ב' - 20: 1, # 'ג' - 16: 2, # 'ד' - 3: 2, # 'ה' - 2: 1, # 'ו' - 24: 1, # 'ז' - 14: 1, # 'ח' - 22: 1, # 'ט' - 1: 1, # 'י' - 25: 1, # 'ך' - 15: 2, # 'כ' - 4: 2, # 'ל' - 11: 2, # 'ם' - 6: 2, # 'מ' - 23: 2, # 'ן' - 12: 2, # 'נ' - 19: 2, # 'ס' - 13: 2, # 'ע' - 26: 1, # 'ף' - 18: 2, # 'פ' - 27: 1, # 'ץ' - 21: 2, # 'צ' - 17: 2, # 'ק' - 7: 2, # 'ר' - 10: 2, # 'ש' - 5: 2, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 62: { # 'ֻ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 1, # 'ב' - 20: 1, # 'ג' - 16: 1, # 'ד' - 3: 1, # 'ה' - 2: 1, # 'ו' - 24: 1, # 'ז' - 14: 1, # 'ח' - 22: 0, # 'ט' - 1: 1, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 2, # 'ל' - 11: 1, # 'ם' - 6: 1, # 'מ' - 23: 1, # 'ן' - 12: 1, # 'נ' - 19: 1, # 'ס' - 13: 1, # 'ע' - 26: 0, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 1, # 'צ' - 17: 1, # 'ק' - 7: 1, # 'ר' - 10: 1, # 'ש' - 5: 1, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 28: { # 'ּ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 3, # 'ְ' - 59: 0, # 'ֱ' - 41: 1, # 'ֲ' - 33: 3, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 3, # 'ַ' - 29: 3, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 0, # 'ּ' - 38: 2, # 'ׁ' - 45: 1, # 'ׂ' - 9: 2, # 'א' - 8: 2, # 'ב' - 20: 1, # 'ג' - 16: 2, # 'ד' - 3: 1, # 'ה' - 2: 2, # 'ו' - 24: 1, # 'ז' - 14: 1, # 'ח' - 22: 1, # 'ט' - 1: 2, # 'י' - 25: 2, # 'ך' - 15: 2, # 'כ' - 4: 2, # 'ל' - 11: 1, # 'ם' - 6: 2, # 'מ' - 23: 1, # 'ן' - 12: 2, # 'נ' - 19: 1, # 'ס' - 13: 2, # 'ע' - 26: 1, # 'ף' - 18: 1, # 'פ' - 27: 1, # 'ץ' - 21: 1, # 'צ' - 17: 1, # 'ק' - 7: 2, # 'ר' - 10: 2, # 'ש' - 5: 2, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 38: { # 'ׁ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 1, # 'ֹ' - 62: 1, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 2, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 1, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 1, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 45: { # 'ׂ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 1, # 'ֵ' - 36: 2, # 'ֶ' - 31: 1, # 'ַ' - 29: 2, # 'ָ' - 35: 1, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 0, # 'ב' - 20: 1, # 'ג' - 16: 0, # 'ד' - 3: 1, # 'ה' - 2: 2, # 'ו' - 24: 0, # 'ז' - 14: 1, # 'ח' - 22: 0, # 'ט' - 1: 1, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 1, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 1, # 'נ' - 19: 0, # 'ס' - 13: 1, # 'ע' - 26: 0, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 1, # 'ר' - 10: 0, # 'ש' - 5: 1, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 9: { # 'א' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 1, # '´' - 48: 1, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 2, # 'ֱ' - 41: 2, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 3, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 2, # 'ע' - 26: 3, # 'ף' - 18: 3, # 'פ' - 27: 1, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 8: { # 'ב' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 1, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 3, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 2, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 2, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 3, # 'ע' - 26: 1, # 'ף' - 18: 3, # 'פ' - 27: 2, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 1, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 20: { # 'ג' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 2, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 1, # 'ִ' - 37: 1, # 'ֵ' - 36: 1, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 1, # 'ֹ' - 62: 0, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 3, # 'ב' - 20: 2, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 2, # 'ח' - 22: 2, # 'ט' - 1: 3, # 'י' - 25: 1, # 'ך' - 15: 1, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 2, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 2, # 'פ' - 27: 1, # 'ץ' - 21: 1, # 'צ' - 17: 1, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 16: { # 'ד' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 1, # 'ז' - 14: 2, # 'ח' - 22: 2, # 'ט' - 1: 3, # 'י' - 25: 2, # 'ך' - 15: 2, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 2, # 'ן' - 12: 3, # 'נ' - 19: 2, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 3, # 'פ' - 27: 0, # 'ץ' - 21: 2, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 3: { # 'ה' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 1, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 0, # '´' - 48: 1, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 1, # 'ְ' - 59: 1, # 'ֱ' - 41: 2, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 3, # 'ַ' - 29: 2, # 'ָ' - 35: 1, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 1, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 3, # 'ע' - 26: 0, # 'ף' - 18: 3, # 'פ' - 27: 1, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 1, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 2, # '…' - }, - 2: { # 'ו' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 1, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 1, # '´' - 48: 1, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 1, # 'ֵ' - 36: 1, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 3, # 'ֹ' - 62: 0, # 'ֻ' - 28: 3, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 3, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 3, # 'ע' - 26: 3, # 'ף' - 18: 3, # 'פ' - 27: 3, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 1, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 2, # '…' - }, - 24: { # 'ז' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 1, # 'ֲ' - 33: 1, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 1, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 2, # 'ב' - 20: 2, # 'ג' - 16: 2, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 2, # 'ז' - 14: 2, # 'ח' - 22: 1, # 'ט' - 1: 3, # 'י' - 25: 1, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 2, # 'ם' - 6: 3, # 'מ' - 23: 2, # 'ן' - 12: 2, # 'נ' - 19: 1, # 'ס' - 13: 2, # 'ע' - 26: 1, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 2, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 1, # 'ש' - 5: 2, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 14: { # 'ח' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 1, # 'ֱ' - 41: 2, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 3, # 'ב' - 20: 2, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 2, # 'ח' - 22: 2, # 'ט' - 1: 3, # 'י' - 25: 1, # 'ך' - 15: 2, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 2, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 1, # 'ע' - 26: 2, # 'ף' - 18: 2, # 'פ' - 27: 2, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 22: { # 'ט' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 1, # 'ֵ' - 36: 1, # 'ֶ' - 31: 2, # 'ַ' - 29: 1, # 'ָ' - 35: 1, # 'ֹ' - 62: 1, # 'ֻ' - 28: 1, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 1, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 2, # 'ז' - 14: 3, # 'ח' - 22: 2, # 'ט' - 1: 3, # 'י' - 25: 1, # 'ך' - 15: 2, # 'כ' - 4: 3, # 'ל' - 11: 2, # 'ם' - 6: 2, # 'מ' - 23: 2, # 'ן' - 12: 3, # 'נ' - 19: 2, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 3, # 'פ' - 27: 1, # 'ץ' - 21: 2, # 'צ' - 17: 2, # 'ק' - 7: 3, # 'ר' - 10: 2, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 1: { # 'י' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 1, # '´' - 48: 1, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 1, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 3, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 3, # 'ע' - 26: 3, # 'ף' - 18: 3, # 'פ' - 27: 3, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 1, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 2, # '…' - }, - 25: { # 'ך' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 2, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 1, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 1, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 1, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 1, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 15: { # 'כ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 1, # 'ֹ' - 62: 1, # 'ֻ' - 28: 3, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 2, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 3, # 'ח' - 22: 2, # 'ט' - 1: 3, # 'י' - 25: 3, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 2, # 'ע' - 26: 3, # 'ף' - 18: 3, # 'פ' - 27: 1, # 'ץ' - 21: 2, # 'צ' - 17: 2, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 4: { # 'ל' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 3, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 3, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 2, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 3, # 'פ' - 27: 2, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 1, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 11: { # 'ם' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 1, # 'ב' - 20: 1, # 'ג' - 16: 0, # 'ד' - 3: 1, # 'ה' - 2: 1, # 'ו' - 24: 1, # 'ז' - 14: 1, # 'ח' - 22: 0, # 'ט' - 1: 1, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 1, # 'ל' - 11: 1, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 1, # 'נ' - 19: 0, # 'ס' - 13: 1, # 'ע' - 26: 0, # 'ף' - 18: 1, # 'פ' - 27: 1, # 'ץ' - 21: 1, # 'צ' - 17: 1, # 'ק' - 7: 1, # 'ר' - 10: 1, # 'ש' - 5: 1, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 2, # '…' - }, - 6: { # 'מ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 2, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 3, # 'ע' - 26: 0, # 'ף' - 18: 3, # 'פ' - 27: 2, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 23: { # 'ן' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 0, # '´' - 48: 1, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 1, # 'ב' - 20: 1, # 'ג' - 16: 1, # 'ד' - 3: 1, # 'ה' - 2: 1, # 'ו' - 24: 0, # 'ז' - 14: 1, # 'ח' - 22: 1, # 'ט' - 1: 1, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 1, # 'ל' - 11: 1, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 1, # 'נ' - 19: 1, # 'ס' - 13: 1, # 'ע' - 26: 1, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 1, # 'ק' - 7: 1, # 'ר' - 10: 1, # 'ש' - 5: 1, # 'ת' - 32: 1, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 2, # '…' - }, - 12: { # 'נ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 1, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 2, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 3, # 'פ' - 27: 2, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 19: { # 'ס' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 1, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 1, # 'ָ' - 35: 1, # 'ֹ' - 62: 2, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 1, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 2, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 2, # 'ם' - 6: 3, # 'מ' - 23: 2, # 'ן' - 12: 3, # 'נ' - 19: 2, # 'ס' - 13: 3, # 'ע' - 26: 3, # 'ף' - 18: 3, # 'פ' - 27: 0, # 'ץ' - 21: 2, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 1, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 13: { # 'ע' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 1, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 1, # 'ְ' - 59: 1, # 'ֱ' - 41: 2, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 1, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 2, # 'ך' - 15: 2, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 2, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 2, # 'ע' - 26: 1, # 'ף' - 18: 2, # 'פ' - 27: 2, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 26: { # 'ף' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 1, # 'ו' - 24: 0, # 'ז' - 14: 1, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 1, # 'ס' - 13: 0, # 'ע' - 26: 1, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 1, # 'ק' - 7: 1, # 'ר' - 10: 1, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 18: { # 'פ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 1, # 'ֵ' - 36: 2, # 'ֶ' - 31: 1, # 'ַ' - 29: 2, # 'ָ' - 35: 1, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 2, # 'ב' - 20: 3, # 'ג' - 16: 2, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 2, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 2, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 2, # 'ם' - 6: 2, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 2, # 'פ' - 27: 2, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 27: { # 'ץ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 1, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 1, # 'ר' - 10: 0, # 'ש' - 5: 1, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 21: { # 'צ' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 1, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 1, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 2, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 1, # 'ז' - 14: 3, # 'ח' - 22: 2, # 'ט' - 1: 3, # 'י' - 25: 1, # 'ך' - 15: 1, # 'כ' - 4: 3, # 'ל' - 11: 2, # 'ם' - 6: 3, # 'מ' - 23: 2, # 'ן' - 12: 3, # 'נ' - 19: 1, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 3, # 'פ' - 27: 2, # 'ץ' - 21: 2, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 0, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 17: { # 'ק' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 1, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 1, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 2, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 2, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 1, # 'ך' - 15: 1, # 'כ' - 4: 3, # 'ל' - 11: 2, # 'ם' - 6: 3, # 'מ' - 23: 2, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 3, # 'פ' - 27: 2, # 'ץ' - 21: 3, # 'צ' - 17: 2, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 7: { # 'ר' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 2, # '´' - 48: 1, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 1, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 2, # 'ֹ' - 62: 1, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 3, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 3, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 3, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 3, # 'פ' - 27: 3, # 'ץ' - 21: 3, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 2, # '…' - }, - 10: { # 'ש' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 1, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 1, # 'ִ' - 37: 1, # 'ֵ' - 36: 1, # 'ֶ' - 31: 1, # 'ַ' - 29: 1, # 'ָ' - 35: 1, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 3, # 'ׁ' - 45: 2, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 3, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 2, # 'ז' - 14: 3, # 'ח' - 22: 3, # 'ט' - 1: 3, # 'י' - 25: 3, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 2, # 'ן' - 12: 3, # 'נ' - 19: 2, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 3, # 'פ' - 27: 1, # 'ץ' - 21: 2, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 1, # '…' - }, - 5: { # 'ת' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 1, # '\xa0' - 55: 0, # '´' - 48: 1, # '¼' - 39: 1, # '½' - 57: 0, # '¾' - 30: 2, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 2, # 'ִ' - 37: 2, # 'ֵ' - 36: 2, # 'ֶ' - 31: 2, # 'ַ' - 29: 2, # 'ָ' - 35: 1, # 'ֹ' - 62: 1, # 'ֻ' - 28: 2, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 3, # 'א' - 8: 3, # 'ב' - 20: 3, # 'ג' - 16: 2, # 'ד' - 3: 3, # 'ה' - 2: 3, # 'ו' - 24: 2, # 'ז' - 14: 3, # 'ח' - 22: 2, # 'ט' - 1: 3, # 'י' - 25: 2, # 'ך' - 15: 3, # 'כ' - 4: 3, # 'ל' - 11: 3, # 'ם' - 6: 3, # 'מ' - 23: 3, # 'ן' - 12: 3, # 'נ' - 19: 2, # 'ס' - 13: 3, # 'ע' - 26: 2, # 'ף' - 18: 3, # 'פ' - 27: 1, # 'ץ' - 21: 2, # 'צ' - 17: 3, # 'ק' - 7: 3, # 'ר' - 10: 3, # 'ש' - 5: 3, # 'ת' - 32: 1, # '–' - 52: 1, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 2, # '…' - }, - 32: { # '–' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 1, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 1, # 'ב' - 20: 1, # 'ג' - 16: 1, # 'ד' - 3: 1, # 'ה' - 2: 1, # 'ו' - 24: 0, # 'ז' - 14: 1, # 'ח' - 22: 0, # 'ט' - 1: 1, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 1, # 'ס' - 13: 1, # 'ע' - 26: 0, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 1, # 'צ' - 17: 0, # 'ק' - 7: 1, # 'ר' - 10: 1, # 'ש' - 5: 1, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 52: { # '’' - 50: 1, # 'a' - 60: 0, # 'c' - 61: 1, # 'd' - 42: 1, # 'e' - 53: 1, # 'i' - 56: 1, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 1, # 'r' - 43: 2, # 's' - 44: 2, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 1, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 1, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 47: { # '“' - 50: 1, # 'a' - 60: 1, # 'c' - 61: 1, # 'd' - 42: 1, # 'e' - 53: 1, # 'i' - 56: 1, # 'l' - 54: 1, # 'n' - 49: 1, # 'o' - 51: 1, # 'r' - 43: 1, # 's' - 44: 1, # 't' - 63: 1, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 2, # 'א' - 8: 1, # 'ב' - 20: 1, # 'ג' - 16: 1, # 'ד' - 3: 1, # 'ה' - 2: 1, # 'ו' - 24: 1, # 'ז' - 14: 1, # 'ח' - 22: 1, # 'ט' - 1: 1, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 1, # 'נ' - 19: 1, # 'ס' - 13: 1, # 'ע' - 26: 0, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 1, # 'צ' - 17: 1, # 'ק' - 7: 1, # 'ר' - 10: 1, # 'ש' - 5: 1, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 46: { # '”' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 1, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 1, # 'ב' - 20: 1, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 1, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 1, # 'צ' - 17: 0, # 'ק' - 7: 1, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 0, # '†' - 40: 0, # '…' - }, - 58: { # '†' - 50: 0, # 'a' - 60: 0, # 'c' - 61: 0, # 'd' - 42: 0, # 'e' - 53: 0, # 'i' - 56: 0, # 'l' - 54: 0, # 'n' - 49: 0, # 'o' - 51: 0, # 'r' - 43: 0, # 's' - 44: 0, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 0, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 0, # 'ה' - 2: 0, # 'ו' - 24: 0, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 0, # 'י' - 25: 0, # 'ך' - 15: 0, # 'כ' - 4: 0, # 'ל' - 11: 0, # 'ם' - 6: 0, # 'מ' - 23: 0, # 'ן' - 12: 0, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 0, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 0, # 'ר' - 10: 0, # 'ש' - 5: 0, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 0, # '”' - 58: 2, # '†' - 40: 0, # '…' - }, - 40: { # '…' - 50: 1, # 'a' - 60: 1, # 'c' - 61: 1, # 'd' - 42: 1, # 'e' - 53: 1, # 'i' - 56: 0, # 'l' - 54: 1, # 'n' - 49: 0, # 'o' - 51: 1, # 'r' - 43: 1, # 's' - 44: 1, # 't' - 63: 0, # 'u' - 34: 0, # '\xa0' - 55: 0, # '´' - 48: 0, # '¼' - 39: 0, # '½' - 57: 0, # '¾' - 30: 0, # 'ְ' - 59: 0, # 'ֱ' - 41: 0, # 'ֲ' - 33: 0, # 'ִ' - 37: 0, # 'ֵ' - 36: 0, # 'ֶ' - 31: 0, # 'ַ' - 29: 0, # 'ָ' - 35: 0, # 'ֹ' - 62: 0, # 'ֻ' - 28: 0, # 'ּ' - 38: 0, # 'ׁ' - 45: 0, # 'ׂ' - 9: 1, # 'א' - 8: 0, # 'ב' - 20: 0, # 'ג' - 16: 0, # 'ד' - 3: 1, # 'ה' - 2: 1, # 'ו' - 24: 1, # 'ז' - 14: 0, # 'ח' - 22: 0, # 'ט' - 1: 1, # 'י' - 25: 0, # 'ך' - 15: 1, # 'כ' - 4: 1, # 'ל' - 11: 0, # 'ם' - 6: 1, # 'מ' - 23: 0, # 'ן' - 12: 1, # 'נ' - 19: 0, # 'ס' - 13: 0, # 'ע' - 26: 0, # 'ף' - 18: 1, # 'פ' - 27: 0, # 'ץ' - 21: 0, # 'צ' - 17: 0, # 'ק' - 7: 1, # 'ר' - 10: 1, # 'ש' - 5: 1, # 'ת' - 32: 0, # '–' - 52: 0, # '’' - 47: 0, # '“' - 46: 1, # '”' - 58: 0, # '†' - 40: 2, # '…' - }, -} - -# 255: Undefined characters that did not exist in training text -# 254: Carriage/Return -# 253: symbol (punctuation) that does not belong to word -# 252: 0 - 9 -# 251: Control characters - -# Character Mapping Table(s): -WINDOWS_1255_HEBREW_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 69, # 'A' - 66: 91, # 'B' - 67: 79, # 'C' - 68: 80, # 'D' - 69: 92, # 'E' - 70: 89, # 'F' - 71: 97, # 'G' - 72: 90, # 'H' - 73: 68, # 'I' - 74: 111, # 'J' - 75: 112, # 'K' - 76: 82, # 'L' - 77: 73, # 'M' - 78: 95, # 'N' - 79: 85, # 'O' - 80: 78, # 'P' - 81: 121, # 'Q' - 82: 86, # 'R' - 83: 71, # 'S' - 84: 67, # 'T' - 85: 102, # 'U' - 86: 107, # 'V' - 87: 84, # 'W' - 88: 114, # 'X' - 89: 103, # 'Y' - 90: 115, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 50, # 'a' - 98: 74, # 'b' - 99: 60, # 'c' - 100: 61, # 'd' - 101: 42, # 'e' - 102: 76, # 'f' - 103: 70, # 'g' - 104: 64, # 'h' - 105: 53, # 'i' - 106: 105, # 'j' - 107: 93, # 'k' - 108: 56, # 'l' - 109: 65, # 'm' - 110: 54, # 'n' - 111: 49, # 'o' - 112: 66, # 'p' - 113: 110, # 'q' - 114: 51, # 'r' - 115: 43, # 's' - 116: 44, # 't' - 117: 63, # 'u' - 118: 81, # 'v' - 119: 77, # 'w' - 120: 98, # 'x' - 121: 75, # 'y' - 122: 108, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 124, # '€' - 129: 202, # None - 130: 203, # '‚' - 131: 204, # 'ƒ' - 132: 205, # '„' - 133: 40, # '…' - 134: 58, # '†' - 135: 206, # '‡' - 136: 207, # 'ˆ' - 137: 208, # '‰' - 138: 209, # None - 139: 210, # '‹' - 140: 211, # None - 141: 212, # None - 142: 213, # None - 143: 214, # None - 144: 215, # None - 145: 83, # '‘' - 146: 52, # '’' - 147: 47, # '“' - 148: 46, # '”' - 149: 72, # '•' - 150: 32, # '–' - 151: 94, # '—' - 152: 216, # '˜' - 153: 113, # '™' - 154: 217, # None - 155: 109, # '›' - 156: 218, # None - 157: 219, # None - 158: 220, # None - 159: 221, # None - 160: 34, # '\xa0' - 161: 116, # '¡' - 162: 222, # '¢' - 163: 118, # '£' - 164: 100, # '₪' - 165: 223, # '¥' - 166: 224, # '¦' - 167: 117, # '§' - 168: 119, # '¨' - 169: 104, # '©' - 170: 125, # '×' - 171: 225, # '«' - 172: 226, # '¬' - 173: 87, # '\xad' - 174: 99, # '®' - 175: 227, # '¯' - 176: 106, # '°' - 177: 122, # '±' - 178: 123, # '²' - 179: 228, # '³' - 180: 55, # '´' - 181: 229, # 'µ' - 182: 230, # '¶' - 183: 101, # '·' - 184: 231, # '¸' - 185: 232, # '¹' - 186: 120, # '÷' - 187: 233, # '»' - 188: 48, # '¼' - 189: 39, # '½' - 190: 57, # '¾' - 191: 234, # '¿' - 192: 30, # 'ְ' - 193: 59, # 'ֱ' - 194: 41, # 'ֲ' - 195: 88, # 'ֳ' - 196: 33, # 'ִ' - 197: 37, # 'ֵ' - 198: 36, # 'ֶ' - 199: 31, # 'ַ' - 200: 29, # 'ָ' - 201: 35, # 'ֹ' - 202: 235, # None - 203: 62, # 'ֻ' - 204: 28, # 'ּ' - 205: 236, # 'ֽ' - 206: 126, # '־' - 207: 237, # 'ֿ' - 208: 238, # '׀' - 209: 38, # 'ׁ' - 210: 45, # 'ׂ' - 211: 239, # '׃' - 212: 240, # 'װ' - 213: 241, # 'ױ' - 214: 242, # 'ײ' - 215: 243, # '׳' - 216: 127, # '״' - 217: 244, # None - 218: 245, # None - 219: 246, # None - 220: 247, # None - 221: 248, # None - 222: 249, # None - 223: 250, # None - 224: 9, # 'א' - 225: 8, # 'ב' - 226: 20, # 'ג' - 227: 16, # 'ד' - 228: 3, # 'ה' - 229: 2, # 'ו' - 230: 24, # 'ז' - 231: 14, # 'ח' - 232: 22, # 'ט' - 233: 1, # 'י' - 234: 25, # 'ך' - 235: 15, # 'כ' - 236: 4, # 'ל' - 237: 11, # 'ם' - 238: 6, # 'מ' - 239: 23, # 'ן' - 240: 12, # 'נ' - 241: 19, # 'ס' - 242: 13, # 'ע' - 243: 26, # 'ף' - 244: 18, # 'פ' - 245: 27, # 'ץ' - 246: 21, # 'צ' - 247: 17, # 'ק' - 248: 7, # 'ר' - 249: 10, # 'ש' - 250: 5, # 'ת' - 251: 251, # None - 252: 252, # None - 253: 128, # '\u200e' - 254: 96, # '\u200f' - 255: 253, # None -} - -WINDOWS_1255_HEBREW_MODEL = SingleByteCharSetModel( - charset_name="windows-1255", - language="Hebrew", - char_to_order_map=WINDOWS_1255_HEBREW_CHAR_TO_ORDER, - language_model=HEBREW_LANG_MODEL, - typical_positive_ratio=0.984004, - keep_ascii_letters=False, - alphabet="אבגדהוזחטיךכלםמןנסעףפץצקרשתװױײ", -) diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py b/myenv/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py deleted file mode 100644 index 09a0d32..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py +++ /dev/null @@ -1,4649 +0,0 @@ -from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - -# 3: Positive -# 2: Likely -# 1: Unlikely -# 0: Negative - -HUNGARIAN_LANG_MODEL = { - 28: { # 'A' - 28: 0, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 2, # 'D' - 32: 1, # 'E' - 50: 1, # 'F' - 49: 2, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 2, # 'K' - 41: 2, # 'L' - 34: 1, # 'M' - 35: 2, # 'N' - 47: 1, # 'O' - 46: 2, # 'P' - 43: 2, # 'R' - 33: 2, # 'S' - 37: 2, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 2, # 'Z' - 2: 0, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 2, # 'd' - 1: 1, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 1, # 'h' - 9: 1, # 'i' - 22: 1, # 'j' - 7: 2, # 'k' - 6: 2, # 'l' - 13: 2, # 'm' - 4: 2, # 'n' - 8: 0, # 'o' - 23: 2, # 'p' - 10: 2, # 'r' - 5: 1, # 's' - 3: 1, # 't' - 21: 1, # 'u' - 19: 1, # 'v' - 62: 1, # 'x' - 16: 0, # 'y' - 11: 3, # 'z' - 51: 1, # 'Á' - 44: 0, # 'É' - 61: 1, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 40: { # 'B' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 0, # 'M' - 35: 1, # 'N' - 47: 2, # 'O' - 46: 0, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 3, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 2, # 'i' - 22: 1, # 'j' - 7: 0, # 'k' - 6: 1, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 2, # 'o' - 23: 1, # 'p' - 10: 2, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 3, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 0, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 2, # 'á' - 15: 2, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 54: { # 'C' - 28: 1, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 1, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 0, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 2, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 0, # 'V' - 55: 1, # 'Y' - 52: 1, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 1, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 1, # 'h' - 9: 1, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 1, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 2, # 'o' - 23: 0, # 'p' - 10: 1, # 'r' - 5: 3, # 's' - 3: 0, # 't' - 21: 1, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 1, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 1, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 45: { # 'D' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 0, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 0, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 2, # 'O' - 46: 0, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 1, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 3, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 1, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 0, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 1, # 'o' - 23: 0, # 'p' - 10: 2, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 2, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 1, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 1, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 1, # 'ő' - 56: 0, # 'ű' - }, - 32: { # 'E' - 28: 1, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 1, # 'E' - 50: 1, # 'F' - 49: 2, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 2, # 'K' - 41: 2, # 'L' - 34: 2, # 'M' - 35: 2, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 2, # 'R' - 33: 2, # 'S' - 37: 2, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 1, # 'Z' - 2: 1, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 2, # 'd' - 1: 1, # 'e' - 27: 1, # 'f' - 12: 3, # 'g' - 20: 1, # 'h' - 9: 1, # 'i' - 22: 1, # 'j' - 7: 1, # 'k' - 6: 2, # 'l' - 13: 2, # 'm' - 4: 2, # 'n' - 8: 0, # 'o' - 23: 1, # 'p' - 10: 2, # 'r' - 5: 2, # 's' - 3: 1, # 't' - 21: 2, # 'u' - 19: 1, # 'v' - 62: 1, # 'x' - 16: 0, # 'y' - 11: 3, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 0, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 0, # 'Ú' - 63: 1, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 1, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 50: { # 'F' - 28: 1, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 1, # 'E' - 50: 1, # 'F' - 49: 0, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 1, # 'O' - 46: 0, # 'P' - 43: 1, # 'R' - 33: 0, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 0, # 'V' - 55: 1, # 'Y' - 52: 0, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 2, # 'e' - 27: 1, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 2, # 'i' - 22: 1, # 'j' - 7: 0, # 'k' - 6: 1, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 2, # 'o' - 23: 0, # 'p' - 10: 2, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 1, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 0, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 0, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 0, # 'Ú' - 63: 1, # 'Ü' - 14: 1, # 'á' - 15: 1, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 2, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 49: { # 'G' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 2, # 'Y' - 52: 1, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 2, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 1, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 1, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 2, # 'o' - 23: 0, # 'p' - 10: 2, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 1, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 2, # 'y' - 11: 0, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 1, # 'á' - 15: 1, # 'é' - 30: 0, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 1, # 'ő' - 56: 0, # 'ű' - }, - 38: { # 'H' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 0, # 'D' - 32: 1, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 1, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 1, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 1, # 'O' - 46: 0, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 0, # 'V' - 55: 1, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 2, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 2, # 'i' - 22: 1, # 'j' - 7: 0, # 'k' - 6: 1, # 'l' - 13: 1, # 'm' - 4: 0, # 'n' - 8: 3, # 'o' - 23: 0, # 'p' - 10: 1, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 2, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 0, # 'z' - 51: 2, # 'Á' - 44: 2, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 2, # 'á' - 15: 1, # 'é' - 30: 2, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 39: { # 'I' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 1, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 2, # 'K' - 41: 2, # 'L' - 34: 1, # 'M' - 35: 2, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 2, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 2, # 'Z' - 2: 0, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 2, # 'd' - 1: 0, # 'e' - 27: 1, # 'f' - 12: 2, # 'g' - 20: 1, # 'h' - 9: 0, # 'i' - 22: 1, # 'j' - 7: 1, # 'k' - 6: 2, # 'l' - 13: 2, # 'm' - 4: 1, # 'n' - 8: 0, # 'o' - 23: 1, # 'p' - 10: 2, # 'r' - 5: 2, # 's' - 3: 2, # 't' - 21: 0, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 1, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 0, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 53: { # 'J' - 28: 2, # 'A' - 40: 0, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 1, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 1, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 2, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 1, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 0, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 1, # 'o' - 23: 0, # 'p' - 10: 0, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 2, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 0, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 0, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 2, # 'á' - 15: 1, # 'é' - 30: 0, # 'í' - 25: 2, # 'ó' - 24: 2, # 'ö' - 31: 1, # 'ú' - 29: 0, # 'ü' - 42: 1, # 'ő' - 56: 0, # 'ű' - }, - 36: { # 'K' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 0, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 2, # 'O' - 46: 0, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 0, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 2, # 'e' - 27: 1, # 'f' - 12: 0, # 'g' - 20: 1, # 'h' - 9: 3, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 1, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 8: 2, # 'o' - 23: 0, # 'p' - 10: 2, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 1, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 0, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 2, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 2, # 'á' - 15: 2, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 2, # 'ö' - 31: 1, # 'ú' - 29: 2, # 'ü' - 42: 1, # 'ő' - 56: 0, # 'ű' - }, - 41: { # 'L' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 2, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 2, # 'O' - 46: 0, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 2, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 1, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 3, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 2, # 'i' - 22: 1, # 'j' - 7: 0, # 'k' - 6: 1, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 2, # 'o' - 23: 0, # 'p' - 10: 0, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 2, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 0, # 'z' - 51: 2, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 2, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 0, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 34: { # 'M' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 0, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 1, # 'Z' - 2: 3, # 'a' - 18: 0, # 'b' - 26: 1, # 'c' - 17: 0, # 'd' - 1: 3, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 3, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 0, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 8: 3, # 'o' - 23: 0, # 'p' - 10: 1, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 2, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 0, # 'z' - 51: 2, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 2, # 'á' - 15: 2, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 1, # 'ű' - }, - 35: { # 'N' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 2, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 2, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 2, # 'Y' - 52: 1, # 'Z' - 2: 3, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 3, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 2, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 0, # 'l' - 13: 0, # 'm' - 4: 1, # 'n' - 8: 2, # 'o' - 23: 0, # 'p' - 10: 0, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 1, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 2, # 'y' - 11: 0, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 1, # 'á' - 15: 2, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 1, # 'ő' - 56: 0, # 'ű' - }, - 47: { # 'O' - 28: 1, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 1, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 2, # 'K' - 41: 2, # 'L' - 34: 2, # 'M' - 35: 2, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 2, # 'R' - 33: 2, # 'S' - 37: 2, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 1, # 'Z' - 2: 0, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 1, # 'd' - 1: 1, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 1, # 'h' - 9: 1, # 'i' - 22: 1, # 'j' - 7: 2, # 'k' - 6: 2, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 8: 1, # 'o' - 23: 1, # 'p' - 10: 2, # 'r' - 5: 1, # 's' - 3: 2, # 't' - 21: 1, # 'u' - 19: 0, # 'v' - 62: 1, # 'x' - 16: 0, # 'y' - 11: 1, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 0, # 'Í' - 58: 1, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 46: { # 'P' - 28: 1, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 1, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 0, # 'M' - 35: 1, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 2, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 1, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 2, # 'e' - 27: 1, # 'f' - 12: 0, # 'g' - 20: 1, # 'h' - 9: 2, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 1, # 'l' - 13: 0, # 'm' - 4: 1, # 'n' - 8: 2, # 'o' - 23: 0, # 'p' - 10: 2, # 'r' - 5: 1, # 's' - 3: 0, # 't' - 21: 1, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 0, # 'z' - 51: 2, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 0, # 'Ú' - 63: 1, # 'Ü' - 14: 3, # 'á' - 15: 2, # 'é' - 30: 0, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 0, # 'ú' - 29: 1, # 'ü' - 42: 1, # 'ő' - 56: 0, # 'ű' - }, - 43: { # 'R' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 2, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 2, # 'S' - 37: 2, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 1, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 2, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 1, # 'h' - 9: 2, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 0, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 2, # 'o' - 23: 0, # 'p' - 10: 0, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 1, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 0, # 'z' - 51: 2, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 2, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 2, # 'á' - 15: 2, # 'é' - 30: 1, # 'í' - 25: 2, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 33: { # 'S' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 2, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 2, # 'S' - 37: 2, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 3, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 1, # 'c' - 17: 0, # 'd' - 1: 2, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 1, # 'h' - 9: 2, # 'i' - 22: 0, # 'j' - 7: 1, # 'k' - 6: 1, # 'l' - 13: 1, # 'm' - 4: 0, # 'n' - 8: 2, # 'o' - 23: 1, # 'p' - 10: 0, # 'r' - 5: 0, # 's' - 3: 1, # 't' - 21: 1, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 3, # 'z' - 51: 2, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 2, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 37: { # 'T' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 2, # 'O' - 46: 1, # 'P' - 43: 2, # 'R' - 33: 1, # 'S' - 37: 2, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 1, # 'Z' - 2: 2, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 2, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 1, # 'h' - 9: 2, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 0, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 2, # 'o' - 23: 0, # 'p' - 10: 1, # 'r' - 5: 1, # 's' - 3: 0, # 't' - 21: 2, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 1, # 'z' - 51: 2, # 'Á' - 44: 2, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 2, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 2, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 57: { # 'U' - 28: 1, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 1, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 2, # 'S' - 37: 1, # 'T' - 57: 0, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 1, # 'Z' - 2: 0, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 1, # 'd' - 1: 1, # 'e' - 27: 0, # 'f' - 12: 2, # 'g' - 20: 0, # 'h' - 9: 0, # 'i' - 22: 1, # 'j' - 7: 1, # 'k' - 6: 1, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 8: 0, # 'o' - 23: 1, # 'p' - 10: 1, # 'r' - 5: 1, # 's' - 3: 1, # 't' - 21: 0, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 1, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 1, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 48: { # 'V' - 28: 2, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 0, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 2, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 2, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 1, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 2, # 'o' - 23: 0, # 'p' - 10: 0, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 1, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 0, # 'z' - 51: 2, # 'Á' - 44: 2, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 0, # 'Ú' - 63: 1, # 'Ü' - 14: 2, # 'á' - 15: 2, # 'é' - 30: 1, # 'í' - 25: 0, # 'ó' - 24: 1, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 55: { # 'Y' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 1, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 2, # 'Z' - 2: 1, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 1, # 'd' - 1: 1, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 0, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 0, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 8: 1, # 'o' - 23: 1, # 'p' - 10: 0, # 'r' - 5: 0, # 's' - 3: 0, # 't' - 21: 0, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 0, # 'z' - 51: 1, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 52: { # 'Z' - 28: 2, # 'A' - 40: 1, # 'B' - 54: 0, # 'C' - 45: 1, # 'D' - 32: 2, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 2, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 2, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 2, # 'S' - 37: 1, # 'T' - 57: 1, # 'U' - 48: 1, # 'V' - 55: 1, # 'Y' - 52: 1, # 'Z' - 2: 1, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 1, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 1, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 0, # 'l' - 13: 0, # 'm' - 4: 1, # 'n' - 8: 1, # 'o' - 23: 0, # 'p' - 10: 1, # 'r' - 5: 2, # 's' - 3: 0, # 't' - 21: 1, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 0, # 'z' - 51: 2, # 'Á' - 44: 1, # 'É' - 61: 1, # 'Í' - 58: 1, # 'Ó' - 59: 1, # 'Ö' - 60: 1, # 'Ú' - 63: 1, # 'Ü' - 14: 1, # 'á' - 15: 1, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 2: { # 'a' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 1, # 'a' - 18: 3, # 'b' - 26: 3, # 'c' - 17: 3, # 'd' - 1: 2, # 'e' - 27: 2, # 'f' - 12: 3, # 'g' - 20: 3, # 'h' - 9: 3, # 'i' - 22: 3, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 2, # 'o' - 23: 3, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 3, # 'v' - 62: 1, # 'x' - 16: 2, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 1, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 18: { # 'b' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 3, # 'b' - 26: 1, # 'c' - 17: 1, # 'd' - 1: 3, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 1, # 'h' - 9: 3, # 'i' - 22: 2, # 'j' - 7: 2, # 'k' - 6: 2, # 'l' - 13: 1, # 'm' - 4: 2, # 'n' - 8: 3, # 'o' - 23: 1, # 'p' - 10: 3, # 'r' - 5: 2, # 's' - 3: 1, # 't' - 21: 3, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 1, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 2, # 'í' - 25: 3, # 'ó' - 24: 2, # 'ö' - 31: 2, # 'ú' - 29: 2, # 'ü' - 42: 2, # 'ő' - 56: 1, # 'ű' - }, - 26: { # 'c' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 1, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 1, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 2, # 'a' - 18: 1, # 'b' - 26: 2, # 'c' - 17: 1, # 'd' - 1: 3, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 3, # 'h' - 9: 3, # 'i' - 22: 1, # 'j' - 7: 2, # 'k' - 6: 1, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 8: 3, # 'o' - 23: 1, # 'p' - 10: 2, # 'r' - 5: 3, # 's' - 3: 2, # 't' - 21: 2, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 2, # 'á' - 15: 2, # 'é' - 30: 2, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 17: { # 'd' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 2, # 'b' - 26: 1, # 'c' - 17: 2, # 'd' - 1: 3, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 2, # 'h' - 9: 3, # 'i' - 22: 3, # 'j' - 7: 2, # 'k' - 6: 1, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 8: 3, # 'o' - 23: 1, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 3, # 'v' - 62: 0, # 'x' - 16: 2, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 3, # 'í' - 25: 3, # 'ó' - 24: 3, # 'ö' - 31: 2, # 'ú' - 29: 2, # 'ü' - 42: 2, # 'ő' - 56: 1, # 'ű' - }, - 1: { # 'e' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 2, # 'a' - 18: 3, # 'b' - 26: 3, # 'c' - 17: 3, # 'd' - 1: 2, # 'e' - 27: 3, # 'f' - 12: 3, # 'g' - 20: 3, # 'h' - 9: 3, # 'i' - 22: 3, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 2, # 'o' - 23: 3, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 2, # 'u' - 19: 3, # 'v' - 62: 2, # 'x' - 16: 2, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 27: { # 'f' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 1, # 'd' - 1: 3, # 'e' - 27: 2, # 'f' - 12: 1, # 'g' - 20: 1, # 'h' - 9: 3, # 'i' - 22: 2, # 'j' - 7: 1, # 'k' - 6: 1, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 8: 3, # 'o' - 23: 0, # 'p' - 10: 3, # 'r' - 5: 1, # 's' - 3: 1, # 't' - 21: 2, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 0, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 3, # 'ö' - 31: 1, # 'ú' - 29: 2, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 12: { # 'g' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 3, # 'b' - 26: 2, # 'c' - 17: 2, # 'd' - 1: 3, # 'e' - 27: 2, # 'f' - 12: 3, # 'g' - 20: 3, # 'h' - 9: 3, # 'i' - 22: 3, # 'j' - 7: 2, # 'k' - 6: 3, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 8: 3, # 'o' - 23: 1, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 3, # 'v' - 62: 0, # 'x' - 16: 3, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 2, # 'í' - 25: 3, # 'ó' - 24: 2, # 'ö' - 31: 2, # 'ú' - 29: 2, # 'ü' - 42: 2, # 'ő' - 56: 1, # 'ű' - }, - 20: { # 'h' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 0, # 'd' - 1: 3, # 'e' - 27: 0, # 'f' - 12: 1, # 'g' - 20: 2, # 'h' - 9: 3, # 'i' - 22: 1, # 'j' - 7: 1, # 'k' - 6: 1, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 8: 3, # 'o' - 23: 0, # 'p' - 10: 1, # 'r' - 5: 2, # 's' - 3: 1, # 't' - 21: 3, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 2, # 'y' - 11: 0, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 3, # 'í' - 25: 2, # 'ó' - 24: 2, # 'ö' - 31: 2, # 'ú' - 29: 1, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 9: { # 'i' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 3, # 'b' - 26: 3, # 'c' - 17: 3, # 'd' - 1: 3, # 'e' - 27: 3, # 'f' - 12: 3, # 'g' - 20: 3, # 'h' - 9: 2, # 'i' - 22: 2, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 2, # 'o' - 23: 2, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 3, # 'v' - 62: 1, # 'x' - 16: 1, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 2, # 'é' - 30: 1, # 'í' - 25: 3, # 'ó' - 24: 1, # 'ö' - 31: 2, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 1, # 'ű' - }, - 22: { # 'j' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 2, # 'b' - 26: 1, # 'c' - 17: 3, # 'd' - 1: 3, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 2, # 'h' - 9: 1, # 'i' - 22: 2, # 'j' - 7: 2, # 'k' - 6: 2, # 'l' - 13: 1, # 'm' - 4: 2, # 'n' - 8: 3, # 'o' - 23: 1, # 'p' - 10: 2, # 'r' - 5: 2, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 1, # 'í' - 25: 3, # 'ó' - 24: 3, # 'ö' - 31: 3, # 'ú' - 29: 2, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 7: { # 'k' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 3, # 'b' - 26: 2, # 'c' - 17: 1, # 'd' - 1: 3, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 2, # 'h' - 9: 3, # 'i' - 22: 2, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 1, # 'm' - 4: 3, # 'n' - 8: 3, # 'o' - 23: 1, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 2, # 'v' - 62: 0, # 'x' - 16: 2, # 'y' - 11: 1, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 3, # 'í' - 25: 2, # 'ó' - 24: 3, # 'ö' - 31: 1, # 'ú' - 29: 3, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 6: { # 'l' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 1, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 1, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 2, # 'b' - 26: 3, # 'c' - 17: 3, # 'd' - 1: 3, # 'e' - 27: 3, # 'f' - 12: 3, # 'g' - 20: 3, # 'h' - 9: 3, # 'i' - 22: 3, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 3, # 'o' - 23: 2, # 'p' - 10: 2, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 3, # 'v' - 62: 0, # 'x' - 16: 3, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 3, # 'í' - 25: 3, # 'ó' - 24: 3, # 'ö' - 31: 2, # 'ú' - 29: 2, # 'ü' - 42: 3, # 'ő' - 56: 1, # 'ű' - }, - 13: { # 'm' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 3, # 'b' - 26: 2, # 'c' - 17: 1, # 'd' - 1: 3, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 2, # 'h' - 9: 3, # 'i' - 22: 2, # 'j' - 7: 1, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 2, # 'n' - 8: 3, # 'o' - 23: 3, # 'p' - 10: 2, # 'r' - 5: 2, # 's' - 3: 2, # 't' - 21: 3, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 2, # 'í' - 25: 2, # 'ó' - 24: 2, # 'ö' - 31: 2, # 'ú' - 29: 2, # 'ü' - 42: 1, # 'ő' - 56: 2, # 'ű' - }, - 4: { # 'n' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 3, # 'b' - 26: 3, # 'c' - 17: 3, # 'd' - 1: 3, # 'e' - 27: 2, # 'f' - 12: 3, # 'g' - 20: 3, # 'h' - 9: 3, # 'i' - 22: 2, # 'j' - 7: 3, # 'k' - 6: 2, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 8: 3, # 'o' - 23: 2, # 'p' - 10: 2, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 2, # 'v' - 62: 1, # 'x' - 16: 3, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 2, # 'í' - 25: 2, # 'ó' - 24: 3, # 'ö' - 31: 2, # 'ú' - 29: 3, # 'ü' - 42: 2, # 'ő' - 56: 1, # 'ű' - }, - 8: { # 'o' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 1, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 2, # 'a' - 18: 3, # 'b' - 26: 3, # 'c' - 17: 3, # 'd' - 1: 2, # 'e' - 27: 2, # 'f' - 12: 3, # 'g' - 20: 3, # 'h' - 9: 2, # 'i' - 22: 2, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 1, # 'o' - 23: 3, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 2, # 'u' - 19: 3, # 'v' - 62: 1, # 'x' - 16: 1, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 1, # 'á' - 15: 2, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 23: { # 'p' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 1, # 'b' - 26: 2, # 'c' - 17: 1, # 'd' - 1: 3, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 2, # 'h' - 9: 3, # 'i' - 22: 2, # 'j' - 7: 2, # 'k' - 6: 3, # 'l' - 13: 1, # 'm' - 4: 2, # 'n' - 8: 3, # 'o' - 23: 3, # 'p' - 10: 3, # 'r' - 5: 2, # 's' - 3: 2, # 't' - 21: 3, # 'u' - 19: 2, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 2, # 'í' - 25: 2, # 'ó' - 24: 2, # 'ö' - 31: 1, # 'ú' - 29: 2, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 10: { # 'r' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 3, # 'b' - 26: 3, # 'c' - 17: 3, # 'd' - 1: 3, # 'e' - 27: 2, # 'f' - 12: 3, # 'g' - 20: 2, # 'h' - 9: 3, # 'i' - 22: 3, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 3, # 'o' - 23: 2, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 3, # 'v' - 62: 1, # 'x' - 16: 2, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 2, # 'í' - 25: 3, # 'ó' - 24: 3, # 'ö' - 31: 3, # 'ú' - 29: 3, # 'ü' - 42: 2, # 'ő' - 56: 2, # 'ű' - }, - 5: { # 's' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 3, # 'b' - 26: 2, # 'c' - 17: 2, # 'd' - 1: 3, # 'e' - 27: 2, # 'f' - 12: 2, # 'g' - 20: 2, # 'h' - 9: 3, # 'i' - 22: 1, # 'j' - 7: 3, # 'k' - 6: 2, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 3, # 'o' - 23: 2, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 2, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 3, # 'í' - 25: 3, # 'ó' - 24: 3, # 'ö' - 31: 3, # 'ú' - 29: 3, # 'ü' - 42: 2, # 'ő' - 56: 1, # 'ű' - }, - 3: { # 't' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 3, # 'b' - 26: 2, # 'c' - 17: 1, # 'd' - 1: 3, # 'e' - 27: 2, # 'f' - 12: 1, # 'g' - 20: 3, # 'h' - 9: 3, # 'i' - 22: 3, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 8: 3, # 'o' - 23: 1, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 3, # 'v' - 62: 0, # 'x' - 16: 3, # 'y' - 11: 1, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 2, # 'í' - 25: 3, # 'ó' - 24: 3, # 'ö' - 31: 3, # 'ú' - 29: 3, # 'ü' - 42: 3, # 'ő' - 56: 2, # 'ű' - }, - 21: { # 'u' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 1, # 'a' - 18: 2, # 'b' - 26: 2, # 'c' - 17: 3, # 'd' - 1: 2, # 'e' - 27: 1, # 'f' - 12: 3, # 'g' - 20: 2, # 'h' - 9: 2, # 'i' - 22: 2, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 1, # 'o' - 23: 2, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 1, # 'u' - 19: 3, # 'v' - 62: 1, # 'x' - 16: 1, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 2, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 0, # 'ö' - 31: 1, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 19: { # 'v' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 2, # 'b' - 26: 1, # 'c' - 17: 1, # 'd' - 1: 3, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 1, # 'h' - 9: 3, # 'i' - 22: 1, # 'j' - 7: 1, # 'k' - 6: 1, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 8: 3, # 'o' - 23: 1, # 'p' - 10: 1, # 'r' - 5: 2, # 's' - 3: 2, # 't' - 21: 2, # 'u' - 19: 2, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 1, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 2, # 'í' - 25: 2, # 'ó' - 24: 2, # 'ö' - 31: 1, # 'ú' - 29: 2, # 'ü' - 42: 1, # 'ő' - 56: 1, # 'ű' - }, - 62: { # 'x' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 1, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 0, # 'd' - 1: 1, # 'e' - 27: 1, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 1, # 'i' - 22: 0, # 'j' - 7: 1, # 'k' - 6: 1, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 8: 1, # 'o' - 23: 1, # 'p' - 10: 1, # 'r' - 5: 1, # 's' - 3: 1, # 't' - 21: 1, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 0, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 1, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 1, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 16: { # 'y' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 2, # 'b' - 26: 1, # 'c' - 17: 1, # 'd' - 1: 3, # 'e' - 27: 2, # 'f' - 12: 2, # 'g' - 20: 2, # 'h' - 9: 3, # 'i' - 22: 2, # 'j' - 7: 2, # 'k' - 6: 2, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 8: 3, # 'o' - 23: 2, # 'p' - 10: 2, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 3, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 2, # 'í' - 25: 2, # 'ó' - 24: 3, # 'ö' - 31: 2, # 'ú' - 29: 2, # 'ü' - 42: 1, # 'ő' - 56: 2, # 'ű' - }, - 11: { # 'z' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 3, # 'a' - 18: 2, # 'b' - 26: 1, # 'c' - 17: 3, # 'd' - 1: 3, # 'e' - 27: 1, # 'f' - 12: 2, # 'g' - 20: 2, # 'h' - 9: 3, # 'i' - 22: 1, # 'j' - 7: 3, # 'k' - 6: 2, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 3, # 'o' - 23: 1, # 'p' - 10: 2, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 3, # 'u' - 19: 2, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 3, # 'á' - 15: 3, # 'é' - 30: 3, # 'í' - 25: 3, # 'ó' - 24: 3, # 'ö' - 31: 2, # 'ú' - 29: 3, # 'ü' - 42: 2, # 'ő' - 56: 1, # 'ű' - }, - 51: { # 'Á' - 28: 0, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 0, # 'E' - 50: 1, # 'F' - 49: 2, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 2, # 'L' - 34: 1, # 'M' - 35: 2, # 'N' - 47: 0, # 'O' - 46: 1, # 'P' - 43: 2, # 'R' - 33: 2, # 'S' - 37: 1, # 'T' - 57: 0, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 1, # 'Z' - 2: 0, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 1, # 'd' - 1: 0, # 'e' - 27: 0, # 'f' - 12: 1, # 'g' - 20: 1, # 'h' - 9: 0, # 'i' - 22: 1, # 'j' - 7: 1, # 'k' - 6: 2, # 'l' - 13: 2, # 'm' - 4: 0, # 'n' - 8: 0, # 'o' - 23: 1, # 'p' - 10: 1, # 'r' - 5: 1, # 's' - 3: 1, # 't' - 21: 0, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 1, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 1, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 44: { # 'É' - 28: 0, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 1, # 'E' - 50: 0, # 'F' - 49: 2, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 2, # 'L' - 34: 1, # 'M' - 35: 2, # 'N' - 47: 0, # 'O' - 46: 1, # 'P' - 43: 2, # 'R' - 33: 2, # 'S' - 37: 2, # 'T' - 57: 0, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 1, # 'Z' - 2: 0, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 1, # 'd' - 1: 0, # 'e' - 27: 0, # 'f' - 12: 1, # 'g' - 20: 1, # 'h' - 9: 0, # 'i' - 22: 1, # 'j' - 7: 1, # 'k' - 6: 2, # 'l' - 13: 1, # 'm' - 4: 2, # 'n' - 8: 0, # 'o' - 23: 1, # 'p' - 10: 2, # 'r' - 5: 3, # 's' - 3: 1, # 't' - 21: 0, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 0, # 'z' - 51: 0, # 'Á' - 44: 1, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 61: { # 'Í' - 28: 0, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 0, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 1, # 'J' - 36: 0, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 0, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 0, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 1, # 'Z' - 2: 0, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 0, # 'e' - 27: 0, # 'f' - 12: 2, # 'g' - 20: 0, # 'h' - 9: 0, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 0, # 'l' - 13: 1, # 'm' - 4: 0, # 'n' - 8: 0, # 'o' - 23: 0, # 'p' - 10: 1, # 'r' - 5: 0, # 's' - 3: 1, # 't' - 21: 0, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 1, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 58: { # 'Ó' - 28: 1, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 0, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 1, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 2, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 0, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 0, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 1, # 'Z' - 2: 0, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 1, # 'd' - 1: 0, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 2, # 'h' - 9: 0, # 'i' - 22: 0, # 'j' - 7: 1, # 'k' - 6: 1, # 'l' - 13: 0, # 'm' - 4: 1, # 'n' - 8: 0, # 'o' - 23: 1, # 'p' - 10: 1, # 'r' - 5: 1, # 's' - 3: 0, # 't' - 21: 0, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 1, # 'z' - 51: 0, # 'Á' - 44: 1, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 59: { # 'Ö' - 28: 0, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 0, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 0, # 'O' - 46: 1, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 0, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 1, # 'Z' - 2: 0, # 'a' - 18: 0, # 'b' - 26: 1, # 'c' - 17: 1, # 'd' - 1: 0, # 'e' - 27: 0, # 'f' - 12: 0, # 'g' - 20: 0, # 'h' - 9: 0, # 'i' - 22: 0, # 'j' - 7: 1, # 'k' - 6: 1, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 8: 0, # 'o' - 23: 0, # 'p' - 10: 2, # 'r' - 5: 1, # 's' - 3: 1, # 't' - 21: 0, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 1, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 60: { # 'Ú' - 28: 0, # 'A' - 40: 1, # 'B' - 54: 1, # 'C' - 45: 1, # 'D' - 32: 0, # 'E' - 50: 1, # 'F' - 49: 1, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 0, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 1, # 'Z' - 2: 0, # 'a' - 18: 0, # 'b' - 26: 0, # 'c' - 17: 0, # 'd' - 1: 0, # 'e' - 27: 0, # 'f' - 12: 2, # 'g' - 20: 0, # 'h' - 9: 0, # 'i' - 22: 2, # 'j' - 7: 0, # 'k' - 6: 0, # 'l' - 13: 0, # 'm' - 4: 1, # 'n' - 8: 0, # 'o' - 23: 0, # 'p' - 10: 1, # 'r' - 5: 1, # 's' - 3: 1, # 't' - 21: 0, # 'u' - 19: 0, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 0, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 63: { # 'Ü' - 28: 0, # 'A' - 40: 1, # 'B' - 54: 0, # 'C' - 45: 1, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 1, # 'G' - 38: 1, # 'H' - 39: 0, # 'I' - 53: 1, # 'J' - 36: 1, # 'K' - 41: 1, # 'L' - 34: 1, # 'M' - 35: 1, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 1, # 'R' - 33: 1, # 'S' - 37: 1, # 'T' - 57: 0, # 'U' - 48: 1, # 'V' - 55: 0, # 'Y' - 52: 1, # 'Z' - 2: 0, # 'a' - 18: 1, # 'b' - 26: 0, # 'c' - 17: 1, # 'd' - 1: 0, # 'e' - 27: 0, # 'f' - 12: 1, # 'g' - 20: 0, # 'h' - 9: 0, # 'i' - 22: 0, # 'j' - 7: 0, # 'k' - 6: 1, # 'l' - 13: 0, # 'm' - 4: 1, # 'n' - 8: 0, # 'o' - 23: 0, # 'p' - 10: 1, # 'r' - 5: 1, # 's' - 3: 1, # 't' - 21: 0, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 1, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 14: { # 'á' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 1, # 'a' - 18: 3, # 'b' - 26: 3, # 'c' - 17: 3, # 'd' - 1: 1, # 'e' - 27: 2, # 'f' - 12: 3, # 'g' - 20: 2, # 'h' - 9: 2, # 'i' - 22: 3, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 1, # 'o' - 23: 2, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 2, # 'u' - 19: 3, # 'v' - 62: 0, # 'x' - 16: 1, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 1, # 'á' - 15: 2, # 'é' - 30: 1, # 'í' - 25: 0, # 'ó' - 24: 1, # 'ö' - 31: 0, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 15: { # 'é' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 1, # 'a' - 18: 3, # 'b' - 26: 2, # 'c' - 17: 3, # 'd' - 1: 1, # 'e' - 27: 1, # 'f' - 12: 3, # 'g' - 20: 3, # 'h' - 9: 2, # 'i' - 22: 2, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 1, # 'o' - 23: 3, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 0, # 'u' - 19: 3, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 1, # 'á' - 15: 1, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 30: { # 'í' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 0, # 'a' - 18: 1, # 'b' - 26: 2, # 'c' - 17: 1, # 'd' - 1: 0, # 'e' - 27: 1, # 'f' - 12: 3, # 'g' - 20: 0, # 'h' - 9: 0, # 'i' - 22: 1, # 'j' - 7: 1, # 'k' - 6: 2, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 8: 0, # 'o' - 23: 1, # 'p' - 10: 3, # 'r' - 5: 2, # 's' - 3: 3, # 't' - 21: 0, # 'u' - 19: 3, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 25: { # 'ó' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 2, # 'a' - 18: 3, # 'b' - 26: 2, # 'c' - 17: 3, # 'd' - 1: 1, # 'e' - 27: 2, # 'f' - 12: 2, # 'g' - 20: 2, # 'h' - 9: 2, # 'i' - 22: 2, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 8: 1, # 'o' - 23: 2, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 1, # 'u' - 19: 2, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 1, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 0, # 'ó' - 24: 1, # 'ö' - 31: 1, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 24: { # 'ö' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 0, # 'a' - 18: 3, # 'b' - 26: 1, # 'c' - 17: 2, # 'd' - 1: 0, # 'e' - 27: 1, # 'f' - 12: 2, # 'g' - 20: 1, # 'h' - 9: 0, # 'i' - 22: 1, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 8: 0, # 'o' - 23: 2, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 3, # 't' - 21: 0, # 'u' - 19: 3, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 3, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 31: { # 'ú' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 1, # 'a' - 18: 1, # 'b' - 26: 2, # 'c' - 17: 1, # 'd' - 1: 1, # 'e' - 27: 2, # 'f' - 12: 3, # 'g' - 20: 1, # 'h' - 9: 1, # 'i' - 22: 3, # 'j' - 7: 1, # 'k' - 6: 3, # 'l' - 13: 1, # 'm' - 4: 2, # 'n' - 8: 0, # 'o' - 23: 1, # 'p' - 10: 3, # 'r' - 5: 3, # 's' - 3: 2, # 't' - 21: 1, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 1, # 'á' - 15: 1, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 29: { # 'ü' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 1, # 'a' - 18: 1, # 'b' - 26: 1, # 'c' - 17: 2, # 'd' - 1: 1, # 'e' - 27: 1, # 'f' - 12: 3, # 'g' - 20: 2, # 'h' - 9: 1, # 'i' - 22: 1, # 'j' - 7: 3, # 'k' - 6: 3, # 'l' - 13: 1, # 'm' - 4: 3, # 'n' - 8: 0, # 'o' - 23: 1, # 'p' - 10: 2, # 'r' - 5: 2, # 's' - 3: 2, # 't' - 21: 0, # 'u' - 19: 2, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 1, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 42: { # 'ő' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 1, # 'a' - 18: 2, # 'b' - 26: 1, # 'c' - 17: 2, # 'd' - 1: 1, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 1, # 'h' - 9: 1, # 'i' - 22: 1, # 'j' - 7: 2, # 'k' - 6: 3, # 'l' - 13: 1, # 'm' - 4: 2, # 'n' - 8: 1, # 'o' - 23: 1, # 'p' - 10: 2, # 'r' - 5: 2, # 's' - 3: 2, # 't' - 21: 1, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 1, # 'é' - 30: 1, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 1, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, - 56: { # 'ű' - 28: 0, # 'A' - 40: 0, # 'B' - 54: 0, # 'C' - 45: 0, # 'D' - 32: 0, # 'E' - 50: 0, # 'F' - 49: 0, # 'G' - 38: 0, # 'H' - 39: 0, # 'I' - 53: 0, # 'J' - 36: 0, # 'K' - 41: 0, # 'L' - 34: 0, # 'M' - 35: 0, # 'N' - 47: 0, # 'O' - 46: 0, # 'P' - 43: 0, # 'R' - 33: 0, # 'S' - 37: 0, # 'T' - 57: 0, # 'U' - 48: 0, # 'V' - 55: 0, # 'Y' - 52: 0, # 'Z' - 2: 1, # 'a' - 18: 1, # 'b' - 26: 0, # 'c' - 17: 1, # 'd' - 1: 1, # 'e' - 27: 1, # 'f' - 12: 1, # 'g' - 20: 1, # 'h' - 9: 1, # 'i' - 22: 1, # 'j' - 7: 1, # 'k' - 6: 1, # 'l' - 13: 0, # 'm' - 4: 2, # 'n' - 8: 0, # 'o' - 23: 0, # 'p' - 10: 1, # 'r' - 5: 1, # 's' - 3: 1, # 't' - 21: 0, # 'u' - 19: 1, # 'v' - 62: 0, # 'x' - 16: 0, # 'y' - 11: 2, # 'z' - 51: 0, # 'Á' - 44: 0, # 'É' - 61: 0, # 'Í' - 58: 0, # 'Ó' - 59: 0, # 'Ö' - 60: 0, # 'Ú' - 63: 0, # 'Ü' - 14: 0, # 'á' - 15: 0, # 'é' - 30: 0, # 'í' - 25: 0, # 'ó' - 24: 0, # 'ö' - 31: 0, # 'ú' - 29: 0, # 'ü' - 42: 0, # 'ő' - 56: 0, # 'ű' - }, -} - -# 255: Undefined characters that did not exist in training text -# 254: Carriage/Return -# 253: symbol (punctuation) that does not belong to word -# 252: 0 - 9 -# 251: Control characters - -# Character Mapping Table(s): -WINDOWS_1250_HUNGARIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 28, # 'A' - 66: 40, # 'B' - 67: 54, # 'C' - 68: 45, # 'D' - 69: 32, # 'E' - 70: 50, # 'F' - 71: 49, # 'G' - 72: 38, # 'H' - 73: 39, # 'I' - 74: 53, # 'J' - 75: 36, # 'K' - 76: 41, # 'L' - 77: 34, # 'M' - 78: 35, # 'N' - 79: 47, # 'O' - 80: 46, # 'P' - 81: 72, # 'Q' - 82: 43, # 'R' - 83: 33, # 'S' - 84: 37, # 'T' - 85: 57, # 'U' - 86: 48, # 'V' - 87: 64, # 'W' - 88: 68, # 'X' - 89: 55, # 'Y' - 90: 52, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 2, # 'a' - 98: 18, # 'b' - 99: 26, # 'c' - 100: 17, # 'd' - 101: 1, # 'e' - 102: 27, # 'f' - 103: 12, # 'g' - 104: 20, # 'h' - 105: 9, # 'i' - 106: 22, # 'j' - 107: 7, # 'k' - 108: 6, # 'l' - 109: 13, # 'm' - 110: 4, # 'n' - 111: 8, # 'o' - 112: 23, # 'p' - 113: 67, # 'q' - 114: 10, # 'r' - 115: 5, # 's' - 116: 3, # 't' - 117: 21, # 'u' - 118: 19, # 'v' - 119: 65, # 'w' - 120: 62, # 'x' - 121: 16, # 'y' - 122: 11, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 161, # '€' - 129: 162, # None - 130: 163, # '‚' - 131: 164, # None - 132: 165, # '„' - 133: 166, # '…' - 134: 167, # '†' - 135: 168, # '‡' - 136: 169, # None - 137: 170, # '‰' - 138: 171, # 'Š' - 139: 172, # '‹' - 140: 173, # 'Ś' - 141: 174, # 'Ť' - 142: 175, # 'Ž' - 143: 176, # 'Ź' - 144: 177, # None - 145: 178, # '‘' - 146: 179, # '’' - 147: 180, # '“' - 148: 78, # '”' - 149: 181, # '•' - 150: 69, # '–' - 151: 182, # '—' - 152: 183, # None - 153: 184, # '™' - 154: 185, # 'š' - 155: 186, # '›' - 156: 187, # 'ś' - 157: 188, # 'ť' - 158: 189, # 'ž' - 159: 190, # 'ź' - 160: 191, # '\xa0' - 161: 192, # 'ˇ' - 162: 193, # '˘' - 163: 194, # 'Ł' - 164: 195, # '¤' - 165: 196, # 'Ą' - 166: 197, # '¦' - 167: 76, # '§' - 168: 198, # '¨' - 169: 199, # '©' - 170: 200, # 'Ş' - 171: 201, # '«' - 172: 202, # '¬' - 173: 203, # '\xad' - 174: 204, # '®' - 175: 205, # 'Ż' - 176: 81, # '°' - 177: 206, # '±' - 178: 207, # '˛' - 179: 208, # 'ł' - 180: 209, # '´' - 181: 210, # 'µ' - 182: 211, # '¶' - 183: 212, # '·' - 184: 213, # '¸' - 185: 214, # 'ą' - 186: 215, # 'ş' - 187: 216, # '»' - 188: 217, # 'Ľ' - 189: 218, # '˝' - 190: 219, # 'ľ' - 191: 220, # 'ż' - 192: 221, # 'Ŕ' - 193: 51, # 'Á' - 194: 83, # 'Â' - 195: 222, # 'Ă' - 196: 80, # 'Ä' - 197: 223, # 'Ĺ' - 198: 224, # 'Ć' - 199: 225, # 'Ç' - 200: 226, # 'Č' - 201: 44, # 'É' - 202: 227, # 'Ę' - 203: 228, # 'Ë' - 204: 229, # 'Ě' - 205: 61, # 'Í' - 206: 230, # 'Î' - 207: 231, # 'Ď' - 208: 232, # 'Đ' - 209: 233, # 'Ń' - 210: 234, # 'Ň' - 211: 58, # 'Ó' - 212: 235, # 'Ô' - 213: 66, # 'Ő' - 214: 59, # 'Ö' - 215: 236, # '×' - 216: 237, # 'Ř' - 217: 238, # 'Ů' - 218: 60, # 'Ú' - 219: 70, # 'Ű' - 220: 63, # 'Ü' - 221: 239, # 'Ý' - 222: 240, # 'Ţ' - 223: 241, # 'ß' - 224: 84, # 'ŕ' - 225: 14, # 'á' - 226: 75, # 'â' - 227: 242, # 'ă' - 228: 71, # 'ä' - 229: 82, # 'ĺ' - 230: 243, # 'ć' - 231: 73, # 'ç' - 232: 244, # 'č' - 233: 15, # 'é' - 234: 85, # 'ę' - 235: 79, # 'ë' - 236: 86, # 'ě' - 237: 30, # 'í' - 238: 77, # 'î' - 239: 87, # 'ď' - 240: 245, # 'đ' - 241: 246, # 'ń' - 242: 247, # 'ň' - 243: 25, # 'ó' - 244: 74, # 'ô' - 245: 42, # 'ő' - 246: 24, # 'ö' - 247: 248, # '÷' - 248: 249, # 'ř' - 249: 250, # 'ů' - 250: 31, # 'ú' - 251: 56, # 'ű' - 252: 29, # 'ü' - 253: 251, # 'ý' - 254: 252, # 'ţ' - 255: 253, # '˙' -} - -WINDOWS_1250_HUNGARIAN_MODEL = SingleByteCharSetModel( - charset_name="windows-1250", - language="Hungarian", - char_to_order_map=WINDOWS_1250_HUNGARIAN_CHAR_TO_ORDER, - language_model=HUNGARIAN_LANG_MODEL, - typical_positive_ratio=0.947368, - keep_ascii_letters=True, - alphabet="ABCDEFGHIJKLMNOPRSTUVZabcdefghijklmnoprstuvzÁÉÍÓÖÚÜáéíóöúüŐőŰű", -) - -ISO_8859_2_HUNGARIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 28, # 'A' - 66: 40, # 'B' - 67: 54, # 'C' - 68: 45, # 'D' - 69: 32, # 'E' - 70: 50, # 'F' - 71: 49, # 'G' - 72: 38, # 'H' - 73: 39, # 'I' - 74: 53, # 'J' - 75: 36, # 'K' - 76: 41, # 'L' - 77: 34, # 'M' - 78: 35, # 'N' - 79: 47, # 'O' - 80: 46, # 'P' - 81: 71, # 'Q' - 82: 43, # 'R' - 83: 33, # 'S' - 84: 37, # 'T' - 85: 57, # 'U' - 86: 48, # 'V' - 87: 64, # 'W' - 88: 68, # 'X' - 89: 55, # 'Y' - 90: 52, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 2, # 'a' - 98: 18, # 'b' - 99: 26, # 'c' - 100: 17, # 'd' - 101: 1, # 'e' - 102: 27, # 'f' - 103: 12, # 'g' - 104: 20, # 'h' - 105: 9, # 'i' - 106: 22, # 'j' - 107: 7, # 'k' - 108: 6, # 'l' - 109: 13, # 'm' - 110: 4, # 'n' - 111: 8, # 'o' - 112: 23, # 'p' - 113: 67, # 'q' - 114: 10, # 'r' - 115: 5, # 's' - 116: 3, # 't' - 117: 21, # 'u' - 118: 19, # 'v' - 119: 65, # 'w' - 120: 62, # 'x' - 121: 16, # 'y' - 122: 11, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 159, # '\x80' - 129: 160, # '\x81' - 130: 161, # '\x82' - 131: 162, # '\x83' - 132: 163, # '\x84' - 133: 164, # '\x85' - 134: 165, # '\x86' - 135: 166, # '\x87' - 136: 167, # '\x88' - 137: 168, # '\x89' - 138: 169, # '\x8a' - 139: 170, # '\x8b' - 140: 171, # '\x8c' - 141: 172, # '\x8d' - 142: 173, # '\x8e' - 143: 174, # '\x8f' - 144: 175, # '\x90' - 145: 176, # '\x91' - 146: 177, # '\x92' - 147: 178, # '\x93' - 148: 179, # '\x94' - 149: 180, # '\x95' - 150: 181, # '\x96' - 151: 182, # '\x97' - 152: 183, # '\x98' - 153: 184, # '\x99' - 154: 185, # '\x9a' - 155: 186, # '\x9b' - 156: 187, # '\x9c' - 157: 188, # '\x9d' - 158: 189, # '\x9e' - 159: 190, # '\x9f' - 160: 191, # '\xa0' - 161: 192, # 'Ą' - 162: 193, # '˘' - 163: 194, # 'Ł' - 164: 195, # '¤' - 165: 196, # 'Ľ' - 166: 197, # 'Ś' - 167: 75, # '§' - 168: 198, # '¨' - 169: 199, # 'Š' - 170: 200, # 'Ş' - 171: 201, # 'Ť' - 172: 202, # 'Ź' - 173: 203, # '\xad' - 174: 204, # 'Ž' - 175: 205, # 'Ż' - 176: 79, # '°' - 177: 206, # 'ą' - 178: 207, # '˛' - 179: 208, # 'ł' - 180: 209, # '´' - 181: 210, # 'ľ' - 182: 211, # 'ś' - 183: 212, # 'ˇ' - 184: 213, # '¸' - 185: 214, # 'š' - 186: 215, # 'ş' - 187: 216, # 'ť' - 188: 217, # 'ź' - 189: 218, # '˝' - 190: 219, # 'ž' - 191: 220, # 'ż' - 192: 221, # 'Ŕ' - 193: 51, # 'Á' - 194: 81, # 'Â' - 195: 222, # 'Ă' - 196: 78, # 'Ä' - 197: 223, # 'Ĺ' - 198: 224, # 'Ć' - 199: 225, # 'Ç' - 200: 226, # 'Č' - 201: 44, # 'É' - 202: 227, # 'Ę' - 203: 228, # 'Ë' - 204: 229, # 'Ě' - 205: 61, # 'Í' - 206: 230, # 'Î' - 207: 231, # 'Ď' - 208: 232, # 'Đ' - 209: 233, # 'Ń' - 210: 234, # 'Ň' - 211: 58, # 'Ó' - 212: 235, # 'Ô' - 213: 66, # 'Ő' - 214: 59, # 'Ö' - 215: 236, # '×' - 216: 237, # 'Ř' - 217: 238, # 'Ů' - 218: 60, # 'Ú' - 219: 69, # 'Ű' - 220: 63, # 'Ü' - 221: 239, # 'Ý' - 222: 240, # 'Ţ' - 223: 241, # 'ß' - 224: 82, # 'ŕ' - 225: 14, # 'á' - 226: 74, # 'â' - 227: 242, # 'ă' - 228: 70, # 'ä' - 229: 80, # 'ĺ' - 230: 243, # 'ć' - 231: 72, # 'ç' - 232: 244, # 'č' - 233: 15, # 'é' - 234: 83, # 'ę' - 235: 77, # 'ë' - 236: 84, # 'ě' - 237: 30, # 'í' - 238: 76, # 'î' - 239: 85, # 'ď' - 240: 245, # 'đ' - 241: 246, # 'ń' - 242: 247, # 'ň' - 243: 25, # 'ó' - 244: 73, # 'ô' - 245: 42, # 'ő' - 246: 24, # 'ö' - 247: 248, # '÷' - 248: 249, # 'ř' - 249: 250, # 'ů' - 250: 31, # 'ú' - 251: 56, # 'ű' - 252: 29, # 'ü' - 253: 251, # 'ý' - 254: 252, # 'ţ' - 255: 253, # '˙' -} - -ISO_8859_2_HUNGARIAN_MODEL = SingleByteCharSetModel( - charset_name="ISO-8859-2", - language="Hungarian", - char_to_order_map=ISO_8859_2_HUNGARIAN_CHAR_TO_ORDER, - language_model=HUNGARIAN_LANG_MODEL, - typical_positive_ratio=0.947368, - keep_ascii_letters=True, - alphabet="ABCDEFGHIJKLMNOPRSTUVZabcdefghijklmnoprstuvzÁÉÍÓÖÚÜáéíóöúüŐőŰű", -) diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py b/myenv/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py deleted file mode 100644 index 39a5388..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py +++ /dev/null @@ -1,5725 +0,0 @@ -from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - -# 3: Positive -# 2: Likely -# 1: Unlikely -# 0: Negative - -RUSSIAN_LANG_MODEL = { - 37: { # 'А' - 37: 0, # 'А' - 44: 1, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 1, # 'Д' - 48: 1, # 'Е' - 56: 1, # 'Ж' - 51: 1, # 'З' - 42: 1, # 'И' - 60: 1, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 2, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 1, # 'Ф' - 55: 1, # 'Х' - 58: 1, # 'Ц' - 50: 1, # 'Ч' - 57: 1, # 'Ш' - 63: 1, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 1, # 'Ю' - 43: 1, # 'Я' - 3: 1, # 'а' - 21: 2, # 'б' - 10: 2, # 'в' - 19: 2, # 'г' - 13: 2, # 'д' - 2: 0, # 'е' - 24: 1, # 'ж' - 20: 1, # 'з' - 4: 0, # 'и' - 23: 1, # 'й' - 11: 2, # 'к' - 8: 3, # 'л' - 12: 2, # 'м' - 5: 2, # 'н' - 1: 0, # 'о' - 15: 2, # 'п' - 9: 2, # 'р' - 7: 2, # 'с' - 6: 2, # 'т' - 14: 2, # 'у' - 39: 2, # 'ф' - 26: 2, # 'х' - 28: 0, # 'ц' - 22: 1, # 'ч' - 25: 2, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 1, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 44: { # 'Б' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 0, # 'П' - 45: 1, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 1, # 'Я' - 3: 2, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 1, # 'д' - 2: 3, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 2, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 2, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 2, # 'ы' - 17: 1, # 'ь' - 30: 2, # 'э' - 27: 1, # 'ю' - 16: 1, # 'я' - }, - 33: { # 'В' - 37: 2, # 'А' - 44: 0, # 'Б' - 33: 1, # 'В' - 46: 0, # 'Г' - 41: 1, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 1, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 1, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 1, # 'Я' - 3: 2, # 'а' - 21: 1, # 'б' - 10: 1, # 'в' - 19: 1, # 'г' - 13: 2, # 'д' - 2: 3, # 'е' - 24: 0, # 'ж' - 20: 2, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 1, # 'к' - 8: 2, # 'л' - 12: 2, # 'м' - 5: 2, # 'н' - 1: 3, # 'о' - 15: 2, # 'п' - 9: 2, # 'р' - 7: 3, # 'с' - 6: 2, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 1, # 'х' - 28: 1, # 'ц' - 22: 2, # 'ч' - 25: 1, # 'ш' - 29: 0, # 'щ' - 54: 1, # 'ъ' - 18: 3, # 'ы' - 17: 1, # 'ь' - 30: 2, # 'э' - 27: 0, # 'ю' - 16: 1, # 'я' - }, - 46: { # 'Г' - 37: 1, # 'А' - 44: 1, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 1, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 1, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 0, # 'б' - 10: 1, # 'в' - 19: 0, # 'г' - 13: 2, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 2, # 'л' - 12: 1, # 'м' - 5: 1, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 2, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 1, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 0, # 'я' - }, - 41: { # 'Д' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 1, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 2, # 'Е' - 56: 1, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 0, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 0, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 1, # 'Ц' - 50: 1, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 1, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 1, # 'Я' - 3: 3, # 'а' - 21: 0, # 'б' - 10: 2, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 3, # 'ж' - 20: 1, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 2, # 'л' - 12: 1, # 'м' - 5: 1, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 2, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 1, # 'ы' - 17: 1, # 'ь' - 30: 2, # 'э' - 27: 1, # 'ю' - 16: 1, # 'я' - }, - 48: { # 'Е' - 37: 1, # 'А' - 44: 1, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 1, # 'Д' - 48: 1, # 'Е' - 56: 1, # 'Ж' - 51: 1, # 'З' - 42: 1, # 'И' - 60: 1, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 2, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 2, # 'Р' - 32: 2, # 'С' - 40: 1, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 1, # 'Х' - 58: 1, # 'Ц' - 50: 1, # 'Ч' - 57: 1, # 'Ш' - 63: 1, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 1, # 'Я' - 3: 0, # 'а' - 21: 0, # 'б' - 10: 2, # 'в' - 19: 2, # 'г' - 13: 2, # 'д' - 2: 2, # 'е' - 24: 1, # 'ж' - 20: 1, # 'з' - 4: 0, # 'и' - 23: 2, # 'й' - 11: 1, # 'к' - 8: 2, # 'л' - 12: 2, # 'м' - 5: 1, # 'н' - 1: 0, # 'о' - 15: 1, # 'п' - 9: 1, # 'р' - 7: 3, # 'с' - 6: 0, # 'т' - 14: 0, # 'у' - 39: 1, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 1, # 'ш' - 29: 2, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 1, # 'ю' - 16: 0, # 'я' - }, - 56: { # 'Ж' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 1, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 1, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 1, # 'б' - 10: 0, # 'в' - 19: 1, # 'г' - 13: 1, # 'д' - 2: 2, # 'е' - 24: 1, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 0, # 'л' - 12: 1, # 'м' - 5: 0, # 'н' - 1: 2, # 'о' - 15: 0, # 'п' - 9: 1, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 2, # 'ю' - 16: 0, # 'я' - }, - 51: { # 'З' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 1, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 0, # 'П' - 45: 1, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 1, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 1, # 'б' - 10: 2, # 'в' - 19: 0, # 'г' - 13: 2, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 1, # 'л' - 12: 1, # 'м' - 5: 2, # 'н' - 1: 2, # 'о' - 15: 0, # 'п' - 9: 1, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 1, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 1, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 1, # 'я' - }, - 42: { # 'И' - 37: 1, # 'А' - 44: 1, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 1, # 'Д' - 48: 2, # 'Е' - 56: 1, # 'Ж' - 51: 1, # 'З' - 42: 1, # 'И' - 60: 1, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 1, # 'Р' - 32: 2, # 'С' - 40: 1, # 'Т' - 52: 0, # 'У' - 53: 1, # 'Ф' - 55: 1, # 'Х' - 58: 1, # 'Ц' - 50: 1, # 'Ч' - 57: 0, # 'Ш' - 63: 1, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 1, # 'Ю' - 43: 1, # 'Я' - 3: 1, # 'а' - 21: 2, # 'б' - 10: 2, # 'в' - 19: 2, # 'г' - 13: 2, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 2, # 'з' - 4: 1, # 'и' - 23: 0, # 'й' - 11: 1, # 'к' - 8: 2, # 'л' - 12: 2, # 'м' - 5: 2, # 'н' - 1: 1, # 'о' - 15: 1, # 'п' - 9: 2, # 'р' - 7: 2, # 'с' - 6: 2, # 'т' - 14: 1, # 'у' - 39: 1, # 'ф' - 26: 2, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 1, # 'ш' - 29: 1, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 1, # 'ю' - 16: 0, # 'я' - }, - 60: { # 'Й' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 1, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 1, # 'Х' - 58: 1, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 0, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 1, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 0, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 0, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 2, # 'о' - 15: 0, # 'п' - 9: 0, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 0, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 36: { # 'К' - 37: 2, # 'А' - 44: 0, # 'Б' - 33: 1, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 1, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 1, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 2, # 'О' - 35: 1, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 1, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 0, # 'б' - 10: 1, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 2, # 'л' - 12: 0, # 'м' - 5: 1, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 2, # 'р' - 7: 2, # 'с' - 6: 2, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 1, # 'ы' - 17: 1, # 'ь' - 30: 2, # 'э' - 27: 1, # 'ю' - 16: 0, # 'я' - }, - 49: { # 'Л' - 37: 2, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 1, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 1, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 0, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 0, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 1, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 1, # 'Ь' - 47: 0, # 'Э' - 59: 1, # 'Ю' - 43: 1, # 'Я' - 3: 2, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 1, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 1, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 1, # 'л' - 12: 0, # 'м' - 5: 1, # 'н' - 1: 2, # 'о' - 15: 0, # 'п' - 9: 0, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 1, # 'ы' - 17: 1, # 'ь' - 30: 2, # 'э' - 27: 2, # 'ю' - 16: 1, # 'я' - }, - 38: { # 'М' - 37: 1, # 'А' - 44: 1, # 'Б' - 33: 1, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 1, # 'Ф' - 55: 1, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 0, # 'Ь' - 47: 1, # 'Э' - 59: 0, # 'Ю' - 43: 1, # 'Я' - 3: 3, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 1, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 1, # 'л' - 12: 1, # 'м' - 5: 2, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 1, # 'р' - 7: 1, # 'с' - 6: 0, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 3, # 'ы' - 17: 1, # 'ь' - 30: 2, # 'э' - 27: 1, # 'ю' - 16: 1, # 'я' - }, - 31: { # 'Н' - 37: 2, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 1, # 'Г' - 41: 1, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 1, # 'З' - 42: 2, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 0, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 1, # 'Ф' - 55: 1, # 'Х' - 58: 1, # 'Ц' - 50: 1, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 1, # 'Ь' - 47: 1, # 'Э' - 59: 0, # 'Ю' - 43: 1, # 'Я' - 3: 3, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 3, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 0, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 1, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 3, # 'у' - 39: 0, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 1, # 'ы' - 17: 2, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 1, # 'я' - }, - 34: { # 'О' - 37: 0, # 'А' - 44: 1, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 2, # 'Д' - 48: 1, # 'Е' - 56: 1, # 'Ж' - 51: 1, # 'З' - 42: 1, # 'И' - 60: 1, # 'Й' - 36: 1, # 'К' - 49: 2, # 'Л' - 38: 1, # 'М' - 31: 2, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 2, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 1, # 'Ф' - 55: 1, # 'Х' - 58: 0, # 'Ц' - 50: 1, # 'Ч' - 57: 1, # 'Ш' - 63: 1, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 1, # 'Я' - 3: 1, # 'а' - 21: 2, # 'б' - 10: 1, # 'в' - 19: 2, # 'г' - 13: 2, # 'д' - 2: 0, # 'е' - 24: 1, # 'ж' - 20: 1, # 'з' - 4: 0, # 'и' - 23: 1, # 'й' - 11: 2, # 'к' - 8: 2, # 'л' - 12: 1, # 'м' - 5: 3, # 'н' - 1: 0, # 'о' - 15: 2, # 'п' - 9: 2, # 'р' - 7: 2, # 'с' - 6: 2, # 'т' - 14: 1, # 'у' - 39: 1, # 'ф' - 26: 2, # 'х' - 28: 1, # 'ц' - 22: 2, # 'ч' - 25: 2, # 'ш' - 29: 1, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 35: { # 'П' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 1, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 2, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 1, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 1, # 'Я' - 3: 2, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 2, # 'л' - 12: 0, # 'м' - 5: 1, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 3, # 'р' - 7: 1, # 'с' - 6: 1, # 'т' - 14: 2, # 'у' - 39: 1, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 1, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 1, # 'ы' - 17: 2, # 'ь' - 30: 1, # 'э' - 27: 0, # 'ю' - 16: 2, # 'я' - }, - 45: { # 'Р' - 37: 2, # 'А' - 44: 1, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 1, # 'Д' - 48: 2, # 'Е' - 56: 1, # 'Ж' - 51: 0, # 'З' - 42: 2, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 2, # 'О' - 35: 0, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 1, # 'Х' - 58: 1, # 'Ц' - 50: 1, # 'Ч' - 57: 1, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 1, # 'Ь' - 47: 1, # 'Э' - 59: 1, # 'Ю' - 43: 1, # 'Я' - 3: 3, # 'а' - 21: 0, # 'б' - 10: 1, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 1, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 0, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 1, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 2, # 'ы' - 17: 0, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 2, # 'я' - }, - 32: { # 'С' - 37: 1, # 'А' - 44: 1, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 1, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 2, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 1, # 'Х' - 58: 1, # 'Ц' - 50: 1, # 'Ч' - 57: 1, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 1, # 'Ь' - 47: 1, # 'Э' - 59: 1, # 'Ю' - 43: 1, # 'Я' - 3: 2, # 'а' - 21: 1, # 'б' - 10: 2, # 'в' - 19: 1, # 'г' - 13: 2, # 'д' - 2: 3, # 'е' - 24: 1, # 'ж' - 20: 1, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 2, # 'к' - 8: 2, # 'л' - 12: 2, # 'м' - 5: 2, # 'н' - 1: 2, # 'о' - 15: 2, # 'п' - 9: 2, # 'р' - 7: 1, # 'с' - 6: 3, # 'т' - 14: 2, # 'у' - 39: 1, # 'ф' - 26: 1, # 'х' - 28: 1, # 'ц' - 22: 1, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 1, # 'ъ' - 18: 1, # 'ы' - 17: 1, # 'ь' - 30: 2, # 'э' - 27: 1, # 'ю' - 16: 1, # 'я' - }, - 40: { # 'Т' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 1, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 2, # 'О' - 35: 0, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 1, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 1, # 'Ь' - 47: 1, # 'Э' - 59: 1, # 'Ю' - 43: 1, # 'Я' - 3: 3, # 'а' - 21: 1, # 'б' - 10: 2, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 3, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 1, # 'к' - 8: 1, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 2, # 'р' - 7: 1, # 'с' - 6: 0, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 1, # 'щ' - 54: 0, # 'ъ' - 18: 3, # 'ы' - 17: 1, # 'ь' - 30: 2, # 'э' - 27: 1, # 'ю' - 16: 1, # 'я' - }, - 52: { # 'У' - 37: 1, # 'А' - 44: 1, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 1, # 'Д' - 48: 1, # 'Е' - 56: 1, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 1, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 1, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 1, # 'Х' - 58: 0, # 'Ц' - 50: 1, # 'Ч' - 57: 1, # 'Ш' - 63: 1, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 1, # 'Ю' - 43: 0, # 'Я' - 3: 1, # 'а' - 21: 2, # 'б' - 10: 2, # 'в' - 19: 1, # 'г' - 13: 2, # 'д' - 2: 1, # 'е' - 24: 2, # 'ж' - 20: 2, # 'з' - 4: 2, # 'и' - 23: 1, # 'й' - 11: 1, # 'к' - 8: 2, # 'л' - 12: 2, # 'м' - 5: 1, # 'н' - 1: 2, # 'о' - 15: 1, # 'п' - 9: 2, # 'р' - 7: 2, # 'с' - 6: 2, # 'т' - 14: 0, # 'у' - 39: 1, # 'ф' - 26: 1, # 'х' - 28: 1, # 'ц' - 22: 2, # 'ч' - 25: 1, # 'ш' - 29: 1, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 2, # 'э' - 27: 1, # 'ю' - 16: 0, # 'я' - }, - 53: { # 'Ф' - 37: 1, # 'А' - 44: 1, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 1, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 1, # 'О' - 35: 0, # 'П' - 45: 1, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 2, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 2, # 'о' - 15: 0, # 'п' - 9: 2, # 'р' - 7: 0, # 'с' - 6: 1, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 1, # 'ь' - 30: 2, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 55: { # 'Х' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 1, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 0, # 'б' - 10: 2, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 2, # 'л' - 12: 1, # 'м' - 5: 0, # 'н' - 1: 2, # 'о' - 15: 0, # 'п' - 9: 2, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 1, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 1, # 'ь' - 30: 1, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 58: { # 'Ц' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 1, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 1, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 1, # 'а' - 21: 0, # 'б' - 10: 1, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 0, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 0, # 'о' - 15: 0, # 'п' - 9: 0, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 1, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 1, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 1, # 'ю' - 16: 0, # 'я' - }, - 50: { # 'Ч' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 0, # 'О' - 35: 1, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 1, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 1, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 1, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 1, # 'о' - 15: 0, # 'п' - 9: 1, # 'р' - 7: 0, # 'с' - 6: 3, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 1, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 57: { # 'Ш' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 1, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 0, # 'б' - 10: 1, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 1, # 'и' - 23: 0, # 'й' - 11: 1, # 'к' - 8: 2, # 'л' - 12: 1, # 'м' - 5: 1, # 'н' - 1: 2, # 'о' - 15: 2, # 'п' - 9: 1, # 'р' - 7: 0, # 'с' - 6: 2, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 1, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 1, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 63: { # 'Щ' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 1, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 1, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 1, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 1, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 0, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 1, # 'о' - 15: 0, # 'п' - 9: 0, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 1, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 62: { # 'Ы' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 1, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 0, # 'О' - 35: 1, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 1, # 'Х' - 58: 1, # 'Ц' - 50: 0, # 'Ч' - 57: 1, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 0, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 0, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 0, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 0, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 0, # 'о' - 15: 0, # 'п' - 9: 0, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 0, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 61: { # 'Ь' - 37: 0, # 'А' - 44: 1, # 'Б' - 33: 1, # 'В' - 46: 0, # 'Г' - 41: 1, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 0, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 1, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 1, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 1, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 1, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 1, # 'Ю' - 43: 1, # 'Я' - 3: 0, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 0, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 0, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 0, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 0, # 'о' - 15: 0, # 'п' - 9: 0, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 0, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 47: { # 'Э' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 1, # 'В' - 46: 0, # 'Г' - 41: 1, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 1, # 'Й' - 36: 1, # 'К' - 49: 1, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 0, # 'О' - 35: 1, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 1, # 'а' - 21: 1, # 'б' - 10: 2, # 'в' - 19: 1, # 'г' - 13: 2, # 'д' - 2: 0, # 'е' - 24: 1, # 'ж' - 20: 0, # 'з' - 4: 0, # 'и' - 23: 2, # 'й' - 11: 2, # 'к' - 8: 2, # 'л' - 12: 2, # 'м' - 5: 2, # 'н' - 1: 0, # 'о' - 15: 1, # 'п' - 9: 2, # 'р' - 7: 1, # 'с' - 6: 3, # 'т' - 14: 1, # 'у' - 39: 1, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 1, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 59: { # 'Ю' - 37: 1, # 'А' - 44: 1, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 1, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 1, # 'Р' - 32: 0, # 'С' - 40: 1, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 1, # 'Ч' - 57: 0, # 'Ш' - 63: 1, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 0, # 'а' - 21: 1, # 'б' - 10: 0, # 'в' - 19: 1, # 'г' - 13: 1, # 'д' - 2: 0, # 'е' - 24: 1, # 'ж' - 20: 0, # 'з' - 4: 0, # 'и' - 23: 0, # 'й' - 11: 1, # 'к' - 8: 2, # 'л' - 12: 1, # 'м' - 5: 2, # 'н' - 1: 0, # 'о' - 15: 1, # 'п' - 9: 1, # 'р' - 7: 1, # 'с' - 6: 0, # 'т' - 14: 0, # 'у' - 39: 0, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 43: { # 'Я' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 1, # 'В' - 46: 1, # 'Г' - 41: 0, # 'Д' - 48: 1, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 1, # 'С' - 40: 1, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 1, # 'Х' - 58: 0, # 'Ц' - 50: 1, # 'Ч' - 57: 0, # 'Ш' - 63: 1, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 1, # 'Ю' - 43: 1, # 'Я' - 3: 0, # 'а' - 21: 1, # 'б' - 10: 1, # 'в' - 19: 1, # 'г' - 13: 1, # 'д' - 2: 0, # 'е' - 24: 0, # 'ж' - 20: 1, # 'з' - 4: 0, # 'и' - 23: 1, # 'й' - 11: 1, # 'к' - 8: 1, # 'л' - 12: 1, # 'м' - 5: 2, # 'н' - 1: 0, # 'о' - 15: 1, # 'п' - 9: 1, # 'р' - 7: 1, # 'с' - 6: 0, # 'т' - 14: 0, # 'у' - 39: 0, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 1, # 'ш' - 29: 1, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 3: { # 'а' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 1, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 3, # 'б' - 10: 3, # 'в' - 19: 3, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 3, # 'ж' - 20: 3, # 'з' - 4: 3, # 'и' - 23: 3, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 2, # 'о' - 15: 3, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 3, # 'у' - 39: 2, # 'ф' - 26: 3, # 'х' - 28: 3, # 'ц' - 22: 3, # 'ч' - 25: 3, # 'ш' - 29: 3, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 2, # 'э' - 27: 3, # 'ю' - 16: 3, # 'я' - }, - 21: { # 'б' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 1, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 2, # 'б' - 10: 2, # 'в' - 19: 1, # 'г' - 13: 2, # 'д' - 2: 3, # 'е' - 24: 2, # 'ж' - 20: 1, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 2, # 'к' - 8: 3, # 'л' - 12: 2, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 1, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 2, # 'т' - 14: 3, # 'у' - 39: 0, # 'ф' - 26: 2, # 'х' - 28: 1, # 'ц' - 22: 1, # 'ч' - 25: 2, # 'ш' - 29: 3, # 'щ' - 54: 2, # 'ъ' - 18: 3, # 'ы' - 17: 2, # 'ь' - 30: 1, # 'э' - 27: 2, # 'ю' - 16: 3, # 'я' - }, - 10: { # 'в' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 2, # 'б' - 10: 2, # 'в' - 19: 2, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 1, # 'ж' - 20: 3, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 2, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 3, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 3, # 'у' - 39: 1, # 'ф' - 26: 2, # 'х' - 28: 2, # 'ц' - 22: 2, # 'ч' - 25: 3, # 'ш' - 29: 2, # 'щ' - 54: 2, # 'ъ' - 18: 3, # 'ы' - 17: 3, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 3, # 'я' - }, - 19: { # 'г' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 1, # 'б' - 10: 2, # 'в' - 19: 1, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 0, # 'ж' - 20: 1, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 2, # 'к' - 8: 3, # 'л' - 12: 2, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 3, # 'р' - 7: 2, # 'с' - 6: 2, # 'т' - 14: 3, # 'у' - 39: 1, # 'ф' - 26: 1, # 'х' - 28: 1, # 'ц' - 22: 2, # 'ч' - 25: 1, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 1, # 'ы' - 17: 1, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 0, # 'я' - }, - 13: { # 'д' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 2, # 'б' - 10: 3, # 'в' - 19: 2, # 'г' - 13: 2, # 'д' - 2: 3, # 'е' - 24: 2, # 'ж' - 20: 2, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 2, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 2, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 3, # 'у' - 39: 1, # 'ф' - 26: 2, # 'х' - 28: 3, # 'ц' - 22: 2, # 'ч' - 25: 2, # 'ш' - 29: 1, # 'щ' - 54: 2, # 'ъ' - 18: 3, # 'ы' - 17: 3, # 'ь' - 30: 1, # 'э' - 27: 2, # 'ю' - 16: 3, # 'я' - }, - 2: { # 'е' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 3, # 'б' - 10: 3, # 'в' - 19: 3, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 3, # 'ж' - 20: 3, # 'з' - 4: 2, # 'и' - 23: 3, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 3, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 2, # 'у' - 39: 2, # 'ф' - 26: 3, # 'х' - 28: 3, # 'ц' - 22: 3, # 'ч' - 25: 3, # 'ш' - 29: 3, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 1, # 'э' - 27: 2, # 'ю' - 16: 3, # 'я' - }, - 24: { # 'ж' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 2, # 'б' - 10: 1, # 'в' - 19: 2, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 2, # 'ж' - 20: 1, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 2, # 'к' - 8: 2, # 'л' - 12: 1, # 'м' - 5: 3, # 'н' - 1: 2, # 'о' - 15: 1, # 'п' - 9: 2, # 'р' - 7: 2, # 'с' - 6: 1, # 'т' - 14: 3, # 'у' - 39: 1, # 'ф' - 26: 0, # 'х' - 28: 1, # 'ц' - 22: 2, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 1, # 'ы' - 17: 2, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 1, # 'я' - }, - 20: { # 'з' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 3, # 'б' - 10: 3, # 'в' - 19: 3, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 2, # 'ж' - 20: 2, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 3, # 'р' - 7: 2, # 'с' - 6: 2, # 'т' - 14: 3, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 1, # 'ц' - 22: 2, # 'ч' - 25: 1, # 'ш' - 29: 0, # 'щ' - 54: 2, # 'ъ' - 18: 3, # 'ы' - 17: 2, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 3, # 'я' - }, - 4: { # 'и' - 37: 1, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 1, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 3, # 'б' - 10: 3, # 'в' - 19: 3, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 3, # 'ж' - 20: 3, # 'з' - 4: 3, # 'и' - 23: 3, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 3, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 2, # 'у' - 39: 2, # 'ф' - 26: 3, # 'х' - 28: 3, # 'ц' - 22: 3, # 'ч' - 25: 3, # 'ш' - 29: 3, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 2, # 'э' - 27: 3, # 'ю' - 16: 3, # 'я' - }, - 23: { # 'й' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 1, # 'а' - 21: 1, # 'б' - 10: 1, # 'в' - 19: 2, # 'г' - 13: 3, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 2, # 'з' - 4: 1, # 'и' - 23: 0, # 'й' - 11: 2, # 'к' - 8: 2, # 'л' - 12: 2, # 'м' - 5: 3, # 'н' - 1: 2, # 'о' - 15: 1, # 'п' - 9: 2, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 1, # 'у' - 39: 2, # 'ф' - 26: 1, # 'х' - 28: 2, # 'ц' - 22: 3, # 'ч' - 25: 2, # 'ш' - 29: 1, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 2, # 'я' - }, - 11: { # 'к' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 1, # 'б' - 10: 3, # 'в' - 19: 1, # 'г' - 13: 1, # 'д' - 2: 3, # 'е' - 24: 2, # 'ж' - 20: 2, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 2, # 'к' - 8: 3, # 'л' - 12: 1, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 3, # 'у' - 39: 1, # 'ф' - 26: 2, # 'х' - 28: 2, # 'ц' - 22: 1, # 'ч' - 25: 2, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 1, # 'ы' - 17: 1, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 1, # 'я' - }, - 8: { # 'л' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 2, # 'б' - 10: 2, # 'в' - 19: 3, # 'г' - 13: 2, # 'д' - 2: 3, # 'е' - 24: 3, # 'ж' - 20: 2, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 2, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 2, # 'п' - 9: 1, # 'р' - 7: 3, # 'с' - 6: 2, # 'т' - 14: 3, # 'у' - 39: 2, # 'ф' - 26: 2, # 'х' - 28: 1, # 'ц' - 22: 3, # 'ч' - 25: 2, # 'ш' - 29: 1, # 'щ' - 54: 0, # 'ъ' - 18: 3, # 'ы' - 17: 3, # 'ь' - 30: 1, # 'э' - 27: 3, # 'ю' - 16: 3, # 'я' - }, - 12: { # 'м' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 2, # 'б' - 10: 2, # 'в' - 19: 2, # 'г' - 13: 1, # 'д' - 2: 3, # 'е' - 24: 1, # 'ж' - 20: 1, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 2, # 'к' - 8: 3, # 'л' - 12: 2, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 2, # 'п' - 9: 2, # 'р' - 7: 3, # 'с' - 6: 2, # 'т' - 14: 3, # 'у' - 39: 2, # 'ф' - 26: 2, # 'х' - 28: 2, # 'ц' - 22: 2, # 'ч' - 25: 1, # 'ш' - 29: 1, # 'щ' - 54: 0, # 'ъ' - 18: 3, # 'ы' - 17: 2, # 'ь' - 30: 2, # 'э' - 27: 1, # 'ю' - 16: 3, # 'я' - }, - 5: { # 'н' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 2, # 'б' - 10: 2, # 'в' - 19: 3, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 2, # 'ж' - 20: 2, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 2, # 'л' - 12: 1, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 1, # 'п' - 9: 2, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 3, # 'у' - 39: 2, # 'ф' - 26: 2, # 'х' - 28: 3, # 'ц' - 22: 3, # 'ч' - 25: 2, # 'ш' - 29: 2, # 'щ' - 54: 1, # 'ъ' - 18: 3, # 'ы' - 17: 3, # 'ь' - 30: 1, # 'э' - 27: 3, # 'ю' - 16: 3, # 'я' - }, - 1: { # 'о' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 3, # 'б' - 10: 3, # 'в' - 19: 3, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 3, # 'ж' - 20: 3, # 'з' - 4: 3, # 'и' - 23: 3, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 3, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 2, # 'у' - 39: 2, # 'ф' - 26: 3, # 'х' - 28: 2, # 'ц' - 22: 3, # 'ч' - 25: 3, # 'ш' - 29: 3, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 2, # 'э' - 27: 3, # 'ю' - 16: 3, # 'я' - }, - 15: { # 'п' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 1, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 3, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 2, # 'к' - 8: 3, # 'л' - 12: 1, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 2, # 'п' - 9: 3, # 'р' - 7: 2, # 'с' - 6: 2, # 'т' - 14: 3, # 'у' - 39: 1, # 'ф' - 26: 0, # 'х' - 28: 2, # 'ц' - 22: 2, # 'ч' - 25: 1, # 'ш' - 29: 1, # 'щ' - 54: 0, # 'ъ' - 18: 3, # 'ы' - 17: 2, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 3, # 'я' - }, - 9: { # 'р' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 2, # 'б' - 10: 3, # 'в' - 19: 3, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 3, # 'ж' - 20: 2, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 2, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 2, # 'п' - 9: 2, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 3, # 'у' - 39: 2, # 'ф' - 26: 3, # 'х' - 28: 2, # 'ц' - 22: 2, # 'ч' - 25: 3, # 'ш' - 29: 2, # 'щ' - 54: 0, # 'ъ' - 18: 3, # 'ы' - 17: 3, # 'ь' - 30: 2, # 'э' - 27: 2, # 'ю' - 16: 3, # 'я' - }, - 7: { # 'с' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 1, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 2, # 'б' - 10: 3, # 'в' - 19: 2, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 2, # 'ж' - 20: 2, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 3, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 3, # 'у' - 39: 2, # 'ф' - 26: 3, # 'х' - 28: 2, # 'ц' - 22: 3, # 'ч' - 25: 2, # 'ш' - 29: 1, # 'щ' - 54: 2, # 'ъ' - 18: 3, # 'ы' - 17: 3, # 'ь' - 30: 2, # 'э' - 27: 3, # 'ю' - 16: 3, # 'я' - }, - 6: { # 'т' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 2, # 'б' - 10: 3, # 'в' - 19: 2, # 'г' - 13: 2, # 'д' - 2: 3, # 'е' - 24: 1, # 'ж' - 20: 1, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 2, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 2, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 2, # 'т' - 14: 3, # 'у' - 39: 2, # 'ф' - 26: 2, # 'х' - 28: 2, # 'ц' - 22: 2, # 'ч' - 25: 2, # 'ш' - 29: 2, # 'щ' - 54: 2, # 'ъ' - 18: 3, # 'ы' - 17: 3, # 'ь' - 30: 2, # 'э' - 27: 2, # 'ю' - 16: 3, # 'я' - }, - 14: { # 'у' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 3, # 'б' - 10: 3, # 'в' - 19: 3, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 3, # 'ж' - 20: 3, # 'з' - 4: 2, # 'и' - 23: 2, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 2, # 'о' - 15: 3, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 1, # 'у' - 39: 2, # 'ф' - 26: 3, # 'х' - 28: 2, # 'ц' - 22: 3, # 'ч' - 25: 3, # 'ш' - 29: 3, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 2, # 'э' - 27: 3, # 'ю' - 16: 2, # 'я' - }, - 39: { # 'ф' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 1, # 'б' - 10: 0, # 'в' - 19: 1, # 'г' - 13: 0, # 'д' - 2: 3, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 1, # 'к' - 8: 2, # 'л' - 12: 1, # 'м' - 5: 1, # 'н' - 1: 3, # 'о' - 15: 1, # 'п' - 9: 2, # 'р' - 7: 2, # 'с' - 6: 2, # 'т' - 14: 2, # 'у' - 39: 2, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 1, # 'ч' - 25: 1, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 2, # 'ы' - 17: 1, # 'ь' - 30: 2, # 'э' - 27: 1, # 'ю' - 16: 1, # 'я' - }, - 26: { # 'х' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 0, # 'б' - 10: 3, # 'в' - 19: 1, # 'г' - 13: 1, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 1, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 1, # 'к' - 8: 2, # 'л' - 12: 2, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 1, # 'п' - 9: 3, # 'р' - 7: 2, # 'с' - 6: 2, # 'т' - 14: 2, # 'у' - 39: 1, # 'ф' - 26: 1, # 'х' - 28: 1, # 'ц' - 22: 1, # 'ч' - 25: 2, # 'ш' - 29: 0, # 'щ' - 54: 1, # 'ъ' - 18: 0, # 'ы' - 17: 1, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 0, # 'я' - }, - 28: { # 'ц' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 1, # 'б' - 10: 2, # 'в' - 19: 1, # 'г' - 13: 1, # 'д' - 2: 3, # 'е' - 24: 0, # 'ж' - 20: 1, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 2, # 'к' - 8: 1, # 'л' - 12: 1, # 'м' - 5: 1, # 'н' - 1: 3, # 'о' - 15: 0, # 'п' - 9: 1, # 'р' - 7: 0, # 'с' - 6: 1, # 'т' - 14: 3, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 1, # 'ц' - 22: 0, # 'ч' - 25: 1, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 3, # 'ы' - 17: 1, # 'ь' - 30: 0, # 'э' - 27: 1, # 'ю' - 16: 0, # 'я' - }, - 22: { # 'ч' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 1, # 'б' - 10: 1, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 3, # 'е' - 24: 1, # 'ж' - 20: 0, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 2, # 'л' - 12: 1, # 'м' - 5: 3, # 'н' - 1: 2, # 'о' - 15: 0, # 'п' - 9: 2, # 'р' - 7: 1, # 'с' - 6: 3, # 'т' - 14: 3, # 'у' - 39: 1, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 1, # 'ч' - 25: 2, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 3, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 25: { # 'ш' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 1, # 'б' - 10: 2, # 'в' - 19: 1, # 'г' - 13: 0, # 'д' - 2: 3, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 2, # 'м' - 5: 3, # 'н' - 1: 3, # 'о' - 15: 2, # 'п' - 9: 2, # 'р' - 7: 1, # 'с' - 6: 2, # 'т' - 14: 3, # 'у' - 39: 2, # 'ф' - 26: 1, # 'х' - 28: 1, # 'ц' - 22: 1, # 'ч' - 25: 1, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 3, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 0, # 'я' - }, - 29: { # 'щ' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 3, # 'а' - 21: 0, # 'б' - 10: 1, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 3, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 3, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 0, # 'л' - 12: 1, # 'м' - 5: 2, # 'н' - 1: 1, # 'о' - 15: 0, # 'п' - 9: 2, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 2, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 2, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 0, # 'я' - }, - 54: { # 'ъ' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 0, # 'а' - 21: 0, # 'б' - 10: 0, # 'в' - 19: 0, # 'г' - 13: 0, # 'д' - 2: 2, # 'е' - 24: 0, # 'ж' - 20: 0, # 'з' - 4: 0, # 'и' - 23: 0, # 'й' - 11: 0, # 'к' - 8: 0, # 'л' - 12: 0, # 'м' - 5: 0, # 'н' - 1: 0, # 'о' - 15: 0, # 'п' - 9: 0, # 'р' - 7: 0, # 'с' - 6: 0, # 'т' - 14: 0, # 'у' - 39: 0, # 'ф' - 26: 0, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 0, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 1, # 'ю' - 16: 2, # 'я' - }, - 18: { # 'ы' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 0, # 'а' - 21: 3, # 'б' - 10: 3, # 'в' - 19: 2, # 'г' - 13: 2, # 'д' - 2: 3, # 'е' - 24: 2, # 'ж' - 20: 2, # 'з' - 4: 2, # 'и' - 23: 3, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 1, # 'о' - 15: 3, # 'п' - 9: 3, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 1, # 'у' - 39: 0, # 'ф' - 26: 3, # 'х' - 28: 2, # 'ц' - 22: 3, # 'ч' - 25: 3, # 'ш' - 29: 2, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 0, # 'ю' - 16: 2, # 'я' - }, - 17: { # 'ь' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 0, # 'а' - 21: 2, # 'б' - 10: 2, # 'в' - 19: 2, # 'г' - 13: 2, # 'д' - 2: 3, # 'е' - 24: 1, # 'ж' - 20: 3, # 'з' - 4: 2, # 'и' - 23: 0, # 'й' - 11: 3, # 'к' - 8: 0, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 2, # 'о' - 15: 2, # 'п' - 9: 1, # 'р' - 7: 3, # 'с' - 6: 2, # 'т' - 14: 0, # 'у' - 39: 2, # 'ф' - 26: 1, # 'х' - 28: 2, # 'ц' - 22: 2, # 'ч' - 25: 3, # 'ш' - 29: 2, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 1, # 'э' - 27: 3, # 'ю' - 16: 3, # 'я' - }, - 30: { # 'э' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 1, # 'М' - 31: 1, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 1, # 'Р' - 32: 1, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 1, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 0, # 'а' - 21: 1, # 'б' - 10: 1, # 'в' - 19: 1, # 'г' - 13: 2, # 'д' - 2: 1, # 'е' - 24: 0, # 'ж' - 20: 1, # 'з' - 4: 0, # 'и' - 23: 2, # 'й' - 11: 2, # 'к' - 8: 2, # 'л' - 12: 2, # 'м' - 5: 2, # 'н' - 1: 0, # 'о' - 15: 2, # 'п' - 9: 2, # 'р' - 7: 2, # 'с' - 6: 3, # 'т' - 14: 1, # 'у' - 39: 2, # 'ф' - 26: 1, # 'х' - 28: 0, # 'ц' - 22: 0, # 'ч' - 25: 1, # 'ш' - 29: 0, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 1, # 'э' - 27: 1, # 'ю' - 16: 1, # 'я' - }, - 27: { # 'ю' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 2, # 'а' - 21: 3, # 'б' - 10: 1, # 'в' - 19: 2, # 'г' - 13: 3, # 'д' - 2: 1, # 'е' - 24: 2, # 'ж' - 20: 2, # 'з' - 4: 1, # 'и' - 23: 1, # 'й' - 11: 2, # 'к' - 8: 2, # 'л' - 12: 2, # 'м' - 5: 2, # 'н' - 1: 1, # 'о' - 15: 2, # 'п' - 9: 2, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 0, # 'у' - 39: 1, # 'ф' - 26: 2, # 'х' - 28: 2, # 'ц' - 22: 2, # 'ч' - 25: 2, # 'ш' - 29: 3, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 1, # 'э' - 27: 2, # 'ю' - 16: 1, # 'я' - }, - 16: { # 'я' - 37: 0, # 'А' - 44: 0, # 'Б' - 33: 0, # 'В' - 46: 0, # 'Г' - 41: 0, # 'Д' - 48: 0, # 'Е' - 56: 0, # 'Ж' - 51: 0, # 'З' - 42: 0, # 'И' - 60: 0, # 'Й' - 36: 0, # 'К' - 49: 0, # 'Л' - 38: 0, # 'М' - 31: 0, # 'Н' - 34: 0, # 'О' - 35: 0, # 'П' - 45: 0, # 'Р' - 32: 0, # 'С' - 40: 0, # 'Т' - 52: 0, # 'У' - 53: 0, # 'Ф' - 55: 0, # 'Х' - 58: 0, # 'Ц' - 50: 0, # 'Ч' - 57: 0, # 'Ш' - 63: 0, # 'Щ' - 62: 0, # 'Ы' - 61: 0, # 'Ь' - 47: 0, # 'Э' - 59: 0, # 'Ю' - 43: 0, # 'Я' - 3: 0, # 'а' - 21: 2, # 'б' - 10: 3, # 'в' - 19: 2, # 'г' - 13: 3, # 'д' - 2: 3, # 'е' - 24: 3, # 'ж' - 20: 3, # 'з' - 4: 2, # 'и' - 23: 2, # 'й' - 11: 3, # 'к' - 8: 3, # 'л' - 12: 3, # 'м' - 5: 3, # 'н' - 1: 0, # 'о' - 15: 2, # 'п' - 9: 2, # 'р' - 7: 3, # 'с' - 6: 3, # 'т' - 14: 1, # 'у' - 39: 1, # 'ф' - 26: 3, # 'х' - 28: 2, # 'ц' - 22: 2, # 'ч' - 25: 2, # 'ш' - 29: 3, # 'щ' - 54: 0, # 'ъ' - 18: 0, # 'ы' - 17: 0, # 'ь' - 30: 0, # 'э' - 27: 2, # 'ю' - 16: 2, # 'я' - }, -} - -# 255: Undefined characters that did not exist in training text -# 254: Carriage/Return -# 253: symbol (punctuation) that does not belong to word -# 252: 0 - 9 -# 251: Control characters - -# Character Mapping Table(s): -IBM866_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 37, # 'А' - 129: 44, # 'Б' - 130: 33, # 'В' - 131: 46, # 'Г' - 132: 41, # 'Д' - 133: 48, # 'Е' - 134: 56, # 'Ж' - 135: 51, # 'З' - 136: 42, # 'И' - 137: 60, # 'Й' - 138: 36, # 'К' - 139: 49, # 'Л' - 140: 38, # 'М' - 141: 31, # 'Н' - 142: 34, # 'О' - 143: 35, # 'П' - 144: 45, # 'Р' - 145: 32, # 'С' - 146: 40, # 'Т' - 147: 52, # 'У' - 148: 53, # 'Ф' - 149: 55, # 'Х' - 150: 58, # 'Ц' - 151: 50, # 'Ч' - 152: 57, # 'Ш' - 153: 63, # 'Щ' - 154: 70, # 'Ъ' - 155: 62, # 'Ы' - 156: 61, # 'Ь' - 157: 47, # 'Э' - 158: 59, # 'Ю' - 159: 43, # 'Я' - 160: 3, # 'а' - 161: 21, # 'б' - 162: 10, # 'в' - 163: 19, # 'г' - 164: 13, # 'д' - 165: 2, # 'е' - 166: 24, # 'ж' - 167: 20, # 'з' - 168: 4, # 'и' - 169: 23, # 'й' - 170: 11, # 'к' - 171: 8, # 'л' - 172: 12, # 'м' - 173: 5, # 'н' - 174: 1, # 'о' - 175: 15, # 'п' - 176: 191, # '░' - 177: 192, # '▒' - 178: 193, # '▓' - 179: 194, # '│' - 180: 195, # '┤' - 181: 196, # '╡' - 182: 197, # '╢' - 183: 198, # '╖' - 184: 199, # '╕' - 185: 200, # '╣' - 186: 201, # '║' - 187: 202, # '╗' - 188: 203, # '╝' - 189: 204, # '╜' - 190: 205, # '╛' - 191: 206, # '┐' - 192: 207, # '└' - 193: 208, # '┴' - 194: 209, # '┬' - 195: 210, # '├' - 196: 211, # '─' - 197: 212, # '┼' - 198: 213, # '╞' - 199: 214, # '╟' - 200: 215, # '╚' - 201: 216, # '╔' - 202: 217, # '╩' - 203: 218, # '╦' - 204: 219, # '╠' - 205: 220, # '═' - 206: 221, # '╬' - 207: 222, # '╧' - 208: 223, # '╨' - 209: 224, # '╤' - 210: 225, # '╥' - 211: 226, # '╙' - 212: 227, # '╘' - 213: 228, # '╒' - 214: 229, # '╓' - 215: 230, # '╫' - 216: 231, # '╪' - 217: 232, # '┘' - 218: 233, # '┌' - 219: 234, # '█' - 220: 235, # '▄' - 221: 236, # '▌' - 222: 237, # '▐' - 223: 238, # '▀' - 224: 9, # 'р' - 225: 7, # 'с' - 226: 6, # 'т' - 227: 14, # 'у' - 228: 39, # 'ф' - 229: 26, # 'х' - 230: 28, # 'ц' - 231: 22, # 'ч' - 232: 25, # 'ш' - 233: 29, # 'щ' - 234: 54, # 'ъ' - 235: 18, # 'ы' - 236: 17, # 'ь' - 237: 30, # 'э' - 238: 27, # 'ю' - 239: 16, # 'я' - 240: 239, # 'Ё' - 241: 68, # 'ё' - 242: 240, # 'Є' - 243: 241, # 'є' - 244: 242, # 'Ї' - 245: 243, # 'ї' - 246: 244, # 'Ў' - 247: 245, # 'ў' - 248: 246, # '°' - 249: 247, # '∙' - 250: 248, # '·' - 251: 249, # '√' - 252: 250, # '№' - 253: 251, # '¤' - 254: 252, # '■' - 255: 255, # '\xa0' -} - -IBM866_RUSSIAN_MODEL = SingleByteCharSetModel( - charset_name="IBM866", - language="Russian", - char_to_order_map=IBM866_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", -) - -WINDOWS_1251_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 191, # 'Ђ' - 129: 192, # 'Ѓ' - 130: 193, # '‚' - 131: 194, # 'ѓ' - 132: 195, # '„' - 133: 196, # '…' - 134: 197, # '†' - 135: 198, # '‡' - 136: 199, # '€' - 137: 200, # '‰' - 138: 201, # 'Љ' - 139: 202, # '‹' - 140: 203, # 'Њ' - 141: 204, # 'Ќ' - 142: 205, # 'Ћ' - 143: 206, # 'Џ' - 144: 207, # 'ђ' - 145: 208, # '‘' - 146: 209, # '’' - 147: 210, # '“' - 148: 211, # '”' - 149: 212, # '•' - 150: 213, # '–' - 151: 214, # '—' - 152: 215, # None - 153: 216, # '™' - 154: 217, # 'љ' - 155: 218, # '›' - 156: 219, # 'њ' - 157: 220, # 'ќ' - 158: 221, # 'ћ' - 159: 222, # 'џ' - 160: 223, # '\xa0' - 161: 224, # 'Ў' - 162: 225, # 'ў' - 163: 226, # 'Ј' - 164: 227, # '¤' - 165: 228, # 'Ґ' - 166: 229, # '¦' - 167: 230, # '§' - 168: 231, # 'Ё' - 169: 232, # '©' - 170: 233, # 'Є' - 171: 234, # '«' - 172: 235, # '¬' - 173: 236, # '\xad' - 174: 237, # '®' - 175: 238, # 'Ї' - 176: 239, # '°' - 177: 240, # '±' - 178: 241, # 'І' - 179: 242, # 'і' - 180: 243, # 'ґ' - 181: 244, # 'µ' - 182: 245, # '¶' - 183: 246, # '·' - 184: 68, # 'ё' - 185: 247, # '№' - 186: 248, # 'є' - 187: 249, # '»' - 188: 250, # 'ј' - 189: 251, # 'Ѕ' - 190: 252, # 'ѕ' - 191: 253, # 'ї' - 192: 37, # 'А' - 193: 44, # 'Б' - 194: 33, # 'В' - 195: 46, # 'Г' - 196: 41, # 'Д' - 197: 48, # 'Е' - 198: 56, # 'Ж' - 199: 51, # 'З' - 200: 42, # 'И' - 201: 60, # 'Й' - 202: 36, # 'К' - 203: 49, # 'Л' - 204: 38, # 'М' - 205: 31, # 'Н' - 206: 34, # 'О' - 207: 35, # 'П' - 208: 45, # 'Р' - 209: 32, # 'С' - 210: 40, # 'Т' - 211: 52, # 'У' - 212: 53, # 'Ф' - 213: 55, # 'Х' - 214: 58, # 'Ц' - 215: 50, # 'Ч' - 216: 57, # 'Ш' - 217: 63, # 'Щ' - 218: 70, # 'Ъ' - 219: 62, # 'Ы' - 220: 61, # 'Ь' - 221: 47, # 'Э' - 222: 59, # 'Ю' - 223: 43, # 'Я' - 224: 3, # 'а' - 225: 21, # 'б' - 226: 10, # 'в' - 227: 19, # 'г' - 228: 13, # 'д' - 229: 2, # 'е' - 230: 24, # 'ж' - 231: 20, # 'з' - 232: 4, # 'и' - 233: 23, # 'й' - 234: 11, # 'к' - 235: 8, # 'л' - 236: 12, # 'м' - 237: 5, # 'н' - 238: 1, # 'о' - 239: 15, # 'п' - 240: 9, # 'р' - 241: 7, # 'с' - 242: 6, # 'т' - 243: 14, # 'у' - 244: 39, # 'ф' - 245: 26, # 'х' - 246: 28, # 'ц' - 247: 22, # 'ч' - 248: 25, # 'ш' - 249: 29, # 'щ' - 250: 54, # 'ъ' - 251: 18, # 'ы' - 252: 17, # 'ь' - 253: 30, # 'э' - 254: 27, # 'ю' - 255: 16, # 'я' -} - -WINDOWS_1251_RUSSIAN_MODEL = SingleByteCharSetModel( - charset_name="windows-1251", - language="Russian", - char_to_order_map=WINDOWS_1251_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", -) - -IBM855_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 191, # 'ђ' - 129: 192, # 'Ђ' - 130: 193, # 'ѓ' - 131: 194, # 'Ѓ' - 132: 68, # 'ё' - 133: 195, # 'Ё' - 134: 196, # 'є' - 135: 197, # 'Є' - 136: 198, # 'ѕ' - 137: 199, # 'Ѕ' - 138: 200, # 'і' - 139: 201, # 'І' - 140: 202, # 'ї' - 141: 203, # 'Ї' - 142: 204, # 'ј' - 143: 205, # 'Ј' - 144: 206, # 'љ' - 145: 207, # 'Љ' - 146: 208, # 'њ' - 147: 209, # 'Њ' - 148: 210, # 'ћ' - 149: 211, # 'Ћ' - 150: 212, # 'ќ' - 151: 213, # 'Ќ' - 152: 214, # 'ў' - 153: 215, # 'Ў' - 154: 216, # 'џ' - 155: 217, # 'Џ' - 156: 27, # 'ю' - 157: 59, # 'Ю' - 158: 54, # 'ъ' - 159: 70, # 'Ъ' - 160: 3, # 'а' - 161: 37, # 'А' - 162: 21, # 'б' - 163: 44, # 'Б' - 164: 28, # 'ц' - 165: 58, # 'Ц' - 166: 13, # 'д' - 167: 41, # 'Д' - 168: 2, # 'е' - 169: 48, # 'Е' - 170: 39, # 'ф' - 171: 53, # 'Ф' - 172: 19, # 'г' - 173: 46, # 'Г' - 174: 218, # '«' - 175: 219, # '»' - 176: 220, # '░' - 177: 221, # '▒' - 178: 222, # '▓' - 179: 223, # '│' - 180: 224, # '┤' - 181: 26, # 'х' - 182: 55, # 'Х' - 183: 4, # 'и' - 184: 42, # 'И' - 185: 225, # '╣' - 186: 226, # '║' - 187: 227, # '╗' - 188: 228, # '╝' - 189: 23, # 'й' - 190: 60, # 'Й' - 191: 229, # '┐' - 192: 230, # '└' - 193: 231, # '┴' - 194: 232, # '┬' - 195: 233, # '├' - 196: 234, # '─' - 197: 235, # '┼' - 198: 11, # 'к' - 199: 36, # 'К' - 200: 236, # '╚' - 201: 237, # '╔' - 202: 238, # '╩' - 203: 239, # '╦' - 204: 240, # '╠' - 205: 241, # '═' - 206: 242, # '╬' - 207: 243, # '¤' - 208: 8, # 'л' - 209: 49, # 'Л' - 210: 12, # 'м' - 211: 38, # 'М' - 212: 5, # 'н' - 213: 31, # 'Н' - 214: 1, # 'о' - 215: 34, # 'О' - 216: 15, # 'п' - 217: 244, # '┘' - 218: 245, # '┌' - 219: 246, # '█' - 220: 247, # '▄' - 221: 35, # 'П' - 222: 16, # 'я' - 223: 248, # '▀' - 224: 43, # 'Я' - 225: 9, # 'р' - 226: 45, # 'Р' - 227: 7, # 'с' - 228: 32, # 'С' - 229: 6, # 'т' - 230: 40, # 'Т' - 231: 14, # 'у' - 232: 52, # 'У' - 233: 24, # 'ж' - 234: 56, # 'Ж' - 235: 10, # 'в' - 236: 33, # 'В' - 237: 17, # 'ь' - 238: 61, # 'Ь' - 239: 249, # '№' - 240: 250, # '\xad' - 241: 18, # 'ы' - 242: 62, # 'Ы' - 243: 20, # 'з' - 244: 51, # 'З' - 245: 25, # 'ш' - 246: 57, # 'Ш' - 247: 30, # 'э' - 248: 47, # 'Э' - 249: 29, # 'щ' - 250: 63, # 'Щ' - 251: 22, # 'ч' - 252: 50, # 'Ч' - 253: 251, # '§' - 254: 252, # '■' - 255: 255, # '\xa0' -} - -IBM855_RUSSIAN_MODEL = SingleByteCharSetModel( - charset_name="IBM855", - language="Russian", - char_to_order_map=IBM855_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", -) - -KOI8_R_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 191, # '─' - 129: 192, # '│' - 130: 193, # '┌' - 131: 194, # '┐' - 132: 195, # '└' - 133: 196, # '┘' - 134: 197, # '├' - 135: 198, # '┤' - 136: 199, # '┬' - 137: 200, # '┴' - 138: 201, # '┼' - 139: 202, # '▀' - 140: 203, # '▄' - 141: 204, # '█' - 142: 205, # '▌' - 143: 206, # '▐' - 144: 207, # '░' - 145: 208, # '▒' - 146: 209, # '▓' - 147: 210, # '⌠' - 148: 211, # '■' - 149: 212, # '∙' - 150: 213, # '√' - 151: 214, # '≈' - 152: 215, # '≤' - 153: 216, # '≥' - 154: 217, # '\xa0' - 155: 218, # '⌡' - 156: 219, # '°' - 157: 220, # '²' - 158: 221, # '·' - 159: 222, # '÷' - 160: 223, # '═' - 161: 224, # '║' - 162: 225, # '╒' - 163: 68, # 'ё' - 164: 226, # '╓' - 165: 227, # '╔' - 166: 228, # '╕' - 167: 229, # '╖' - 168: 230, # '╗' - 169: 231, # '╘' - 170: 232, # '╙' - 171: 233, # '╚' - 172: 234, # '╛' - 173: 235, # '╜' - 174: 236, # '╝' - 175: 237, # '╞' - 176: 238, # '╟' - 177: 239, # '╠' - 178: 240, # '╡' - 179: 241, # 'Ё' - 180: 242, # '╢' - 181: 243, # '╣' - 182: 244, # '╤' - 183: 245, # '╥' - 184: 246, # '╦' - 185: 247, # '╧' - 186: 248, # '╨' - 187: 249, # '╩' - 188: 250, # '╪' - 189: 251, # '╫' - 190: 252, # '╬' - 191: 253, # '©' - 192: 27, # 'ю' - 193: 3, # 'а' - 194: 21, # 'б' - 195: 28, # 'ц' - 196: 13, # 'д' - 197: 2, # 'е' - 198: 39, # 'ф' - 199: 19, # 'г' - 200: 26, # 'х' - 201: 4, # 'и' - 202: 23, # 'й' - 203: 11, # 'к' - 204: 8, # 'л' - 205: 12, # 'м' - 206: 5, # 'н' - 207: 1, # 'о' - 208: 15, # 'п' - 209: 16, # 'я' - 210: 9, # 'р' - 211: 7, # 'с' - 212: 6, # 'т' - 213: 14, # 'у' - 214: 24, # 'ж' - 215: 10, # 'в' - 216: 17, # 'ь' - 217: 18, # 'ы' - 218: 20, # 'з' - 219: 25, # 'ш' - 220: 30, # 'э' - 221: 29, # 'щ' - 222: 22, # 'ч' - 223: 54, # 'ъ' - 224: 59, # 'Ю' - 225: 37, # 'А' - 226: 44, # 'Б' - 227: 58, # 'Ц' - 228: 41, # 'Д' - 229: 48, # 'Е' - 230: 53, # 'Ф' - 231: 46, # 'Г' - 232: 55, # 'Х' - 233: 42, # 'И' - 234: 60, # 'Й' - 235: 36, # 'К' - 236: 49, # 'Л' - 237: 38, # 'М' - 238: 31, # 'Н' - 239: 34, # 'О' - 240: 35, # 'П' - 241: 43, # 'Я' - 242: 45, # 'Р' - 243: 32, # 'С' - 244: 40, # 'Т' - 245: 52, # 'У' - 246: 56, # 'Ж' - 247: 33, # 'В' - 248: 61, # 'Ь' - 249: 62, # 'Ы' - 250: 51, # 'З' - 251: 57, # 'Ш' - 252: 47, # 'Э' - 253: 63, # 'Щ' - 254: 50, # 'Ч' - 255: 70, # 'Ъ' -} - -KOI8_R_RUSSIAN_MODEL = SingleByteCharSetModel( - charset_name="KOI8-R", - language="Russian", - char_to_order_map=KOI8_R_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", -) - -MACCYRILLIC_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 37, # 'А' - 129: 44, # 'Б' - 130: 33, # 'В' - 131: 46, # 'Г' - 132: 41, # 'Д' - 133: 48, # 'Е' - 134: 56, # 'Ж' - 135: 51, # 'З' - 136: 42, # 'И' - 137: 60, # 'Й' - 138: 36, # 'К' - 139: 49, # 'Л' - 140: 38, # 'М' - 141: 31, # 'Н' - 142: 34, # 'О' - 143: 35, # 'П' - 144: 45, # 'Р' - 145: 32, # 'С' - 146: 40, # 'Т' - 147: 52, # 'У' - 148: 53, # 'Ф' - 149: 55, # 'Х' - 150: 58, # 'Ц' - 151: 50, # 'Ч' - 152: 57, # 'Ш' - 153: 63, # 'Щ' - 154: 70, # 'Ъ' - 155: 62, # 'Ы' - 156: 61, # 'Ь' - 157: 47, # 'Э' - 158: 59, # 'Ю' - 159: 43, # 'Я' - 160: 191, # '†' - 161: 192, # '°' - 162: 193, # 'Ґ' - 163: 194, # '£' - 164: 195, # '§' - 165: 196, # '•' - 166: 197, # '¶' - 167: 198, # 'І' - 168: 199, # '®' - 169: 200, # '©' - 170: 201, # '™' - 171: 202, # 'Ђ' - 172: 203, # 'ђ' - 173: 204, # '≠' - 174: 205, # 'Ѓ' - 175: 206, # 'ѓ' - 176: 207, # '∞' - 177: 208, # '±' - 178: 209, # '≤' - 179: 210, # '≥' - 180: 211, # 'і' - 181: 212, # 'µ' - 182: 213, # 'ґ' - 183: 214, # 'Ј' - 184: 215, # 'Є' - 185: 216, # 'є' - 186: 217, # 'Ї' - 187: 218, # 'ї' - 188: 219, # 'Љ' - 189: 220, # 'љ' - 190: 221, # 'Њ' - 191: 222, # 'њ' - 192: 223, # 'ј' - 193: 224, # 'Ѕ' - 194: 225, # '¬' - 195: 226, # '√' - 196: 227, # 'ƒ' - 197: 228, # '≈' - 198: 229, # '∆' - 199: 230, # '«' - 200: 231, # '»' - 201: 232, # '…' - 202: 233, # '\xa0' - 203: 234, # 'Ћ' - 204: 235, # 'ћ' - 205: 236, # 'Ќ' - 206: 237, # 'ќ' - 207: 238, # 'ѕ' - 208: 239, # '–' - 209: 240, # '—' - 210: 241, # '“' - 211: 242, # '”' - 212: 243, # '‘' - 213: 244, # '’' - 214: 245, # '÷' - 215: 246, # '„' - 216: 247, # 'Ў' - 217: 248, # 'ў' - 218: 249, # 'Џ' - 219: 250, # 'џ' - 220: 251, # '№' - 221: 252, # 'Ё' - 222: 68, # 'ё' - 223: 16, # 'я' - 224: 3, # 'а' - 225: 21, # 'б' - 226: 10, # 'в' - 227: 19, # 'г' - 228: 13, # 'д' - 229: 2, # 'е' - 230: 24, # 'ж' - 231: 20, # 'з' - 232: 4, # 'и' - 233: 23, # 'й' - 234: 11, # 'к' - 235: 8, # 'л' - 236: 12, # 'м' - 237: 5, # 'н' - 238: 1, # 'о' - 239: 15, # 'п' - 240: 9, # 'р' - 241: 7, # 'с' - 242: 6, # 'т' - 243: 14, # 'у' - 244: 39, # 'ф' - 245: 26, # 'х' - 246: 28, # 'ц' - 247: 22, # 'ч' - 248: 25, # 'ш' - 249: 29, # 'щ' - 250: 54, # 'ъ' - 251: 18, # 'ы' - 252: 17, # 'ь' - 253: 30, # 'э' - 254: 27, # 'ю' - 255: 255, # '€' -} - -MACCYRILLIC_RUSSIAN_MODEL = SingleByteCharSetModel( - charset_name="MacCyrillic", - language="Russian", - char_to_order_map=MACCYRILLIC_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", -) - -ISO_8859_5_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 191, # '\x80' - 129: 192, # '\x81' - 130: 193, # '\x82' - 131: 194, # '\x83' - 132: 195, # '\x84' - 133: 196, # '\x85' - 134: 197, # '\x86' - 135: 198, # '\x87' - 136: 199, # '\x88' - 137: 200, # '\x89' - 138: 201, # '\x8a' - 139: 202, # '\x8b' - 140: 203, # '\x8c' - 141: 204, # '\x8d' - 142: 205, # '\x8e' - 143: 206, # '\x8f' - 144: 207, # '\x90' - 145: 208, # '\x91' - 146: 209, # '\x92' - 147: 210, # '\x93' - 148: 211, # '\x94' - 149: 212, # '\x95' - 150: 213, # '\x96' - 151: 214, # '\x97' - 152: 215, # '\x98' - 153: 216, # '\x99' - 154: 217, # '\x9a' - 155: 218, # '\x9b' - 156: 219, # '\x9c' - 157: 220, # '\x9d' - 158: 221, # '\x9e' - 159: 222, # '\x9f' - 160: 223, # '\xa0' - 161: 224, # 'Ё' - 162: 225, # 'Ђ' - 163: 226, # 'Ѓ' - 164: 227, # 'Є' - 165: 228, # 'Ѕ' - 166: 229, # 'І' - 167: 230, # 'Ї' - 168: 231, # 'Ј' - 169: 232, # 'Љ' - 170: 233, # 'Њ' - 171: 234, # 'Ћ' - 172: 235, # 'Ќ' - 173: 236, # '\xad' - 174: 237, # 'Ў' - 175: 238, # 'Џ' - 176: 37, # 'А' - 177: 44, # 'Б' - 178: 33, # 'В' - 179: 46, # 'Г' - 180: 41, # 'Д' - 181: 48, # 'Е' - 182: 56, # 'Ж' - 183: 51, # 'З' - 184: 42, # 'И' - 185: 60, # 'Й' - 186: 36, # 'К' - 187: 49, # 'Л' - 188: 38, # 'М' - 189: 31, # 'Н' - 190: 34, # 'О' - 191: 35, # 'П' - 192: 45, # 'Р' - 193: 32, # 'С' - 194: 40, # 'Т' - 195: 52, # 'У' - 196: 53, # 'Ф' - 197: 55, # 'Х' - 198: 58, # 'Ц' - 199: 50, # 'Ч' - 200: 57, # 'Ш' - 201: 63, # 'Щ' - 202: 70, # 'Ъ' - 203: 62, # 'Ы' - 204: 61, # 'Ь' - 205: 47, # 'Э' - 206: 59, # 'Ю' - 207: 43, # 'Я' - 208: 3, # 'а' - 209: 21, # 'б' - 210: 10, # 'в' - 211: 19, # 'г' - 212: 13, # 'д' - 213: 2, # 'е' - 214: 24, # 'ж' - 215: 20, # 'з' - 216: 4, # 'и' - 217: 23, # 'й' - 218: 11, # 'к' - 219: 8, # 'л' - 220: 12, # 'м' - 221: 5, # 'н' - 222: 1, # 'о' - 223: 15, # 'п' - 224: 9, # 'р' - 225: 7, # 'с' - 226: 6, # 'т' - 227: 14, # 'у' - 228: 39, # 'ф' - 229: 26, # 'х' - 230: 28, # 'ц' - 231: 22, # 'ч' - 232: 25, # 'ш' - 233: 29, # 'щ' - 234: 54, # 'ъ' - 235: 18, # 'ы' - 236: 17, # 'ь' - 237: 30, # 'э' - 238: 27, # 'ю' - 239: 16, # 'я' - 240: 239, # '№' - 241: 68, # 'ё' - 242: 240, # 'ђ' - 243: 241, # 'ѓ' - 244: 242, # 'є' - 245: 243, # 'ѕ' - 246: 244, # 'і' - 247: 245, # 'ї' - 248: 246, # 'ј' - 249: 247, # 'љ' - 250: 248, # 'њ' - 251: 249, # 'ћ' - 252: 250, # 'ќ' - 253: 251, # '§' - 254: 252, # 'ў' - 255: 255, # 'џ' -} - -ISO_8859_5_RUSSIAN_MODEL = SingleByteCharSetModel( - charset_name="ISO-8859-5", - language="Russian", - char_to_order_map=ISO_8859_5_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", -) diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py b/myenv/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py deleted file mode 100644 index 489cad9..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py +++ /dev/null @@ -1,4380 +0,0 @@ -from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - -# 3: Positive -# 2: Likely -# 1: Unlikely -# 0: Negative - -THAI_LANG_MODEL = { - 5: { # 'ก' - 5: 2, # 'ก' - 30: 2, # 'ข' - 24: 2, # 'ค' - 8: 2, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 3, # 'ฎ' - 57: 2, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 2, # 'ณ' - 20: 2, # 'ด' - 19: 3, # 'ต' - 44: 0, # 'ถ' - 14: 2, # 'ท' - 48: 0, # 'ธ' - 3: 2, # 'น' - 17: 1, # 'บ' - 25: 2, # 'ป' - 39: 1, # 'ผ' - 62: 1, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 1, # 'ภ' - 9: 2, # 'ม' - 16: 1, # 'ย' - 2: 3, # 'ร' - 61: 2, # 'ฤ' - 15: 3, # 'ล' - 12: 3, # 'ว' - 42: 2, # 'ศ' - 46: 3, # 'ษ' - 18: 2, # 'ส' - 21: 2, # 'ห' - 4: 3, # 'อ' - 63: 1, # 'ฯ' - 22: 2, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 3, # 'ำ' - 23: 3, # 'ิ' - 13: 3, # 'ี' - 40: 0, # 'ึ' - 27: 2, # 'ื' - 32: 2, # 'ุ' - 35: 1, # 'ู' - 11: 2, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 1, # 'ใ' - 33: 2, # 'ไ' - 50: 1, # 'ๆ' - 37: 3, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 2, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 30: { # 'ข' - 5: 1, # 'ก' - 30: 0, # 'ข' - 24: 1, # 'ค' - 8: 1, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 2, # 'ณ' - 20: 0, # 'ด' - 19: 2, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 2, # 'น' - 17: 1, # 'บ' - 25: 1, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 2, # 'ย' - 2: 1, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 2, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 1, # 'ห' - 4: 3, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 2, # 'ี' - 40: 3, # 'ึ' - 27: 1, # 'ื' - 32: 1, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 1, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 1, # '็' - 6: 2, # '่' - 7: 3, # '้' - 38: 1, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 24: { # 'ค' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 2, # 'ค' - 8: 2, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 2, # 'ณ' - 20: 2, # 'ด' - 19: 2, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 0, # 'บ' - 25: 1, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 2, # 'ม' - 16: 2, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 3, # 'ล' - 12: 3, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 0, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 2, # 'ะ' - 10: 3, # 'ั' - 1: 2, # 'า' - 36: 3, # 'ำ' - 23: 3, # 'ิ' - 13: 2, # 'ี' - 40: 0, # 'ึ' - 27: 3, # 'ื' - 32: 3, # 'ุ' - 35: 2, # 'ู' - 11: 1, # 'เ' - 28: 0, # 'แ' - 41: 3, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 1, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 3, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 8: { # 'ง' - 5: 3, # 'ก' - 30: 2, # 'ข' - 24: 3, # 'ค' - 8: 2, # 'ง' - 26: 2, # 'จ' - 52: 1, # 'ฉ' - 34: 2, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 2, # 'ด' - 19: 2, # 'ต' - 44: 1, # 'ถ' - 14: 3, # 'ท' - 48: 1, # 'ธ' - 3: 3, # 'น' - 17: 2, # 'บ' - 25: 2, # 'ป' - 39: 2, # 'ผ' - 62: 1, # 'ฝ' - 31: 2, # 'พ' - 54: 0, # 'ฟ' - 45: 1, # 'ภ' - 9: 2, # 'ม' - 16: 1, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 2, # 'ว' - 42: 2, # 'ศ' - 46: 1, # 'ษ' - 18: 3, # 'ส' - 21: 3, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 1, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 2, # 'ิ' - 13: 1, # 'ี' - 40: 0, # 'ึ' - 27: 1, # 'ื' - 32: 1, # 'ุ' - 35: 0, # 'ู' - 11: 3, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 3, # 'ๆ' - 37: 0, # '็' - 6: 2, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 26: { # 'จ' - 5: 2, # 'ก' - 30: 1, # 'ข' - 24: 0, # 'ค' - 8: 2, # 'ง' - 26: 3, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 2, # 'ด' - 19: 1, # 'ต' - 44: 1, # 'ถ' - 14: 2, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 1, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 1, # 'ม' - 16: 1, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 1, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 3, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 3, # 'ำ' - 23: 2, # 'ิ' - 13: 1, # 'ี' - 40: 3, # 'ึ' - 27: 1, # 'ื' - 32: 3, # 'ุ' - 35: 2, # 'ู' - 11: 1, # 'เ' - 28: 1, # 'แ' - 41: 0, # 'โ' - 29: 1, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 2, # '่' - 7: 2, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 52: { # 'ฉ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 3, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 3, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 1, # 'ม' - 16: 1, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 1, # 'ะ' - 10: 1, # 'ั' - 1: 1, # 'า' - 36: 0, # 'ำ' - 23: 1, # 'ิ' - 13: 1, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 1, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 34: { # 'ช' - 5: 1, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 1, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 1, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 2, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 2, # 'ม' - 16: 1, # 'ย' - 2: 1, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 2, # 'ั' - 1: 3, # 'า' - 36: 1, # 'ำ' - 23: 3, # 'ิ' - 13: 2, # 'ี' - 40: 0, # 'ึ' - 27: 3, # 'ื' - 32: 3, # 'ุ' - 35: 1, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 1, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 51: { # 'ซ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 1, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 1, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 0, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 1, # 'ั' - 1: 1, # 'า' - 36: 0, # 'ำ' - 23: 1, # 'ิ' - 13: 2, # 'ี' - 40: 3, # 'ึ' - 27: 2, # 'ื' - 32: 1, # 'ุ' - 35: 1, # 'ู' - 11: 1, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 1, # '็' - 6: 1, # '่' - 7: 2, # '้' - 38: 1, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 47: { # 'ญ' - 5: 1, # 'ก' - 30: 1, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 3, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 1, # 'บ' - 25: 1, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 1, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 1, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 2, # 'ห' - 4: 1, # 'อ' - 63: 0, # 'ฯ' - 22: 1, # 'ะ' - 10: 2, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 1, # 'ิ' - 13: 1, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 1, # 'เ' - 28: 1, # 'แ' - 41: 0, # 'โ' - 29: 1, # 'ใ' - 33: 0, # 'ไ' - 50: 1, # 'ๆ' - 37: 0, # '็' - 6: 2, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 58: { # 'ฎ' - 5: 2, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 1, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 1, # 'ิ' - 13: 2, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 57: { # 'ฏ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 3, # 'ิ' - 13: 1, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 49: { # 'ฐ' - 5: 1, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 2, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 2, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 1, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 1, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 1, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 53: { # 'ฑ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 2, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 3, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 55: { # 'ฒ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 1, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 43: { # 'ณ' - 5: 1, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 3, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 3, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 1, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 1, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 3, # 'ะ' - 10: 0, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 1, # 'ิ' - 13: 2, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 1, # 'เ' - 28: 1, # 'แ' - 41: 0, # 'โ' - 29: 1, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 3, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 20: { # 'ด' - 5: 2, # 'ก' - 30: 2, # 'ข' - 24: 2, # 'ค' - 8: 3, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 2, # 'ต' - 44: 1, # 'ถ' - 14: 2, # 'ท' - 48: 0, # 'ธ' - 3: 1, # 'น' - 17: 1, # 'บ' - 25: 1, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 1, # 'ภ' - 9: 2, # 'ม' - 16: 3, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 2, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 2, # 'ห' - 4: 1, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 3, # 'ั' - 1: 2, # 'า' - 36: 2, # 'ำ' - 23: 3, # 'ิ' - 13: 3, # 'ี' - 40: 1, # 'ึ' - 27: 2, # 'ื' - 32: 3, # 'ุ' - 35: 2, # 'ู' - 11: 2, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 2, # 'ๆ' - 37: 2, # '็' - 6: 1, # '่' - 7: 3, # '้' - 38: 1, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 19: { # 'ต' - 5: 2, # 'ก' - 30: 1, # 'ข' - 24: 1, # 'ค' - 8: 0, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 1, # 'ต' - 44: 2, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 2, # 'น' - 17: 1, # 'บ' - 25: 1, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 2, # 'ภ' - 9: 1, # 'ม' - 16: 1, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 3, # 'ส' - 21: 0, # 'ห' - 4: 3, # 'อ' - 63: 1, # 'ฯ' - 22: 2, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 2, # 'ำ' - 23: 3, # 'ิ' - 13: 2, # 'ี' - 40: 1, # 'ึ' - 27: 1, # 'ื' - 32: 3, # 'ุ' - 35: 2, # 'ู' - 11: 1, # 'เ' - 28: 1, # 'แ' - 41: 1, # 'โ' - 29: 1, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 2, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 2, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 44: { # 'ถ' - 5: 1, # 'ก' - 30: 0, # 'ข' - 24: 1, # 'ค' - 8: 0, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 1, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 1, # 'น' - 17: 2, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 1, # 'ร' - 61: 0, # 'ฤ' - 15: 1, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 0, # 'ห' - 4: 1, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 2, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 2, # 'ิ' - 13: 1, # 'ี' - 40: 3, # 'ึ' - 27: 2, # 'ื' - 32: 2, # 'ุ' - 35: 3, # 'ู' - 11: 1, # 'เ' - 28: 1, # 'แ' - 41: 0, # 'โ' - 29: 1, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 2, # '่' - 7: 3, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 14: { # 'ท' - 5: 1, # 'ก' - 30: 1, # 'ข' - 24: 3, # 'ค' - 8: 1, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 2, # 'ด' - 19: 1, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 3, # 'ธ' - 3: 3, # 'น' - 17: 2, # 'บ' - 25: 2, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 2, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 1, # 'ม' - 16: 3, # 'ย' - 2: 3, # 'ร' - 61: 1, # 'ฤ' - 15: 1, # 'ล' - 12: 2, # 'ว' - 42: 3, # 'ศ' - 46: 1, # 'ษ' - 18: 1, # 'ส' - 21: 0, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 2, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 3, # 'ำ' - 23: 2, # 'ิ' - 13: 3, # 'ี' - 40: 2, # 'ึ' - 27: 1, # 'ื' - 32: 3, # 'ุ' - 35: 1, # 'ู' - 11: 0, # 'เ' - 28: 1, # 'แ' - 41: 0, # 'โ' - 29: 1, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 1, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 2, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 48: { # 'ธ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 1, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 1, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 2, # 'า' - 36: 0, # 'ำ' - 23: 3, # 'ิ' - 13: 3, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 2, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 3, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 3: { # 'น' - 5: 3, # 'ก' - 30: 2, # 'ข' - 24: 3, # 'ค' - 8: 1, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 1, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 3, # 'ด' - 19: 3, # 'ต' - 44: 2, # 'ถ' - 14: 3, # 'ท' - 48: 3, # 'ธ' - 3: 2, # 'น' - 17: 2, # 'บ' - 25: 2, # 'ป' - 39: 2, # 'ผ' - 62: 0, # 'ฝ' - 31: 2, # 'พ' - 54: 1, # 'ฟ' - 45: 1, # 'ภ' - 9: 2, # 'ม' - 16: 2, # 'ย' - 2: 2, # 'ร' - 61: 1, # 'ฤ' - 15: 2, # 'ล' - 12: 3, # 'ว' - 42: 1, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 2, # 'ห' - 4: 3, # 'อ' - 63: 1, # 'ฯ' - 22: 2, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 3, # 'ำ' - 23: 3, # 'ิ' - 13: 3, # 'ี' - 40: 3, # 'ึ' - 27: 3, # 'ื' - 32: 3, # 'ุ' - 35: 2, # 'ู' - 11: 3, # 'เ' - 28: 2, # 'แ' - 41: 3, # 'โ' - 29: 3, # 'ใ' - 33: 3, # 'ไ' - 50: 2, # 'ๆ' - 37: 1, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 2, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 17: { # 'บ' - 5: 3, # 'ก' - 30: 2, # 'ข' - 24: 2, # 'ค' - 8: 1, # 'ง' - 26: 1, # 'จ' - 52: 1, # 'ฉ' - 34: 1, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 2, # 'ต' - 44: 1, # 'ถ' - 14: 3, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 3, # 'บ' - 25: 2, # 'ป' - 39: 2, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 1, # 'ฟ' - 45: 1, # 'ภ' - 9: 1, # 'ม' - 16: 0, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 3, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 2, # 'ห' - 4: 2, # 'อ' - 63: 1, # 'ฯ' - 22: 0, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 2, # 'ำ' - 23: 2, # 'ิ' - 13: 2, # 'ี' - 40: 0, # 'ึ' - 27: 2, # 'ื' - 32: 3, # 'ุ' - 35: 2, # 'ู' - 11: 2, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 0, # 'ๆ' - 37: 1, # '็' - 6: 2, # '่' - 7: 2, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 25: { # 'ป' - 5: 2, # 'ก' - 30: 0, # 'ข' - 24: 1, # 'ค' - 8: 0, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 1, # 'ฎ' - 57: 3, # 'ฏ' - 49: 1, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 1, # 'ต' - 44: 1, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 2, # 'น' - 17: 0, # 'บ' - 25: 1, # 'ป' - 39: 1, # 'ผ' - 62: 1, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 1, # 'ม' - 16: 0, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 3, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 1, # 'ษ' - 18: 2, # 'ส' - 21: 1, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 1, # 'ะ' - 10: 3, # 'ั' - 1: 1, # 'า' - 36: 0, # 'ำ' - 23: 2, # 'ิ' - 13: 3, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 1, # 'ุ' - 35: 0, # 'ู' - 11: 1, # 'เ' - 28: 2, # 'แ' - 41: 0, # 'โ' - 29: 1, # 'ใ' - 33: 2, # 'ไ' - 50: 0, # 'ๆ' - 37: 3, # '็' - 6: 1, # '่' - 7: 2, # '้' - 38: 1, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 39: { # 'ผ' - 5: 1, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 1, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 2, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 1, # 'ม' - 16: 2, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 3, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 1, # 'ะ' - 10: 1, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 2, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 1, # 'ื' - 32: 0, # 'ุ' - 35: 3, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 3, # '่' - 7: 1, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 62: { # 'ฝ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 1, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 1, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 1, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 1, # 'ี' - 40: 2, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 2, # '่' - 7: 1, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 31: { # 'พ' - 5: 1, # 'ก' - 30: 1, # 'ข' - 24: 1, # 'ค' - 8: 1, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 1, # 'ณ' - 20: 1, # 'ด' - 19: 1, # 'ต' - 44: 0, # 'ถ' - 14: 2, # 'ท' - 48: 1, # 'ธ' - 3: 3, # 'น' - 17: 2, # 'บ' - 25: 0, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 1, # 'ม' - 16: 2, # 'ย' - 2: 3, # 'ร' - 61: 2, # 'ฤ' - 15: 2, # 'ล' - 12: 2, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 1, # 'ห' - 4: 2, # 'อ' - 63: 1, # 'ฯ' - 22: 0, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 3, # 'ิ' - 13: 2, # 'ี' - 40: 1, # 'ึ' - 27: 3, # 'ื' - 32: 1, # 'ุ' - 35: 2, # 'ู' - 11: 1, # 'เ' - 28: 1, # 'แ' - 41: 0, # 'โ' - 29: 1, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 1, # '็' - 6: 0, # '่' - 7: 1, # '้' - 38: 3, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 54: { # 'ฟ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 1, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 2, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 1, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 0, # 'ห' - 4: 1, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 2, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 1, # 'ิ' - 13: 1, # 'ี' - 40: 0, # 'ึ' - 27: 1, # 'ื' - 32: 1, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 1, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 2, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 45: { # 'ภ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 1, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 3, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 1, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 1, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 2, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 1, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 9: { # 'ม' - 5: 2, # 'ก' - 30: 2, # 'ข' - 24: 2, # 'ค' - 8: 2, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 1, # 'ณ' - 20: 2, # 'ด' - 19: 2, # 'ต' - 44: 1, # 'ถ' - 14: 2, # 'ท' - 48: 1, # 'ธ' - 3: 3, # 'น' - 17: 2, # 'บ' - 25: 2, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 3, # 'พ' - 54: 0, # 'ฟ' - 45: 1, # 'ภ' - 9: 2, # 'ม' - 16: 1, # 'ย' - 2: 2, # 'ร' - 61: 2, # 'ฤ' - 15: 2, # 'ล' - 12: 2, # 'ว' - 42: 1, # 'ศ' - 46: 1, # 'ษ' - 18: 3, # 'ส' - 21: 3, # 'ห' - 4: 3, # 'อ' - 63: 0, # 'ฯ' - 22: 1, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 3, # 'ิ' - 13: 3, # 'ี' - 40: 0, # 'ึ' - 27: 3, # 'ื' - 32: 3, # 'ุ' - 35: 3, # 'ู' - 11: 2, # 'เ' - 28: 2, # 'แ' - 41: 2, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 1, # 'ๆ' - 37: 1, # '็' - 6: 3, # '่' - 7: 2, # '้' - 38: 1, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 16: { # 'ย' - 5: 3, # 'ก' - 30: 1, # 'ข' - 24: 2, # 'ค' - 8: 3, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 2, # 'ช' - 51: 0, # 'ซ' - 47: 2, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 2, # 'ด' - 19: 2, # 'ต' - 44: 1, # 'ถ' - 14: 2, # 'ท' - 48: 1, # 'ธ' - 3: 3, # 'น' - 17: 3, # 'บ' - 25: 1, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 1, # 'ภ' - 9: 2, # 'ม' - 16: 0, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 1, # 'ล' - 12: 3, # 'ว' - 42: 1, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 1, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 2, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 2, # 'ิ' - 13: 3, # 'ี' - 40: 1, # 'ึ' - 27: 2, # 'ื' - 32: 2, # 'ุ' - 35: 3, # 'ู' - 11: 2, # 'เ' - 28: 1, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 2, # 'ๆ' - 37: 1, # '็' - 6: 3, # '่' - 7: 2, # '้' - 38: 3, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 2: { # 'ร' - 5: 3, # 'ก' - 30: 2, # 'ข' - 24: 2, # 'ค' - 8: 3, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 2, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 3, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 3, # 'ณ' - 20: 2, # 'ด' - 19: 2, # 'ต' - 44: 3, # 'ถ' - 14: 3, # 'ท' - 48: 1, # 'ธ' - 3: 2, # 'น' - 17: 2, # 'บ' - 25: 3, # 'ป' - 39: 2, # 'ผ' - 62: 1, # 'ฝ' - 31: 2, # 'พ' - 54: 1, # 'ฟ' - 45: 1, # 'ภ' - 9: 3, # 'ม' - 16: 2, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 3, # 'ว' - 42: 2, # 'ศ' - 46: 2, # 'ษ' - 18: 2, # 'ส' - 21: 2, # 'ห' - 4: 3, # 'อ' - 63: 1, # 'ฯ' - 22: 3, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 3, # 'ิ' - 13: 3, # 'ี' - 40: 2, # 'ึ' - 27: 3, # 'ื' - 32: 3, # 'ุ' - 35: 3, # 'ู' - 11: 3, # 'เ' - 28: 3, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 3, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 3, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 61: { # 'ฤ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 2, # 'ต' - 44: 0, # 'ถ' - 14: 2, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 1, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 2, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 15: { # 'ล' - 5: 2, # 'ก' - 30: 3, # 'ข' - 24: 1, # 'ค' - 8: 3, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 2, # 'ด' - 19: 2, # 'ต' - 44: 1, # 'ถ' - 14: 2, # 'ท' - 48: 0, # 'ธ' - 3: 1, # 'น' - 17: 2, # 'บ' - 25: 2, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 1, # 'ภ' - 9: 1, # 'ม' - 16: 3, # 'ย' - 2: 1, # 'ร' - 61: 0, # 'ฤ' - 15: 1, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 1, # 'ห' - 4: 3, # 'อ' - 63: 2, # 'ฯ' - 22: 3, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 2, # 'ำ' - 23: 3, # 'ิ' - 13: 3, # 'ี' - 40: 2, # 'ึ' - 27: 3, # 'ื' - 32: 2, # 'ุ' - 35: 3, # 'ู' - 11: 2, # 'เ' - 28: 1, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 2, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 2, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 12: { # 'ว' - 5: 3, # 'ก' - 30: 2, # 'ข' - 24: 1, # 'ค' - 8: 3, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 1, # 'ณ' - 20: 2, # 'ด' - 19: 1, # 'ต' - 44: 1, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 2, # 'บ' - 25: 1, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 1, # 'ฟ' - 45: 0, # 'ภ' - 9: 3, # 'ม' - 16: 3, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 3, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 2, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 2, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 3, # 'ิ' - 13: 2, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 2, # 'ุ' - 35: 0, # 'ู' - 11: 3, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 1, # 'ใ' - 33: 2, # 'ไ' - 50: 1, # 'ๆ' - 37: 0, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 1, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 42: { # 'ศ' - 5: 1, # 'ก' - 30: 0, # 'ข' - 24: 1, # 'ค' - 8: 0, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 1, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 1, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 2, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 2, # 'ว' - 42: 1, # 'ศ' - 46: 2, # 'ษ' - 18: 1, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 2, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 2, # 'ิ' - 13: 0, # 'ี' - 40: 3, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 2, # 'ู' - 11: 0, # 'เ' - 28: 1, # 'แ' - 41: 0, # 'โ' - 29: 1, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 1, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 46: { # 'ษ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 2, # 'ฎ' - 57: 1, # 'ฏ' - 49: 2, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 3, # 'ณ' - 20: 0, # 'ด' - 19: 1, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 1, # 'ภ' - 9: 1, # 'ม' - 16: 2, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 1, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 2, # 'ะ' - 10: 2, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 1, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 1, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 2, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 18: { # 'ส' - 5: 2, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 2, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 3, # 'ด' - 19: 3, # 'ต' - 44: 3, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 2, # 'บ' - 25: 1, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 2, # 'ภ' - 9: 3, # 'ม' - 16: 1, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 1, # 'ล' - 12: 2, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 2, # 'ห' - 4: 3, # 'อ' - 63: 0, # 'ฯ' - 22: 2, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 3, # 'ำ' - 23: 3, # 'ิ' - 13: 3, # 'ี' - 40: 2, # 'ึ' - 27: 3, # 'ื' - 32: 3, # 'ุ' - 35: 3, # 'ู' - 11: 2, # 'เ' - 28: 0, # 'แ' - 41: 1, # 'โ' - 29: 0, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 3, # '่' - 7: 1, # '้' - 38: 2, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 21: { # 'ห' - 5: 3, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 1, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 2, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 3, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 0, # 'บ' - 25: 1, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 3, # 'ม' - 16: 2, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 3, # 'ล' - 12: 2, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 3, # 'อ' - 63: 0, # 'ฯ' - 22: 1, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 0, # 'ำ' - 23: 1, # 'ิ' - 13: 1, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 1, # 'ุ' - 35: 1, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 3, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 2, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 4: { # 'อ' - 5: 3, # 'ก' - 30: 1, # 'ข' - 24: 2, # 'ค' - 8: 3, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 3, # 'ด' - 19: 2, # 'ต' - 44: 1, # 'ถ' - 14: 2, # 'ท' - 48: 1, # 'ธ' - 3: 3, # 'น' - 17: 3, # 'บ' - 25: 1, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 1, # 'ฟ' - 45: 1, # 'ภ' - 9: 3, # 'ม' - 16: 3, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 2, # 'ว' - 42: 1, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 2, # 'ห' - 4: 3, # 'อ' - 63: 0, # 'ฯ' - 22: 2, # 'ะ' - 10: 3, # 'ั' - 1: 3, # 'า' - 36: 2, # 'ำ' - 23: 2, # 'ิ' - 13: 3, # 'ี' - 40: 0, # 'ึ' - 27: 3, # 'ื' - 32: 3, # 'ุ' - 35: 0, # 'ู' - 11: 3, # 'เ' - 28: 1, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 1, # 'ๆ' - 37: 1, # '็' - 6: 2, # '่' - 7: 2, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 63: { # 'ฯ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 22: { # 'ะ' - 5: 3, # 'ก' - 30: 1, # 'ข' - 24: 2, # 'ค' - 8: 1, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 3, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 3, # 'ด' - 19: 3, # 'ต' - 44: 1, # 'ถ' - 14: 3, # 'ท' - 48: 1, # 'ธ' - 3: 2, # 'น' - 17: 3, # 'บ' - 25: 2, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 2, # 'พ' - 54: 0, # 'ฟ' - 45: 1, # 'ภ' - 9: 3, # 'ม' - 16: 2, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 2, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 3, # 'ส' - 21: 3, # 'ห' - 4: 2, # 'อ' - 63: 1, # 'ฯ' - 22: 1, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 3, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 10: { # 'ั' - 5: 3, # 'ก' - 30: 0, # 'ข' - 24: 1, # 'ค' - 8: 3, # 'ง' - 26: 3, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 3, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 2, # 'ฐ' - 53: 0, # 'ฑ' - 55: 3, # 'ฒ' - 43: 3, # 'ณ' - 20: 3, # 'ด' - 19: 3, # 'ต' - 44: 0, # 'ถ' - 14: 2, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 3, # 'บ' - 25: 1, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 2, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 3, # 'ม' - 16: 3, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 3, # 'ว' - 42: 2, # 'ศ' - 46: 0, # 'ษ' - 18: 3, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 1: { # 'า' - 5: 3, # 'ก' - 30: 2, # 'ข' - 24: 3, # 'ค' - 8: 3, # 'ง' - 26: 3, # 'จ' - 52: 0, # 'ฉ' - 34: 3, # 'ช' - 51: 1, # 'ซ' - 47: 2, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 3, # 'ณ' - 20: 3, # 'ด' - 19: 3, # 'ต' - 44: 1, # 'ถ' - 14: 3, # 'ท' - 48: 2, # 'ธ' - 3: 3, # 'น' - 17: 3, # 'บ' - 25: 2, # 'ป' - 39: 1, # 'ผ' - 62: 1, # 'ฝ' - 31: 3, # 'พ' - 54: 1, # 'ฟ' - 45: 1, # 'ภ' - 9: 3, # 'ม' - 16: 3, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 3, # 'ล' - 12: 3, # 'ว' - 42: 2, # 'ศ' - 46: 3, # 'ษ' - 18: 3, # 'ส' - 21: 3, # 'ห' - 4: 2, # 'อ' - 63: 1, # 'ฯ' - 22: 3, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 3, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 1, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 36: { # 'ำ' - 5: 2, # 'ก' - 30: 1, # 'ข' - 24: 3, # 'ค' - 8: 2, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 1, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 1, # 'ต' - 44: 1, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 1, # 'บ' - 25: 1, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 1, # 'ภ' - 9: 1, # 'ม' - 16: 0, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 3, # 'ห' - 4: 1, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 3, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 23: { # 'ิ' - 5: 3, # 'ก' - 30: 1, # 'ข' - 24: 2, # 'ค' - 8: 3, # 'ง' - 26: 3, # 'จ' - 52: 0, # 'ฉ' - 34: 3, # 'ช' - 51: 0, # 'ซ' - 47: 2, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 3, # 'ด' - 19: 3, # 'ต' - 44: 1, # 'ถ' - 14: 3, # 'ท' - 48: 3, # 'ธ' - 3: 3, # 'น' - 17: 3, # 'บ' - 25: 2, # 'ป' - 39: 2, # 'ผ' - 62: 0, # 'ฝ' - 31: 3, # 'พ' - 54: 1, # 'ฟ' - 45: 2, # 'ภ' - 9: 3, # 'ม' - 16: 2, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 3, # 'ว' - 42: 3, # 'ศ' - 46: 2, # 'ษ' - 18: 2, # 'ส' - 21: 3, # 'ห' - 4: 1, # 'อ' - 63: 1, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 3, # 'เ' - 28: 1, # 'แ' - 41: 1, # 'โ' - 29: 1, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 3, # '่' - 7: 2, # '้' - 38: 2, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 13: { # 'ี' - 5: 3, # 'ก' - 30: 2, # 'ข' - 24: 2, # 'ค' - 8: 0, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 2, # 'ด' - 19: 1, # 'ต' - 44: 0, # 'ถ' - 14: 2, # 'ท' - 48: 0, # 'ธ' - 3: 1, # 'น' - 17: 2, # 'บ' - 25: 2, # 'ป' - 39: 1, # 'ผ' - 62: 0, # 'ฝ' - 31: 2, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 2, # 'ม' - 16: 3, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 1, # 'ล' - 12: 2, # 'ว' - 42: 1, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 1, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 2, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 1, # 'ใ' - 33: 1, # 'ไ' - 50: 1, # 'ๆ' - 37: 0, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 40: { # 'ึ' - 5: 3, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 3, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 1, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 27: { # 'ื' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 2, # 'น' - 17: 3, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 2, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 3, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 32: { # 'ุ' - 5: 3, # 'ก' - 30: 2, # 'ข' - 24: 3, # 'ค' - 8: 3, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 2, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 1, # 'ฒ' - 43: 3, # 'ณ' - 20: 3, # 'ด' - 19: 3, # 'ต' - 44: 1, # 'ถ' - 14: 2, # 'ท' - 48: 1, # 'ธ' - 3: 2, # 'น' - 17: 2, # 'บ' - 25: 2, # 'ป' - 39: 2, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 1, # 'ภ' - 9: 3, # 'ม' - 16: 1, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 1, # 'ว' - 42: 1, # 'ศ' - 46: 2, # 'ษ' - 18: 1, # 'ส' - 21: 1, # 'ห' - 4: 1, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 1, # 'เ' - 28: 0, # 'แ' - 41: 1, # 'โ' - 29: 0, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 3, # '่' - 7: 2, # '้' - 38: 1, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 35: { # 'ู' - 5: 3, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 2, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 2, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 1, # 'ณ' - 20: 2, # 'ด' - 19: 2, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 2, # 'น' - 17: 0, # 'บ' - 25: 3, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 2, # 'ม' - 16: 0, # 'ย' - 2: 1, # 'ร' - 61: 0, # 'ฤ' - 15: 3, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 1, # 'เ' - 28: 1, # 'แ' - 41: 1, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 3, # '่' - 7: 3, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 11: { # 'เ' - 5: 3, # 'ก' - 30: 3, # 'ข' - 24: 3, # 'ค' - 8: 2, # 'ง' - 26: 3, # 'จ' - 52: 3, # 'ฉ' - 34: 3, # 'ช' - 51: 2, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 1, # 'ณ' - 20: 3, # 'ด' - 19: 3, # 'ต' - 44: 1, # 'ถ' - 14: 3, # 'ท' - 48: 1, # 'ธ' - 3: 3, # 'น' - 17: 3, # 'บ' - 25: 3, # 'ป' - 39: 2, # 'ผ' - 62: 1, # 'ฝ' - 31: 3, # 'พ' - 54: 1, # 'ฟ' - 45: 3, # 'ภ' - 9: 3, # 'ม' - 16: 2, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 3, # 'ล' - 12: 3, # 'ว' - 42: 2, # 'ศ' - 46: 0, # 'ษ' - 18: 3, # 'ส' - 21: 3, # 'ห' - 4: 3, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 28: { # 'แ' - 5: 3, # 'ก' - 30: 2, # 'ข' - 24: 2, # 'ค' - 8: 1, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 2, # 'ด' - 19: 3, # 'ต' - 44: 2, # 'ถ' - 14: 3, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 3, # 'บ' - 25: 2, # 'ป' - 39: 3, # 'ผ' - 62: 0, # 'ฝ' - 31: 2, # 'พ' - 54: 2, # 'ฟ' - 45: 0, # 'ภ' - 9: 2, # 'ม' - 16: 2, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 3, # 'ล' - 12: 2, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 3, # 'ส' - 21: 3, # 'ห' - 4: 1, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 41: { # 'โ' - 5: 2, # 'ก' - 30: 1, # 'ข' - 24: 2, # 'ค' - 8: 0, # 'ง' - 26: 1, # 'จ' - 52: 1, # 'ฉ' - 34: 1, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 3, # 'ด' - 19: 2, # 'ต' - 44: 0, # 'ถ' - 14: 2, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 1, # 'บ' - 25: 3, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 1, # 'ฟ' - 45: 1, # 'ภ' - 9: 1, # 'ม' - 16: 2, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 3, # 'ล' - 12: 0, # 'ว' - 42: 1, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 0, # 'ห' - 4: 2, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 29: { # 'ใ' - 5: 2, # 'ก' - 30: 0, # 'ข' - 24: 1, # 'ค' - 8: 0, # 'ง' - 26: 3, # 'จ' - 52: 0, # 'ฉ' - 34: 3, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 3, # 'ด' - 19: 1, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 2, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 1, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 3, # 'ส' - 21: 3, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 33: { # 'ไ' - 5: 1, # 'ก' - 30: 2, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 3, # 'ด' - 19: 1, # 'ต' - 44: 0, # 'ถ' - 14: 3, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 1, # 'บ' - 25: 3, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 2, # 'ฟ' - 45: 0, # 'ภ' - 9: 3, # 'ม' - 16: 0, # 'ย' - 2: 3, # 'ร' - 61: 0, # 'ฤ' - 15: 1, # 'ล' - 12: 3, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 2, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 50: { # 'ๆ' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 37: { # '็' - 5: 2, # 'ก' - 30: 1, # 'ข' - 24: 2, # 'ค' - 8: 2, # 'ง' - 26: 3, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 1, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 2, # 'ต' - 44: 0, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 3, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 2, # 'ม' - 16: 1, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 2, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 0, # 'ห' - 4: 1, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 1, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 6: { # '่' - 5: 2, # 'ก' - 30: 1, # 'ข' - 24: 2, # 'ค' - 8: 3, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 1, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 2, # 'ต' - 44: 1, # 'ถ' - 14: 2, # 'ท' - 48: 1, # 'ธ' - 3: 3, # 'น' - 17: 1, # 'บ' - 25: 2, # 'ป' - 39: 2, # 'ผ' - 62: 1, # 'ฝ' - 31: 1, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 3, # 'ม' - 16: 3, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 2, # 'ล' - 12: 3, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 1, # 'ห' - 4: 3, # 'อ' - 63: 0, # 'ฯ' - 22: 1, # 'ะ' - 10: 0, # 'ั' - 1: 3, # 'า' - 36: 2, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 3, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 1, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 7: { # '้' - 5: 2, # 'ก' - 30: 1, # 'ข' - 24: 2, # 'ค' - 8: 3, # 'ง' - 26: 2, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 1, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 1, # 'ด' - 19: 2, # 'ต' - 44: 1, # 'ถ' - 14: 2, # 'ท' - 48: 0, # 'ธ' - 3: 3, # 'น' - 17: 2, # 'บ' - 25: 2, # 'ป' - 39: 2, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 1, # 'ฟ' - 45: 0, # 'ภ' - 9: 3, # 'ม' - 16: 2, # 'ย' - 2: 2, # 'ร' - 61: 0, # 'ฤ' - 15: 1, # 'ล' - 12: 3, # 'ว' - 42: 1, # 'ศ' - 46: 0, # 'ษ' - 18: 2, # 'ส' - 21: 2, # 'ห' - 4: 3, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 3, # 'า' - 36: 2, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 2, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 2, # 'ใ' - 33: 2, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 38: { # '์' - 5: 2, # 'ก' - 30: 1, # 'ข' - 24: 1, # 'ค' - 8: 0, # 'ง' - 26: 1, # 'จ' - 52: 0, # 'ฉ' - 34: 1, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 2, # 'ด' - 19: 1, # 'ต' - 44: 1, # 'ถ' - 14: 1, # 'ท' - 48: 0, # 'ธ' - 3: 1, # 'น' - 17: 1, # 'บ' - 25: 1, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 1, # 'พ' - 54: 1, # 'ฟ' - 45: 0, # 'ภ' - 9: 2, # 'ม' - 16: 0, # 'ย' - 2: 1, # 'ร' - 61: 1, # 'ฤ' - 15: 1, # 'ล' - 12: 1, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 1, # 'ส' - 21: 1, # 'ห' - 4: 2, # 'อ' - 63: 1, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 2, # 'เ' - 28: 2, # 'แ' - 41: 1, # 'โ' - 29: 1, # 'ใ' - 33: 1, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 0, # '๑' - 59: 0, # '๒' - 60: 0, # '๕' - }, - 56: { # '๑' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 2, # '๑' - 59: 1, # '๒' - 60: 1, # '๕' - }, - 59: { # '๒' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 1, # '๑' - 59: 1, # '๒' - 60: 3, # '๕' - }, - 60: { # '๕' - 5: 0, # 'ก' - 30: 0, # 'ข' - 24: 0, # 'ค' - 8: 0, # 'ง' - 26: 0, # 'จ' - 52: 0, # 'ฉ' - 34: 0, # 'ช' - 51: 0, # 'ซ' - 47: 0, # 'ญ' - 58: 0, # 'ฎ' - 57: 0, # 'ฏ' - 49: 0, # 'ฐ' - 53: 0, # 'ฑ' - 55: 0, # 'ฒ' - 43: 0, # 'ณ' - 20: 0, # 'ด' - 19: 0, # 'ต' - 44: 0, # 'ถ' - 14: 0, # 'ท' - 48: 0, # 'ธ' - 3: 0, # 'น' - 17: 0, # 'บ' - 25: 0, # 'ป' - 39: 0, # 'ผ' - 62: 0, # 'ฝ' - 31: 0, # 'พ' - 54: 0, # 'ฟ' - 45: 0, # 'ภ' - 9: 0, # 'ม' - 16: 0, # 'ย' - 2: 0, # 'ร' - 61: 0, # 'ฤ' - 15: 0, # 'ล' - 12: 0, # 'ว' - 42: 0, # 'ศ' - 46: 0, # 'ษ' - 18: 0, # 'ส' - 21: 0, # 'ห' - 4: 0, # 'อ' - 63: 0, # 'ฯ' - 22: 0, # 'ะ' - 10: 0, # 'ั' - 1: 0, # 'า' - 36: 0, # 'ำ' - 23: 0, # 'ิ' - 13: 0, # 'ี' - 40: 0, # 'ึ' - 27: 0, # 'ื' - 32: 0, # 'ุ' - 35: 0, # 'ู' - 11: 0, # 'เ' - 28: 0, # 'แ' - 41: 0, # 'โ' - 29: 0, # 'ใ' - 33: 0, # 'ไ' - 50: 0, # 'ๆ' - 37: 0, # '็' - 6: 0, # '่' - 7: 0, # '้' - 38: 0, # '์' - 56: 2, # '๑' - 59: 1, # '๒' - 60: 0, # '๕' - }, -} - -# 255: Undefined characters that did not exist in training text -# 254: Carriage/Return -# 253: symbol (punctuation) that does not belong to word -# 252: 0 - 9 -# 251: Control characters - -# Character Mapping Table(s): -TIS_620_THAI_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 182, # 'A' - 66: 106, # 'B' - 67: 107, # 'C' - 68: 100, # 'D' - 69: 183, # 'E' - 70: 184, # 'F' - 71: 185, # 'G' - 72: 101, # 'H' - 73: 94, # 'I' - 74: 186, # 'J' - 75: 187, # 'K' - 76: 108, # 'L' - 77: 109, # 'M' - 78: 110, # 'N' - 79: 111, # 'O' - 80: 188, # 'P' - 81: 189, # 'Q' - 82: 190, # 'R' - 83: 89, # 'S' - 84: 95, # 'T' - 85: 112, # 'U' - 86: 113, # 'V' - 87: 191, # 'W' - 88: 192, # 'X' - 89: 193, # 'Y' - 90: 194, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 64, # 'a' - 98: 72, # 'b' - 99: 73, # 'c' - 100: 114, # 'd' - 101: 74, # 'e' - 102: 115, # 'f' - 103: 116, # 'g' - 104: 102, # 'h' - 105: 81, # 'i' - 106: 201, # 'j' - 107: 117, # 'k' - 108: 90, # 'l' - 109: 103, # 'm' - 110: 78, # 'n' - 111: 82, # 'o' - 112: 96, # 'p' - 113: 202, # 'q' - 114: 91, # 'r' - 115: 79, # 's' - 116: 84, # 't' - 117: 104, # 'u' - 118: 105, # 'v' - 119: 97, # 'w' - 120: 98, # 'x' - 121: 92, # 'y' - 122: 203, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 209, # '\x80' - 129: 210, # '\x81' - 130: 211, # '\x82' - 131: 212, # '\x83' - 132: 213, # '\x84' - 133: 88, # '\x85' - 134: 214, # '\x86' - 135: 215, # '\x87' - 136: 216, # '\x88' - 137: 217, # '\x89' - 138: 218, # '\x8a' - 139: 219, # '\x8b' - 140: 220, # '\x8c' - 141: 118, # '\x8d' - 142: 221, # '\x8e' - 143: 222, # '\x8f' - 144: 223, # '\x90' - 145: 224, # '\x91' - 146: 99, # '\x92' - 147: 85, # '\x93' - 148: 83, # '\x94' - 149: 225, # '\x95' - 150: 226, # '\x96' - 151: 227, # '\x97' - 152: 228, # '\x98' - 153: 229, # '\x99' - 154: 230, # '\x9a' - 155: 231, # '\x9b' - 156: 232, # '\x9c' - 157: 233, # '\x9d' - 158: 234, # '\x9e' - 159: 235, # '\x9f' - 160: 236, # None - 161: 5, # 'ก' - 162: 30, # 'ข' - 163: 237, # 'ฃ' - 164: 24, # 'ค' - 165: 238, # 'ฅ' - 166: 75, # 'ฆ' - 167: 8, # 'ง' - 168: 26, # 'จ' - 169: 52, # 'ฉ' - 170: 34, # 'ช' - 171: 51, # 'ซ' - 172: 119, # 'ฌ' - 173: 47, # 'ญ' - 174: 58, # 'ฎ' - 175: 57, # 'ฏ' - 176: 49, # 'ฐ' - 177: 53, # 'ฑ' - 178: 55, # 'ฒ' - 179: 43, # 'ณ' - 180: 20, # 'ด' - 181: 19, # 'ต' - 182: 44, # 'ถ' - 183: 14, # 'ท' - 184: 48, # 'ธ' - 185: 3, # 'น' - 186: 17, # 'บ' - 187: 25, # 'ป' - 188: 39, # 'ผ' - 189: 62, # 'ฝ' - 190: 31, # 'พ' - 191: 54, # 'ฟ' - 192: 45, # 'ภ' - 193: 9, # 'ม' - 194: 16, # 'ย' - 195: 2, # 'ร' - 196: 61, # 'ฤ' - 197: 15, # 'ล' - 198: 239, # 'ฦ' - 199: 12, # 'ว' - 200: 42, # 'ศ' - 201: 46, # 'ษ' - 202: 18, # 'ส' - 203: 21, # 'ห' - 204: 76, # 'ฬ' - 205: 4, # 'อ' - 206: 66, # 'ฮ' - 207: 63, # 'ฯ' - 208: 22, # 'ะ' - 209: 10, # 'ั' - 210: 1, # 'า' - 211: 36, # 'ำ' - 212: 23, # 'ิ' - 213: 13, # 'ี' - 214: 40, # 'ึ' - 215: 27, # 'ื' - 216: 32, # 'ุ' - 217: 35, # 'ู' - 218: 86, # 'ฺ' - 219: 240, # None - 220: 241, # None - 221: 242, # None - 222: 243, # None - 223: 244, # '฿' - 224: 11, # 'เ' - 225: 28, # 'แ' - 226: 41, # 'โ' - 227: 29, # 'ใ' - 228: 33, # 'ไ' - 229: 245, # 'ๅ' - 230: 50, # 'ๆ' - 231: 37, # '็' - 232: 6, # '่' - 233: 7, # '้' - 234: 67, # '๊' - 235: 77, # '๋' - 236: 38, # '์' - 237: 93, # 'ํ' - 238: 246, # '๎' - 239: 247, # '๏' - 240: 68, # '๐' - 241: 56, # '๑' - 242: 59, # '๒' - 243: 65, # '๓' - 244: 69, # '๔' - 245: 60, # '๕' - 246: 70, # '๖' - 247: 80, # '๗' - 248: 71, # '๘' - 249: 87, # '๙' - 250: 248, # '๚' - 251: 249, # '๛' - 252: 250, # None - 253: 251, # None - 254: 252, # None - 255: 253, # None -} - -TIS_620_THAI_MODEL = SingleByteCharSetModel( - charset_name="TIS-620", - language="Thai", - char_to_order_map=TIS_620_THAI_CHAR_TO_ORDER, - language_model=THAI_LANG_MODEL, - typical_positive_ratio=0.926386, - keep_ascii_letters=False, - alphabet="กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛", -) diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py b/myenv/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py deleted file mode 100644 index 291857c..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py +++ /dev/null @@ -1,4380 +0,0 @@ -from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - -# 3: Positive -# 2: Likely -# 1: Unlikely -# 0: Negative - -TURKISH_LANG_MODEL = { - 23: { # 'A' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 0, # 'c' - 12: 2, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 1, # 'g' - 25: 1, # 'h' - 3: 1, # 'i' - 24: 0, # 'j' - 10: 2, # 'k' - 5: 1, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 1, # 'r' - 8: 1, # 's' - 9: 1, # 't' - 14: 1, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 3, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 0, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 37: { # 'B' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 2, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 2, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 1, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 1, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 0, # 'Z' - 1: 2, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 0, # 'k' - 5: 0, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 1, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 1, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 0, # 'ı' - 40: 1, # 'Ş' - 19: 1, # 'ş' - }, - 47: { # 'C' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 1, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 1, # 'L' - 20: 0, # 'M' - 46: 1, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 1, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 2, # 'j' - 10: 1, # 'k' - 5: 2, # 'l' - 13: 2, # 'm' - 4: 2, # 'n' - 15: 1, # 'o' - 26: 0, # 'p' - 7: 2, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 1, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 1, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 39: { # 'D' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 1, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 1, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 2, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 0, # 'k' - 5: 1, # 'l' - 13: 3, # 'm' - 4: 0, # 'n' - 15: 1, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 1, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 1, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 0, # 'İ' - 6: 1, # 'ı' - 40: 1, # 'Ş' - 19: 0, # 'ş' - }, - 29: { # 'E' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 1, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 0, # 'c' - 12: 2, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 1, # 'g' - 25: 0, # 'h' - 3: 1, # 'i' - 24: 1, # 'j' - 10: 0, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 1, # 's' - 9: 1, # 't' - 14: 1, # 'u' - 32: 1, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 2, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 52: { # 'F' - 23: 0, # 'A' - 37: 1, # 'B' - 47: 1, # 'C' - 39: 1, # 'D' - 29: 1, # 'E' - 52: 2, # 'F' - 36: 0, # 'G' - 45: 2, # 'H' - 53: 1, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 1, # 'N' - 42: 1, # 'O' - 48: 2, # 'P' - 44: 1, # 'R' - 35: 1, # 'S' - 31: 1, # 'T' - 51: 1, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 2, # 'Y' - 56: 0, # 'Z' - 1: 0, # 'a' - 21: 1, # 'b' - 28: 1, # 'c' - 12: 1, # 'd' - 2: 0, # 'e' - 18: 1, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 2, # 'i' - 24: 1, # 'j' - 10: 0, # 'k' - 5: 0, # 'l' - 13: 1, # 'm' - 4: 2, # 'n' - 15: 1, # 'o' - 26: 0, # 'p' - 7: 2, # 'r' - 8: 1, # 's' - 9: 1, # 't' - 14: 1, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 1, # 'y' - 22: 1, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 1, # 'Ö' - 55: 2, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 2, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 1, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 2, # 'ş' - }, - 36: { # 'G' - 23: 1, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 1, # 'F' - 36: 2, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 2, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 2, # 'N' - 42: 1, # 'O' - 48: 1, # 'P' - 44: 1, # 'R' - 35: 1, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 2, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 1, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 1, # 'j' - 10: 1, # 'k' - 5: 0, # 'l' - 13: 3, # 'm' - 4: 2, # 'n' - 15: 0, # 'o' - 26: 1, # 'p' - 7: 0, # 'r' - 8: 1, # 's' - 9: 1, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 1, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 2, # 'Ö' - 55: 0, # 'Ü' - 59: 1, # 'â' - 33: 2, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 1, # 'İ' - 6: 2, # 'ı' - 40: 2, # 'Ş' - 19: 1, # 'ş' - }, - 45: { # 'H' - 23: 0, # 'A' - 37: 1, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 2, # 'F' - 36: 2, # 'G' - 45: 1, # 'H' - 53: 1, # 'I' - 60: 0, # 'J' - 16: 2, # 'K' - 49: 1, # 'L' - 20: 0, # 'M' - 46: 1, # 'N' - 42: 1, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 2, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 2, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 2, # 'i' - 24: 0, # 'j' - 10: 1, # 'k' - 5: 0, # 'l' - 13: 2, # 'm' - 4: 0, # 'n' - 15: 1, # 'o' - 26: 1, # 'p' - 7: 1, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 1, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 2, # 'ğ' - 41: 1, # 'İ' - 6: 0, # 'ı' - 40: 2, # 'Ş' - 19: 1, # 'ş' - }, - 53: { # 'I' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 1, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 2, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 2, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 0, # 'k' - 5: 2, # 'l' - 13: 2, # 'm' - 4: 0, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 2, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 0, # 'ı' - 40: 1, # 'Ş' - 19: 1, # 'ş' - }, - 60: { # 'J' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 0, # 'a' - 21: 1, # 'b' - 28: 0, # 'c' - 12: 1, # 'd' - 2: 0, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 1, # 'i' - 24: 0, # 'j' - 10: 0, # 'k' - 5: 0, # 'l' - 13: 0, # 'm' - 4: 1, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 1, # 's' - 9: 0, # 't' - 14: 0, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 0, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 16: { # 'K' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 3, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 2, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 2, # 'a' - 21: 3, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 1, # 'e' - 18: 3, # 'f' - 27: 3, # 'g' - 25: 3, # 'h' - 3: 3, # 'i' - 24: 2, # 'j' - 10: 3, # 'k' - 5: 0, # 'l' - 13: 0, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 1, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 0, # 'u' - 32: 3, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 2, # 'y' - 22: 1, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 2, # 'ü' - 30: 0, # 'ğ' - 41: 1, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 49: { # 'L' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 2, # 'E' - 52: 0, # 'F' - 36: 1, # 'G' - 45: 1, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 2, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 0, # 'Z' - 1: 0, # 'a' - 21: 3, # 'b' - 28: 0, # 'c' - 12: 2, # 'd' - 2: 0, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 2, # 'i' - 24: 0, # 'j' - 10: 1, # 'k' - 5: 0, # 'l' - 13: 0, # 'm' - 4: 2, # 'n' - 15: 1, # 'o' - 26: 1, # 'p' - 7: 1, # 'r' - 8: 1, # 's' - 9: 1, # 't' - 14: 0, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 2, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 2, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 1, # 'ü' - 30: 1, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 20: { # 'M' - 23: 1, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 1, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 1, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 2, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 1, # 'g' - 25: 1, # 'h' - 3: 2, # 'i' - 24: 2, # 'j' - 10: 2, # 'k' - 5: 2, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 1, # 'p' - 7: 3, # 'r' - 8: 0, # 's' - 9: 2, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 2, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 3, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 46: { # 'N' - 23: 0, # 'A' - 37: 1, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 1, # 'F' - 36: 1, # 'G' - 45: 1, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 2, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 1, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 1, # 'R' - 35: 1, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 2, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 1, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 2, # 'j' - 10: 1, # 'k' - 5: 1, # 'l' - 13: 3, # 'm' - 4: 2, # 'n' - 15: 1, # 'o' - 26: 1, # 'p' - 7: 1, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 1, # 'x' - 11: 1, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 1, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 1, # 'İ' - 6: 2, # 'ı' - 40: 1, # 'Ş' - 19: 1, # 'ş' - }, - 42: { # 'O' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 1, # 'F' - 36: 0, # 'G' - 45: 1, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 2, # 'K' - 49: 1, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 2, # 'P' - 44: 1, # 'R' - 35: 1, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 0, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 0, # 'n' - 15: 1, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 2, # 'Ç' - 50: 1, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 2, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 2, # 'İ' - 6: 1, # 'ı' - 40: 1, # 'Ş' - 19: 1, # 'ş' - }, - 48: { # 'P' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 2, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 2, # 'F' - 36: 1, # 'G' - 45: 1, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 2, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 1, # 'N' - 42: 1, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 1, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 2, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 1, # 'k' - 5: 0, # 'l' - 13: 2, # 'm' - 4: 0, # 'n' - 15: 2, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 2, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 2, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 2, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 1, # 'İ' - 6: 0, # 'ı' - 40: 2, # 'Ş' - 19: 1, # 'ş' - }, - 44: { # 'R' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 1, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 1, # 'b' - 28: 1, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 1, # 'k' - 5: 2, # 'l' - 13: 2, # 'm' - 4: 0, # 'n' - 15: 1, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 1, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 1, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 1, # 'ü' - 30: 1, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 1, # 'Ş' - 19: 1, # 'ş' - }, - 35: { # 'S' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 1, # 'F' - 36: 1, # 'G' - 45: 1, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 1, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 1, # 'k' - 5: 1, # 'l' - 13: 2, # 'm' - 4: 1, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 1, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 1, # 'z' - 63: 0, # '·' - 54: 2, # 'Ç' - 50: 2, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 3, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 2, # 'Ş' - 19: 1, # 'ş' - }, - 31: { # 'T' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 1, # 'J' - 16: 2, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 2, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 2, # 'b' - 28: 0, # 'c' - 12: 1, # 'd' - 2: 3, # 'e' - 18: 2, # 'f' - 27: 2, # 'g' - 25: 0, # 'h' - 3: 1, # 'i' - 24: 1, # 'j' - 10: 2, # 'k' - 5: 2, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 2, # 'p' - 7: 2, # 'r' - 8: 0, # 's' - 9: 2, # 't' - 14: 2, # 'u' - 32: 1, # 'v' - 57: 1, # 'w' - 58: 1, # 'x' - 11: 2, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 1, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 51: { # 'U' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 1, # 'F' - 36: 1, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 1, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 1, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 1, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 2, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 1, # 'k' - 5: 1, # 'l' - 13: 3, # 'm' - 4: 2, # 'n' - 15: 0, # 'o' - 26: 1, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 1, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 1, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 1, # 'ş' - }, - 38: { # 'V' - 23: 1, # 'A' - 37: 1, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 2, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 1, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 0, # 'k' - 5: 2, # 'l' - 13: 2, # 'm' - 4: 0, # 'n' - 15: 2, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 1, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 1, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 1, # 'Ö' - 55: 0, # 'Ü' - 59: 1, # 'â' - 33: 2, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 1, # 'İ' - 6: 3, # 'ı' - 40: 2, # 'Ş' - 19: 1, # 'ş' - }, - 62: { # 'W' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 0, # 'a' - 21: 0, # 'b' - 28: 0, # 'c' - 12: 0, # 'd' - 2: 0, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 0, # 'k' - 5: 0, # 'l' - 13: 0, # 'm' - 4: 0, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 0, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 0, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 43: { # 'Y' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 2, # 'F' - 36: 0, # 'G' - 45: 1, # 'H' - 53: 1, # 'I' - 60: 0, # 'J' - 16: 2, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 2, # 'N' - 42: 0, # 'O' - 48: 2, # 'P' - 44: 1, # 'R' - 35: 1, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 2, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 1, # 'j' - 10: 1, # 'k' - 5: 1, # 'l' - 13: 3, # 'm' - 4: 0, # 'n' - 15: 2, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 1, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 2, # 'Ö' - 55: 1, # 'Ü' - 59: 1, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 1, # 'İ' - 6: 0, # 'ı' - 40: 2, # 'Ş' - 19: 1, # 'ş' - }, - 56: { # 'Z' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 2, # 'Z' - 1: 2, # 'a' - 21: 1, # 'b' - 28: 0, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 2, # 'i' - 24: 1, # 'j' - 10: 0, # 'k' - 5: 0, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 1, # 'r' - 8: 1, # 's' - 9: 0, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 1, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 1, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 1: { # 'a' - 23: 3, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 3, # 'E' - 52: 0, # 'F' - 36: 1, # 'G' - 45: 1, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 1, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 3, # 'T' - 51: 0, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 2, # 'Z' - 1: 2, # 'a' - 21: 3, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 2, # 'e' - 18: 3, # 'f' - 27: 3, # 'g' - 25: 3, # 'h' - 3: 3, # 'i' - 24: 3, # 'j' - 10: 3, # 'k' - 5: 0, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 15: 1, # 'o' - 26: 3, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 3, # 'v' - 57: 2, # 'w' - 58: 0, # 'x' - 11: 3, # 'y' - 22: 0, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 1, # 'î' - 34: 1, # 'ö' - 17: 3, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 1, # 'ş' - }, - 21: { # 'b' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 1, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 1, # 'J' - 16: 2, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 1, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 2, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 3, # 'g' - 25: 1, # 'h' - 3: 3, # 'i' - 24: 2, # 'j' - 10: 3, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 3, # 'p' - 7: 1, # 'r' - 8: 2, # 's' - 9: 2, # 't' - 14: 2, # 'u' - 32: 1, # 'v' - 57: 0, # 'w' - 58: 1, # 'x' - 11: 3, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 28: { # 'c' - 23: 0, # 'A' - 37: 1, # 'B' - 47: 1, # 'C' - 39: 1, # 'D' - 29: 2, # 'E' - 52: 0, # 'F' - 36: 2, # 'G' - 45: 2, # 'H' - 53: 1, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 1, # 'N' - 42: 1, # 'O' - 48: 2, # 'P' - 44: 1, # 'R' - 35: 1, # 'S' - 31: 2, # 'T' - 51: 2, # 'U' - 38: 2, # 'V' - 62: 0, # 'W' - 43: 3, # 'Y' - 56: 0, # 'Z' - 1: 1, # 'a' - 21: 1, # 'b' - 28: 2, # 'c' - 12: 2, # 'd' - 2: 1, # 'e' - 18: 1, # 'f' - 27: 2, # 'g' - 25: 2, # 'h' - 3: 3, # 'i' - 24: 1, # 'j' - 10: 3, # 'k' - 5: 0, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 15: 2, # 'o' - 26: 2, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 1, # 'u' - 32: 0, # 'v' - 57: 1, # 'w' - 58: 0, # 'x' - 11: 2, # 'y' - 22: 1, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 1, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 1, # 'î' - 34: 2, # 'ö' - 17: 2, # 'ü' - 30: 2, # 'ğ' - 41: 1, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 2, # 'ş' - }, - 12: { # 'd' - 23: 1, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 2, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 1, # 'S' - 31: 1, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 2, # 'b' - 28: 1, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 1, # 'f' - 27: 3, # 'g' - 25: 3, # 'h' - 3: 2, # 'i' - 24: 3, # 'j' - 10: 2, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 1, # 'o' - 26: 2, # 'p' - 7: 3, # 'r' - 8: 2, # 's' - 9: 2, # 't' - 14: 3, # 'u' - 32: 1, # 'v' - 57: 0, # 'w' - 58: 1, # 'x' - 11: 3, # 'y' - 22: 1, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 1, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 2: { # 'e' - 23: 2, # 'A' - 37: 0, # 'B' - 47: 2, # 'C' - 39: 0, # 'D' - 29: 3, # 'E' - 52: 1, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 1, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 1, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 1, # 'R' - 35: 0, # 'S' - 31: 3, # 'T' - 51: 0, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 3, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 2, # 'e' - 18: 3, # 'f' - 27: 3, # 'g' - 25: 3, # 'h' - 3: 3, # 'i' - 24: 3, # 'j' - 10: 3, # 'k' - 5: 0, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 15: 1, # 'o' - 26: 3, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 3, # 'v' - 57: 2, # 'w' - 58: 0, # 'x' - 11: 3, # 'y' - 22: 1, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 3, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 18: { # 'f' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 2, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 2, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 1, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 2, # 'f' - 27: 1, # 'g' - 25: 1, # 'h' - 3: 1, # 'i' - 24: 1, # 'j' - 10: 1, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 2, # 'p' - 7: 1, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 1, # 'u' - 32: 2, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 1, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 1, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 1, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 27: { # 'g' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 1, # 'S' - 31: 1, # 'T' - 51: 0, # 'U' - 38: 2, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 1, # 'b' - 28: 0, # 'c' - 12: 1, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 2, # 'g' - 25: 1, # 'h' - 3: 2, # 'i' - 24: 3, # 'j' - 10: 2, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 2, # 'n' - 15: 0, # 'o' - 26: 1, # 'p' - 7: 2, # 'r' - 8: 2, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 1, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 1, # 'y' - 22: 0, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 25: { # 'h' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 2, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 0, # 'c' - 12: 2, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 1, # 'g' - 25: 2, # 'h' - 3: 2, # 'i' - 24: 3, # 'j' - 10: 3, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 1, # 'o' - 26: 1, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 2, # 't' - 14: 3, # 'u' - 32: 2, # 'v' - 57: 1, # 'w' - 58: 0, # 'x' - 11: 1, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 3: { # 'i' - 23: 2, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 1, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 0, # 'N' - 42: 1, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 1, # 'S' - 31: 2, # 'T' - 51: 0, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 2, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 2, # 'f' - 27: 3, # 'g' - 25: 1, # 'h' - 3: 3, # 'i' - 24: 2, # 'j' - 10: 3, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 1, # 'o' - 26: 3, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 2, # 'v' - 57: 1, # 'w' - 58: 1, # 'x' - 11: 3, # 'y' - 22: 1, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 1, # 'Ü' - 59: 0, # 'â' - 33: 2, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 3, # 'ü' - 30: 0, # 'ğ' - 41: 1, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 24: { # 'j' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 1, # 'J' - 16: 2, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 1, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 1, # 'Z' - 1: 3, # 'a' - 21: 1, # 'b' - 28: 1, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 2, # 'f' - 27: 1, # 'g' - 25: 1, # 'h' - 3: 2, # 'i' - 24: 1, # 'j' - 10: 2, # 'k' - 5: 2, # 'l' - 13: 3, # 'm' - 4: 2, # 'n' - 15: 0, # 'o' - 26: 1, # 'p' - 7: 2, # 'r' - 8: 3, # 's' - 9: 2, # 't' - 14: 3, # 'u' - 32: 2, # 'v' - 57: 0, # 'w' - 58: 2, # 'x' - 11: 1, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 1, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 10: { # 'k' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 3, # 'T' - 51: 0, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 1, # 'Z' - 1: 3, # 'a' - 21: 2, # 'b' - 28: 0, # 'c' - 12: 2, # 'd' - 2: 3, # 'e' - 18: 1, # 'f' - 27: 2, # 'g' - 25: 2, # 'h' - 3: 3, # 'i' - 24: 2, # 'j' - 10: 2, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 3, # 'p' - 7: 2, # 'r' - 8: 2, # 's' - 9: 2, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 1, # 'x' - 11: 3, # 'y' - 22: 0, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 3, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 3, # 'ü' - 30: 1, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 1, # 'ş' - }, - 5: { # 'l' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 3, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 1, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 0, # 'a' - 21: 3, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 1, # 'e' - 18: 3, # 'f' - 27: 3, # 'g' - 25: 2, # 'h' - 3: 3, # 'i' - 24: 2, # 'j' - 10: 3, # 'k' - 5: 1, # 'l' - 13: 1, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 2, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 2, # 'u' - 32: 2, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 3, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 2, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 13: { # 'm' - 23: 1, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 3, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 3, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 0, # 'Z' - 1: 2, # 'a' - 21: 3, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 2, # 'e' - 18: 3, # 'f' - 27: 3, # 'g' - 25: 3, # 'h' - 3: 3, # 'i' - 24: 3, # 'j' - 10: 3, # 'k' - 5: 0, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 15: 1, # 'o' - 26: 2, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 2, # 'u' - 32: 2, # 'v' - 57: 1, # 'w' - 58: 0, # 'x' - 11: 3, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 3, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 1, # 'ş' - }, - 4: { # 'n' - 23: 1, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 1, # 'H' - 53: 0, # 'I' - 60: 2, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 2, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 2, # 'b' - 28: 1, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 1, # 'f' - 27: 2, # 'g' - 25: 3, # 'h' - 3: 2, # 'i' - 24: 2, # 'j' - 10: 3, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 1, # 'o' - 26: 3, # 'p' - 7: 2, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 2, # 'v' - 57: 0, # 'w' - 58: 2, # 'x' - 11: 3, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 2, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 1, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 15: { # 'o' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 2, # 'F' - 36: 1, # 'G' - 45: 1, # 'H' - 53: 1, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 2, # 'L' - 20: 0, # 'M' - 46: 2, # 'N' - 42: 1, # 'O' - 48: 2, # 'P' - 44: 1, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 1, # 'i' - 24: 2, # 'j' - 10: 1, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 2, # 'n' - 15: 2, # 'o' - 26: 0, # 'p' - 7: 1, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 2, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 2, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 3, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 2, # 'ğ' - 41: 2, # 'İ' - 6: 3, # 'ı' - 40: 2, # 'Ş' - 19: 2, # 'ş' - }, - 26: { # 'p' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 1, # 'b' - 28: 0, # 'c' - 12: 1, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 1, # 'g' - 25: 1, # 'h' - 3: 2, # 'i' - 24: 3, # 'j' - 10: 1, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 2, # 'n' - 15: 0, # 'o' - 26: 2, # 'p' - 7: 2, # 'r' - 8: 1, # 's' - 9: 1, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 1, # 'x' - 11: 1, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 3, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 1, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 7: { # 'r' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 1, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 2, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 2, # 'T' - 51: 1, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 1, # 'Z' - 1: 3, # 'a' - 21: 1, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 2, # 'g' - 25: 3, # 'h' - 3: 2, # 'i' - 24: 2, # 'j' - 10: 3, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 2, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 2, # 'v' - 57: 0, # 'w' - 58: 1, # 'x' - 11: 2, # 'y' - 22: 0, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 2, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 3, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 8: { # 's' - 23: 1, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 1, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 2, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 1, # 'Z' - 1: 3, # 'a' - 21: 2, # 'b' - 28: 1, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 2, # 'g' - 25: 2, # 'h' - 3: 2, # 'i' - 24: 3, # 'j' - 10: 3, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 3, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 2, # 'v' - 57: 0, # 'w' - 58: 1, # 'x' - 11: 2, # 'y' - 22: 1, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 2, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 2, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 1, # 'ş' - }, - 9: { # 't' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 1, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 2, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 1, # 'Z' - 1: 3, # 'a' - 21: 3, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 2, # 'f' - 27: 2, # 'g' - 25: 2, # 'h' - 3: 2, # 'i' - 24: 2, # 'j' - 10: 3, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 2, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 3, # 'v' - 57: 0, # 'w' - 58: 2, # 'x' - 11: 2, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 3, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 2, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 14: { # 'u' - 23: 3, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 3, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 1, # 'H' - 53: 0, # 'I' - 60: 1, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 2, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 3, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 2, # 'Z' - 1: 2, # 'a' - 21: 3, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 2, # 'e' - 18: 2, # 'f' - 27: 3, # 'g' - 25: 3, # 'h' - 3: 3, # 'i' - 24: 2, # 'j' - 10: 3, # 'k' - 5: 0, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 3, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 2, # 'v' - 57: 2, # 'w' - 58: 0, # 'x' - 11: 3, # 'y' - 22: 0, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 3, # 'ü' - 30: 1, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 32: { # 'v' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 0, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 1, # 'j' - 10: 1, # 'k' - 5: 3, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 1, # 'p' - 7: 1, # 'r' - 8: 2, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 1, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 2, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 1, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 57: { # 'w' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 1, # 'a' - 21: 0, # 'b' - 28: 0, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 1, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 1, # 'k' - 5: 0, # 'l' - 13: 0, # 'm' - 4: 1, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 1, # 's' - 9: 0, # 't' - 14: 1, # 'u' - 32: 0, # 'v' - 57: 2, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 0, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 1, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 0, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 58: { # 'x' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 1, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 1, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 0, # 'a' - 21: 1, # 'b' - 28: 0, # 'c' - 12: 2, # 'd' - 2: 1, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 2, # 'i' - 24: 2, # 'j' - 10: 1, # 'k' - 5: 0, # 'l' - 13: 0, # 'm' - 4: 2, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 1, # 'r' - 8: 2, # 's' - 9: 1, # 't' - 14: 0, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 2, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 1, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 11: { # 'y' - 23: 1, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 1, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 1, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 1, # 'Z' - 1: 3, # 'a' - 21: 1, # 'b' - 28: 0, # 'c' - 12: 2, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 2, # 'g' - 25: 2, # 'h' - 3: 2, # 'i' - 24: 1, # 'j' - 10: 2, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 1, # 'p' - 7: 2, # 'r' - 8: 1, # 's' - 9: 2, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 1, # 'x' - 11: 3, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 3, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 2, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 22: { # 'z' - 23: 2, # 'A' - 37: 2, # 'B' - 47: 1, # 'C' - 39: 2, # 'D' - 29: 3, # 'E' - 52: 1, # 'F' - 36: 2, # 'G' - 45: 2, # 'H' - 53: 1, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 2, # 'N' - 42: 2, # 'O' - 48: 2, # 'P' - 44: 1, # 'R' - 35: 1, # 'S' - 31: 3, # 'T' - 51: 2, # 'U' - 38: 2, # 'V' - 62: 0, # 'W' - 43: 2, # 'Y' - 56: 1, # 'Z' - 1: 1, # 'a' - 21: 2, # 'b' - 28: 1, # 'c' - 12: 2, # 'd' - 2: 2, # 'e' - 18: 3, # 'f' - 27: 2, # 'g' - 25: 2, # 'h' - 3: 3, # 'i' - 24: 2, # 'j' - 10: 3, # 'k' - 5: 0, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 15: 2, # 'o' - 26: 2, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 0, # 'u' - 32: 2, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 3, # 'y' - 22: 2, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 2, # 'Ü' - 59: 1, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 2, # 'ö' - 17: 2, # 'ü' - 30: 2, # 'ğ' - 41: 1, # 'İ' - 6: 3, # 'ı' - 40: 1, # 'Ş' - 19: 2, # 'ş' - }, - 63: { # '·' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 0, # 'a' - 21: 0, # 'b' - 28: 0, # 'c' - 12: 0, # 'd' - 2: 1, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 0, # 'k' - 5: 0, # 'l' - 13: 2, # 'm' - 4: 0, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 0, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 54: { # 'Ç' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 1, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 1, # 'G' - 45: 1, # 'H' - 53: 1, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 1, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 2, # 'Y' - 56: 0, # 'Z' - 1: 0, # 'a' - 21: 1, # 'b' - 28: 0, # 'c' - 12: 1, # 'd' - 2: 0, # 'e' - 18: 0, # 'f' - 27: 1, # 'g' - 25: 0, # 'h' - 3: 3, # 'i' - 24: 0, # 'j' - 10: 1, # 'k' - 5: 0, # 'l' - 13: 0, # 'm' - 4: 2, # 'n' - 15: 1, # 'o' - 26: 0, # 'p' - 7: 2, # 'r' - 8: 0, # 's' - 9: 1, # 't' - 14: 0, # 'u' - 32: 2, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 2, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 1, # 'ş' - }, - 50: { # 'Ö' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 1, # 'D' - 29: 2, # 'E' - 52: 0, # 'F' - 36: 1, # 'G' - 45: 2, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 1, # 'N' - 42: 2, # 'O' - 48: 2, # 'P' - 44: 1, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 2, # 'Y' - 56: 0, # 'Z' - 1: 0, # 'a' - 21: 2, # 'b' - 28: 1, # 'c' - 12: 2, # 'd' - 2: 0, # 'e' - 18: 1, # 'f' - 27: 1, # 'g' - 25: 1, # 'h' - 3: 2, # 'i' - 24: 0, # 'j' - 10: 2, # 'k' - 5: 0, # 'l' - 13: 0, # 'm' - 4: 3, # 'n' - 15: 2, # 'o' - 26: 2, # 'p' - 7: 3, # 'r' - 8: 1, # 's' - 9: 2, # 't' - 14: 0, # 'u' - 32: 1, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 1, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 2, # 'ö' - 17: 2, # 'ü' - 30: 1, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 1, # 'ş' - }, - 55: { # 'Ü' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 2, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 1, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 1, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 2, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 1, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 0, # 'k' - 5: 1, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 1, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 1, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 1, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 1, # 'İ' - 6: 0, # 'ı' - 40: 0, # 'Ş' - 19: 1, # 'ş' - }, - 59: { # 'â' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 1, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 1, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 2, # 'a' - 21: 0, # 'b' - 28: 0, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 0, # 'j' - 10: 0, # 'k' - 5: 0, # 'l' - 13: 2, # 'm' - 4: 0, # 'n' - 15: 1, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 2, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 1, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 1, # 'ı' - 40: 1, # 'Ş' - 19: 0, # 'ş' - }, - 33: { # 'ç' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 3, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 2, # 'T' - 51: 0, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 0, # 'Z' - 1: 0, # 'a' - 21: 3, # 'b' - 28: 0, # 'c' - 12: 2, # 'd' - 2: 0, # 'e' - 18: 2, # 'f' - 27: 1, # 'g' - 25: 3, # 'h' - 3: 3, # 'i' - 24: 0, # 'j' - 10: 3, # 'k' - 5: 0, # 'l' - 13: 0, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 1, # 'p' - 7: 3, # 'r' - 8: 2, # 's' - 9: 3, # 't' - 14: 0, # 'u' - 32: 2, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 2, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 1, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 61: { # 'î' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 0, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 0, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 1, # 'Z' - 1: 2, # 'a' - 21: 0, # 'b' - 28: 0, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 1, # 'j' - 10: 0, # 'k' - 5: 0, # 'l' - 13: 1, # 'm' - 4: 1, # 'n' - 15: 0, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 1, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 1, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 1, # 'î' - 34: 0, # 'ö' - 17: 0, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 1, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 34: { # 'ö' - 23: 0, # 'A' - 37: 1, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 2, # 'F' - 36: 1, # 'G' - 45: 1, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 1, # 'L' - 20: 0, # 'M' - 46: 1, # 'N' - 42: 1, # 'O' - 48: 2, # 'P' - 44: 1, # 'R' - 35: 1, # 'S' - 31: 1, # 'T' - 51: 1, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 1, # 'Z' - 1: 3, # 'a' - 21: 1, # 'b' - 28: 2, # 'c' - 12: 1, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 2, # 'g' - 25: 2, # 'h' - 3: 1, # 'i' - 24: 2, # 'j' - 10: 1, # 'k' - 5: 2, # 'l' - 13: 3, # 'm' - 4: 2, # 'n' - 15: 2, # 'o' - 26: 0, # 'p' - 7: 0, # 'r' - 8: 3, # 's' - 9: 1, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 1, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 2, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 2, # 'ç' - 61: 0, # 'î' - 34: 2, # 'ö' - 17: 0, # 'ü' - 30: 2, # 'ğ' - 41: 1, # 'İ' - 6: 1, # 'ı' - 40: 2, # 'Ş' - 19: 1, # 'ş' - }, - 17: { # 'ü' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 0, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 1, # 'J' - 16: 1, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 0, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 1, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 0, # 'Y' - 56: 1, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 0, # 'c' - 12: 1, # 'd' - 2: 3, # 'e' - 18: 1, # 'f' - 27: 2, # 'g' - 25: 0, # 'h' - 3: 1, # 'i' - 24: 1, # 'j' - 10: 2, # 'k' - 5: 3, # 'l' - 13: 2, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 2, # 'p' - 7: 2, # 'r' - 8: 3, # 's' - 9: 2, # 't' - 14: 3, # 'u' - 32: 1, # 'v' - 57: 1, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 2, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 30: { # 'ğ' - 23: 0, # 'A' - 37: 2, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 2, # 'F' - 36: 1, # 'G' - 45: 0, # 'H' - 53: 1, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 1, # 'M' - 46: 2, # 'N' - 42: 2, # 'O' - 48: 1, # 'P' - 44: 1, # 'R' - 35: 0, # 'S' - 31: 1, # 'T' - 51: 0, # 'U' - 38: 2, # 'V' - 62: 0, # 'W' - 43: 2, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 0, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 2, # 'e' - 18: 0, # 'f' - 27: 0, # 'g' - 25: 0, # 'h' - 3: 0, # 'i' - 24: 3, # 'j' - 10: 1, # 'k' - 5: 2, # 'l' - 13: 3, # 'm' - 4: 0, # 'n' - 15: 1, # 'o' - 26: 0, # 'p' - 7: 1, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 2, # 'Ç' - 50: 2, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 0, # 'î' - 34: 2, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 2, # 'İ' - 6: 2, # 'ı' - 40: 2, # 'Ş' - 19: 1, # 'ş' - }, - 41: { # 'İ' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 1, # 'D' - 29: 1, # 'E' - 52: 0, # 'F' - 36: 2, # 'G' - 45: 2, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 1, # 'N' - 42: 1, # 'O' - 48: 2, # 'P' - 44: 0, # 'R' - 35: 1, # 'S' - 31: 1, # 'T' - 51: 1, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 2, # 'Y' - 56: 0, # 'Z' - 1: 1, # 'a' - 21: 2, # 'b' - 28: 1, # 'c' - 12: 2, # 'd' - 2: 1, # 'e' - 18: 0, # 'f' - 27: 3, # 'g' - 25: 2, # 'h' - 3: 2, # 'i' - 24: 2, # 'j' - 10: 2, # 'k' - 5: 0, # 'l' - 13: 1, # 'm' - 4: 3, # 'n' - 15: 1, # 'o' - 26: 1, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 2, # 't' - 14: 0, # 'u' - 32: 0, # 'v' - 57: 1, # 'w' - 58: 0, # 'x' - 11: 2, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 1, # 'Ü' - 59: 1, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 1, # 'ö' - 17: 1, # 'ü' - 30: 2, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 1, # 'ş' - }, - 6: { # 'ı' - 23: 2, # 'A' - 37: 0, # 'B' - 47: 0, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 0, # 'F' - 36: 1, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 2, # 'J' - 16: 3, # 'K' - 49: 0, # 'L' - 20: 3, # 'M' - 46: 1, # 'N' - 42: 0, # 'O' - 48: 0, # 'P' - 44: 0, # 'R' - 35: 0, # 'S' - 31: 2, # 'T' - 51: 0, # 'U' - 38: 0, # 'V' - 62: 0, # 'W' - 43: 2, # 'Y' - 56: 1, # 'Z' - 1: 3, # 'a' - 21: 2, # 'b' - 28: 1, # 'c' - 12: 3, # 'd' - 2: 3, # 'e' - 18: 3, # 'f' - 27: 3, # 'g' - 25: 2, # 'h' - 3: 3, # 'i' - 24: 3, # 'j' - 10: 3, # 'k' - 5: 3, # 'l' - 13: 3, # 'm' - 4: 3, # 'n' - 15: 0, # 'o' - 26: 3, # 'p' - 7: 3, # 'r' - 8: 3, # 's' - 9: 3, # 't' - 14: 3, # 'u' - 32: 3, # 'v' - 57: 1, # 'w' - 58: 1, # 'x' - 11: 3, # 'y' - 22: 0, # 'z' - 63: 1, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 2, # 'ç' - 61: 0, # 'î' - 34: 0, # 'ö' - 17: 3, # 'ü' - 30: 0, # 'ğ' - 41: 0, # 'İ' - 6: 3, # 'ı' - 40: 0, # 'Ş' - 19: 0, # 'ş' - }, - 40: { # 'Ş' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 1, # 'D' - 29: 1, # 'E' - 52: 0, # 'F' - 36: 1, # 'G' - 45: 2, # 'H' - 53: 1, # 'I' - 60: 0, # 'J' - 16: 0, # 'K' - 49: 0, # 'L' - 20: 2, # 'M' - 46: 1, # 'N' - 42: 1, # 'O' - 48: 2, # 'P' - 44: 2, # 'R' - 35: 1, # 'S' - 31: 1, # 'T' - 51: 0, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 2, # 'Y' - 56: 1, # 'Z' - 1: 0, # 'a' - 21: 2, # 'b' - 28: 0, # 'c' - 12: 2, # 'd' - 2: 0, # 'e' - 18: 3, # 'f' - 27: 0, # 'g' - 25: 2, # 'h' - 3: 3, # 'i' - 24: 2, # 'j' - 10: 1, # 'k' - 5: 0, # 'l' - 13: 1, # 'm' - 4: 3, # 'n' - 15: 2, # 'o' - 26: 0, # 'p' - 7: 3, # 'r' - 8: 2, # 's' - 9: 2, # 't' - 14: 1, # 'u' - 32: 3, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 2, # 'y' - 22: 0, # 'z' - 63: 0, # '·' - 54: 0, # 'Ç' - 50: 0, # 'Ö' - 55: 1, # 'Ü' - 59: 0, # 'â' - 33: 0, # 'ç' - 61: 0, # 'î' - 34: 2, # 'ö' - 17: 1, # 'ü' - 30: 2, # 'ğ' - 41: 0, # 'İ' - 6: 2, # 'ı' - 40: 1, # 'Ş' - 19: 2, # 'ş' - }, - 19: { # 'ş' - 23: 0, # 'A' - 37: 0, # 'B' - 47: 1, # 'C' - 39: 0, # 'D' - 29: 0, # 'E' - 52: 2, # 'F' - 36: 1, # 'G' - 45: 0, # 'H' - 53: 0, # 'I' - 60: 0, # 'J' - 16: 3, # 'K' - 49: 2, # 'L' - 20: 0, # 'M' - 46: 1, # 'N' - 42: 1, # 'O' - 48: 1, # 'P' - 44: 1, # 'R' - 35: 1, # 'S' - 31: 0, # 'T' - 51: 1, # 'U' - 38: 1, # 'V' - 62: 0, # 'W' - 43: 1, # 'Y' - 56: 0, # 'Z' - 1: 3, # 'a' - 21: 1, # 'b' - 28: 2, # 'c' - 12: 0, # 'd' - 2: 3, # 'e' - 18: 0, # 'f' - 27: 2, # 'g' - 25: 1, # 'h' - 3: 1, # 'i' - 24: 0, # 'j' - 10: 2, # 'k' - 5: 2, # 'l' - 13: 3, # 'm' - 4: 0, # 'n' - 15: 0, # 'o' - 26: 1, # 'p' - 7: 3, # 'r' - 8: 0, # 's' - 9: 0, # 't' - 14: 3, # 'u' - 32: 0, # 'v' - 57: 0, # 'w' - 58: 0, # 'x' - 11: 0, # 'y' - 22: 2, # 'z' - 63: 0, # '·' - 54: 1, # 'Ç' - 50: 2, # 'Ö' - 55: 0, # 'Ü' - 59: 0, # 'â' - 33: 1, # 'ç' - 61: 1, # 'î' - 34: 2, # 'ö' - 17: 0, # 'ü' - 30: 1, # 'ğ' - 41: 1, # 'İ' - 6: 1, # 'ı' - 40: 1, # 'Ş' - 19: 1, # 'ş' - }, -} - -# 255: Undefined characters that did not exist in training text -# 254: Carriage/Return -# 253: symbol (punctuation) that does not belong to word -# 252: 0 - 9 -# 251: Control characters - -# Character Mapping Table(s): -ISO_8859_9_TURKISH_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 255, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 255, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 255, # ' ' - 33: 255, # '!' - 34: 255, # '"' - 35: 255, # '#' - 36: 255, # '$' - 37: 255, # '%' - 38: 255, # '&' - 39: 255, # "'" - 40: 255, # '(' - 41: 255, # ')' - 42: 255, # '*' - 43: 255, # '+' - 44: 255, # ',' - 45: 255, # '-' - 46: 255, # '.' - 47: 255, # '/' - 48: 255, # '0' - 49: 255, # '1' - 50: 255, # '2' - 51: 255, # '3' - 52: 255, # '4' - 53: 255, # '5' - 54: 255, # '6' - 55: 255, # '7' - 56: 255, # '8' - 57: 255, # '9' - 58: 255, # ':' - 59: 255, # ';' - 60: 255, # '<' - 61: 255, # '=' - 62: 255, # '>' - 63: 255, # '?' - 64: 255, # '@' - 65: 23, # 'A' - 66: 37, # 'B' - 67: 47, # 'C' - 68: 39, # 'D' - 69: 29, # 'E' - 70: 52, # 'F' - 71: 36, # 'G' - 72: 45, # 'H' - 73: 53, # 'I' - 74: 60, # 'J' - 75: 16, # 'K' - 76: 49, # 'L' - 77: 20, # 'M' - 78: 46, # 'N' - 79: 42, # 'O' - 80: 48, # 'P' - 81: 69, # 'Q' - 82: 44, # 'R' - 83: 35, # 'S' - 84: 31, # 'T' - 85: 51, # 'U' - 86: 38, # 'V' - 87: 62, # 'W' - 88: 65, # 'X' - 89: 43, # 'Y' - 90: 56, # 'Z' - 91: 255, # '[' - 92: 255, # '\\' - 93: 255, # ']' - 94: 255, # '^' - 95: 255, # '_' - 96: 255, # '`' - 97: 1, # 'a' - 98: 21, # 'b' - 99: 28, # 'c' - 100: 12, # 'd' - 101: 2, # 'e' - 102: 18, # 'f' - 103: 27, # 'g' - 104: 25, # 'h' - 105: 3, # 'i' - 106: 24, # 'j' - 107: 10, # 'k' - 108: 5, # 'l' - 109: 13, # 'm' - 110: 4, # 'n' - 111: 15, # 'o' - 112: 26, # 'p' - 113: 64, # 'q' - 114: 7, # 'r' - 115: 8, # 's' - 116: 9, # 't' - 117: 14, # 'u' - 118: 32, # 'v' - 119: 57, # 'w' - 120: 58, # 'x' - 121: 11, # 'y' - 122: 22, # 'z' - 123: 255, # '{' - 124: 255, # '|' - 125: 255, # '}' - 126: 255, # '~' - 127: 255, # '\x7f' - 128: 180, # '\x80' - 129: 179, # '\x81' - 130: 178, # '\x82' - 131: 177, # '\x83' - 132: 176, # '\x84' - 133: 175, # '\x85' - 134: 174, # '\x86' - 135: 173, # '\x87' - 136: 172, # '\x88' - 137: 171, # '\x89' - 138: 170, # '\x8a' - 139: 169, # '\x8b' - 140: 168, # '\x8c' - 141: 167, # '\x8d' - 142: 166, # '\x8e' - 143: 165, # '\x8f' - 144: 164, # '\x90' - 145: 163, # '\x91' - 146: 162, # '\x92' - 147: 161, # '\x93' - 148: 160, # '\x94' - 149: 159, # '\x95' - 150: 101, # '\x96' - 151: 158, # '\x97' - 152: 157, # '\x98' - 153: 156, # '\x99' - 154: 155, # '\x9a' - 155: 154, # '\x9b' - 156: 153, # '\x9c' - 157: 152, # '\x9d' - 158: 151, # '\x9e' - 159: 106, # '\x9f' - 160: 150, # '\xa0' - 161: 149, # '¡' - 162: 148, # '¢' - 163: 147, # '£' - 164: 146, # '¤' - 165: 145, # '¥' - 166: 144, # '¦' - 167: 100, # '§' - 168: 143, # '¨' - 169: 142, # '©' - 170: 141, # 'ª' - 171: 140, # '«' - 172: 139, # '¬' - 173: 138, # '\xad' - 174: 137, # '®' - 175: 136, # '¯' - 176: 94, # '°' - 177: 80, # '±' - 178: 93, # '²' - 179: 135, # '³' - 180: 105, # '´' - 181: 134, # 'µ' - 182: 133, # '¶' - 183: 63, # '·' - 184: 132, # '¸' - 185: 131, # '¹' - 186: 130, # 'º' - 187: 129, # '»' - 188: 128, # '¼' - 189: 127, # '½' - 190: 126, # '¾' - 191: 125, # '¿' - 192: 124, # 'À' - 193: 104, # 'Á' - 194: 73, # 'Â' - 195: 99, # 'Ã' - 196: 79, # 'Ä' - 197: 85, # 'Å' - 198: 123, # 'Æ' - 199: 54, # 'Ç' - 200: 122, # 'È' - 201: 98, # 'É' - 202: 92, # 'Ê' - 203: 121, # 'Ë' - 204: 120, # 'Ì' - 205: 91, # 'Í' - 206: 103, # 'Î' - 207: 119, # 'Ï' - 208: 68, # 'Ğ' - 209: 118, # 'Ñ' - 210: 117, # 'Ò' - 211: 97, # 'Ó' - 212: 116, # 'Ô' - 213: 115, # 'Õ' - 214: 50, # 'Ö' - 215: 90, # '×' - 216: 114, # 'Ø' - 217: 113, # 'Ù' - 218: 112, # 'Ú' - 219: 111, # 'Û' - 220: 55, # 'Ü' - 221: 41, # 'İ' - 222: 40, # 'Ş' - 223: 86, # 'ß' - 224: 89, # 'à' - 225: 70, # 'á' - 226: 59, # 'â' - 227: 78, # 'ã' - 228: 71, # 'ä' - 229: 82, # 'å' - 230: 88, # 'æ' - 231: 33, # 'ç' - 232: 77, # 'è' - 233: 66, # 'é' - 234: 84, # 'ê' - 235: 83, # 'ë' - 236: 110, # 'ì' - 237: 75, # 'í' - 238: 61, # 'î' - 239: 96, # 'ï' - 240: 30, # 'ğ' - 241: 67, # 'ñ' - 242: 109, # 'ò' - 243: 74, # 'ó' - 244: 87, # 'ô' - 245: 102, # 'õ' - 246: 34, # 'ö' - 247: 95, # '÷' - 248: 81, # 'ø' - 249: 108, # 'ù' - 250: 76, # 'ú' - 251: 72, # 'û' - 252: 17, # 'ü' - 253: 6, # 'ı' - 254: 19, # 'ş' - 255: 107, # 'ÿ' -} - -ISO_8859_9_TURKISH_MODEL = SingleByteCharSetModel( - charset_name="ISO-8859-9", - language="Turkish", - char_to_order_map=ISO_8859_9_TURKISH_CHAR_TO_ORDER, - language_model=TURKISH_LANG_MODEL, - typical_positive_ratio=0.97029, - keep_ascii_letters=True, - alphabet="ABCDEFGHIJKLMNOPRSTUVYZabcdefghijklmnoprstuvyzÂÇÎÖÛÜâçîöûüĞğİıŞş", -) diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/latin1prober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/latin1prober.py deleted file mode 100644 index 59a01d9..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/latin1prober.py +++ /dev/null @@ -1,147 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Universal charset detector code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 2001 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# Shy Shalom - original C code -# -# 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 .charsetprober import CharSetProber -from .enums import ProbingState - -FREQ_CAT_NUM = 4 - -UDF = 0 # undefined -OTH = 1 # other -ASC = 2 # ascii capital letter -ASS = 3 # ascii small letter -ACV = 4 # accent capital vowel -ACO = 5 # accent capital other -ASV = 6 # accent small vowel -ASO = 7 # accent small other -CLASS_NUM = 8 # total classes - -# fmt: off -Latin1_CharToClass = ( - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 00 - 07 - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 08 - 0F - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 10 - 17 - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 18 - 1F - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 20 - 27 - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 28 - 2F - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 30 - 37 - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 38 - 3F - OTH, ASC, ASC, ASC, ASC, ASC, ASC, ASC, # 40 - 47 - ASC, ASC, ASC, ASC, ASC, ASC, ASC, ASC, # 48 - 4F - ASC, ASC, ASC, ASC, ASC, ASC, ASC, ASC, # 50 - 57 - ASC, ASC, ASC, OTH, OTH, OTH, OTH, OTH, # 58 - 5F - OTH, ASS, ASS, ASS, ASS, ASS, ASS, ASS, # 60 - 67 - ASS, ASS, ASS, ASS, ASS, ASS, ASS, ASS, # 68 - 6F - ASS, ASS, ASS, ASS, ASS, ASS, ASS, ASS, # 70 - 77 - ASS, ASS, ASS, OTH, OTH, OTH, OTH, OTH, # 78 - 7F - OTH, UDF, OTH, ASO, OTH, OTH, OTH, OTH, # 80 - 87 - OTH, OTH, ACO, OTH, ACO, UDF, ACO, UDF, # 88 - 8F - UDF, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 90 - 97 - OTH, OTH, ASO, OTH, ASO, UDF, ASO, ACO, # 98 - 9F - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # A0 - A7 - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # A8 - AF - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # B0 - B7 - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # B8 - BF - ACV, ACV, ACV, ACV, ACV, ACV, ACO, ACO, # C0 - C7 - ACV, ACV, ACV, ACV, ACV, ACV, ACV, ACV, # C8 - CF - ACO, ACO, ACV, ACV, ACV, ACV, ACV, OTH, # D0 - D7 - ACV, ACV, ACV, ACV, ACV, ACO, ACO, ACO, # D8 - DF - ASV, ASV, ASV, ASV, ASV, ASV, ASO, ASO, # E0 - E7 - ASV, ASV, ASV, ASV, ASV, ASV, ASV, ASV, # E8 - EF - ASO, ASO, ASV, ASV, ASV, ASV, ASV, OTH, # F0 - F7 - ASV, ASV, ASV, ASV, ASV, ASO, ASO, ASO, # F8 - FF -) - -# 0 : illegal -# 1 : very unlikely -# 2 : normal -# 3 : very likely -Latin1ClassModel = ( -# UDF OTH ASC ASS ACV ACO ASV ASO - 0, 0, 0, 0, 0, 0, 0, 0, # UDF - 0, 3, 3, 3, 3, 3, 3, 3, # OTH - 0, 3, 3, 3, 3, 3, 3, 3, # ASC - 0, 3, 3, 3, 1, 1, 3, 3, # ASS - 0, 3, 3, 3, 1, 2, 1, 2, # ACV - 0, 3, 3, 3, 3, 3, 3, 3, # ACO - 0, 3, 1, 3, 1, 1, 1, 3, # ASV - 0, 3, 1, 3, 1, 1, 3, 3, # ASO -) -# fmt: on - - -class Latin1Prober(CharSetProber): - def __init__(self) -> None: - super().__init__() - self._last_char_class = OTH - self._freq_counter: List[int] = [] - self.reset() - - def reset(self) -> None: - self._last_char_class = OTH - self._freq_counter = [0] * FREQ_CAT_NUM - super().reset() - - @property - def charset_name(self) -> str: - return "ISO-8859-1" - - @property - def language(self) -> str: - return "" - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - byte_str = self.remove_xml_tags(byte_str) - for c in byte_str: - char_class = Latin1_CharToClass[c] - freq = Latin1ClassModel[(self._last_char_class * CLASS_NUM) + char_class] - if freq == 0: - self._state = ProbingState.NOT_ME - break - self._freq_counter[freq] += 1 - self._last_char_class = char_class - - return self.state - - def get_confidence(self) -> float: - if self.state == ProbingState.NOT_ME: - return 0.01 - - total = sum(self._freq_counter) - confidence = ( - 0.0 - if total < 0.01 - else (self._freq_counter[3] - self._freq_counter[1] * 20.0) / total - ) - confidence = max(confidence, 0.0) - # lower the confidence of latin1 so that other more accurate - # detector can take priority. - confidence *= 0.73 - return confidence diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/macromanprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/macromanprober.py deleted file mode 100644 index 1425d10..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/macromanprober.py +++ /dev/null @@ -1,162 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# This code was modified from latin1prober.py by Rob Speer . -# The Original Code is Mozilla Universal charset detector code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 2001 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Rob Speer - adapt to MacRoman encoding -# Mark Pilgrim - port to Python -# Shy Shalom - original C code -# -# 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 .charsetprober import CharSetProber -from .enums import ProbingState - -FREQ_CAT_NUM = 4 - -UDF = 0 # undefined -OTH = 1 # other -ASC = 2 # ascii capital letter -ASS = 3 # ascii small letter -ACV = 4 # accent capital vowel -ACO = 5 # accent capital other -ASV = 6 # accent small vowel -ASO = 7 # accent small other -ODD = 8 # character that is unlikely to appear -CLASS_NUM = 9 # total classes - -# The change from Latin1 is that we explicitly look for extended characters -# that are infrequently-occurring symbols, and consider them to always be -# improbable. This should let MacRoman get out of the way of more likely -# encodings in most situations. - -# fmt: off -MacRoman_CharToClass = ( - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 00 - 07 - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 08 - 0F - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 10 - 17 - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 18 - 1F - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 20 - 27 - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 28 - 2F - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 30 - 37 - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 38 - 3F - OTH, ASC, ASC, ASC, ASC, ASC, ASC, ASC, # 40 - 47 - ASC, ASC, ASC, ASC, ASC, ASC, ASC, ASC, # 48 - 4F - ASC, ASC, ASC, ASC, ASC, ASC, ASC, ASC, # 50 - 57 - ASC, ASC, ASC, OTH, OTH, OTH, OTH, OTH, # 58 - 5F - OTH, ASS, ASS, ASS, ASS, ASS, ASS, ASS, # 60 - 67 - ASS, ASS, ASS, ASS, ASS, ASS, ASS, ASS, # 68 - 6F - ASS, ASS, ASS, ASS, ASS, ASS, ASS, ASS, # 70 - 77 - ASS, ASS, ASS, OTH, OTH, OTH, OTH, OTH, # 78 - 7F - ACV, ACV, ACO, ACV, ACO, ACV, ACV, ASV, # 80 - 87 - ASV, ASV, ASV, ASV, ASV, ASO, ASV, ASV, # 88 - 8F - ASV, ASV, ASV, ASV, ASV, ASV, ASO, ASV, # 90 - 97 - ASV, ASV, ASV, ASV, ASV, ASV, ASV, ASV, # 98 - 9F - OTH, OTH, OTH, OTH, OTH, OTH, OTH, ASO, # A0 - A7 - OTH, OTH, ODD, ODD, OTH, OTH, ACV, ACV, # A8 - AF - OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # B0 - B7 - OTH, OTH, OTH, OTH, OTH, OTH, ASV, ASV, # B8 - BF - OTH, OTH, ODD, OTH, ODD, OTH, OTH, OTH, # C0 - C7 - OTH, OTH, OTH, ACV, ACV, ACV, ACV, ASV, # C8 - CF - OTH, OTH, OTH, OTH, OTH, OTH, OTH, ODD, # D0 - D7 - ASV, ACV, ODD, OTH, OTH, OTH, OTH, OTH, # D8 - DF - OTH, OTH, OTH, OTH, OTH, ACV, ACV, ACV, # E0 - E7 - ACV, ACV, ACV, ACV, ACV, ACV, ACV, ACV, # E8 - EF - ODD, ACV, ACV, ACV, ACV, ASV, ODD, ODD, # F0 - F7 - ODD, ODD, ODD, ODD, ODD, ODD, ODD, ODD, # F8 - FF -) - -# 0 : illegal -# 1 : very unlikely -# 2 : normal -# 3 : very likely -MacRomanClassModel = ( -# UDF OTH ASC ASS ACV ACO ASV ASO ODD - 0, 0, 0, 0, 0, 0, 0, 0, 0, # UDF - 0, 3, 3, 3, 3, 3, 3, 3, 1, # OTH - 0, 3, 3, 3, 3, 3, 3, 3, 1, # ASC - 0, 3, 3, 3, 1, 1, 3, 3, 1, # ASS - 0, 3, 3, 3, 1, 2, 1, 2, 1, # ACV - 0, 3, 3, 3, 3, 3, 3, 3, 1, # ACO - 0, 3, 1, 3, 1, 1, 1, 3, 1, # ASV - 0, 3, 1, 3, 1, 1, 3, 3, 1, # ASO - 0, 1, 1, 1, 1, 1, 1, 1, 1, # ODD -) -# fmt: on - - -class MacRomanProber(CharSetProber): - def __init__(self) -> None: - super().__init__() - self._last_char_class = OTH - self._freq_counter: List[int] = [] - self.reset() - - def reset(self) -> None: - self._last_char_class = OTH - self._freq_counter = [0] * FREQ_CAT_NUM - - # express the prior that MacRoman is a somewhat rare encoding; - # this can be done by starting out in a slightly improbable state - # that must be overcome - self._freq_counter[2] = 10 - - super().reset() - - @property - def charset_name(self) -> str: - return "MacRoman" - - @property - def language(self) -> str: - return "" - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - byte_str = self.remove_xml_tags(byte_str) - for c in byte_str: - char_class = MacRoman_CharToClass[c] - freq = MacRomanClassModel[(self._last_char_class * CLASS_NUM) + char_class] - if freq == 0: - self._state = ProbingState.NOT_ME - break - self._freq_counter[freq] += 1 - self._last_char_class = char_class - - return self.state - - def get_confidence(self) -> float: - if self.state == ProbingState.NOT_ME: - return 0.01 - - total = sum(self._freq_counter) - confidence = ( - 0.0 - if total < 0.01 - else (self._freq_counter[3] - self._freq_counter[1] * 20.0) / total - ) - confidence = max(confidence, 0.0) - # lower the confidence of MacRoman so that other more accurate - # detector can take priority. - confidence *= 0.73 - return confidence diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py deleted file mode 100644 index 666307e..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py +++ /dev/null @@ -1,95 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Universal charset detector code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 2001 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# Shy Shalom - original C code -# Proofpoint, Inc. -# -# 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 Optional, Union - -from .chardistribution import CharDistributionAnalysis -from .charsetprober import CharSetProber -from .codingstatemachine import CodingStateMachine -from .enums import LanguageFilter, MachineState, ProbingState - - -class MultiByteCharSetProber(CharSetProber): - """ - MultiByteCharSetProber - """ - - def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None: - super().__init__(lang_filter=lang_filter) - self.distribution_analyzer: Optional[CharDistributionAnalysis] = None - self.coding_sm: Optional[CodingStateMachine] = None - self._last_char = bytearray(b"\0\0") - - def reset(self) -> None: - super().reset() - if self.coding_sm: - self.coding_sm.reset() - if self.distribution_analyzer: - self.distribution_analyzer.reset() - self._last_char = bytearray(b"\0\0") - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - assert self.coding_sm is not None - assert self.distribution_analyzer is not None - - for i, byte in enumerate(byte_str): - coding_state = self.coding_sm.next_state(byte) - if coding_state == MachineState.ERROR: - self.logger.debug( - "%s %s prober hit error at byte %s", - self.charset_name, - self.language, - i, - ) - self._state = ProbingState.NOT_ME - break - if coding_state == MachineState.ITS_ME: - self._state = ProbingState.FOUND_IT - break - if coding_state == MachineState.START: - char_len = self.coding_sm.get_current_charlen() - if i == 0: - self._last_char[1] = byte - self.distribution_analyzer.feed(self._last_char, char_len) - else: - self.distribution_analyzer.feed(byte_str[i - 1 : i + 1], char_len) - - self._last_char[0] = byte_str[-1] - - if self.state == ProbingState.DETECTING: - if self.distribution_analyzer.got_enough_data() and ( - self.get_confidence() > self.SHORTCUT_THRESHOLD - ): - self._state = ProbingState.FOUND_IT - - return self.state - - def get_confidence(self) -> float: - assert self.distribution_analyzer is not None - return self.distribution_analyzer.get_confidence() diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py deleted file mode 100644 index 6cb9cc7..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py +++ /dev/null @@ -1,57 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Universal charset detector code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 2001 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# Shy Shalom - original C code -# Proofpoint, Inc. -# -# 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 .big5prober import Big5Prober -from .charsetgroupprober import CharSetGroupProber -from .cp949prober import CP949Prober -from .enums import LanguageFilter -from .eucjpprober import EUCJPProber -from .euckrprober import EUCKRProber -from .euctwprober import EUCTWProber -from .gb2312prober import GB2312Prober -from .johabprober import JOHABProber -from .sjisprober import SJISProber -from .utf8prober import UTF8Prober - - -class MBCSGroupProber(CharSetGroupProber): - def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None: - super().__init__(lang_filter=lang_filter) - self.probers = [ - UTF8Prober(), - SJISProber(), - EUCJPProber(), - GB2312Prober(), - EUCKRProber(), - CP949Prober(), - Big5Prober(), - EUCTWProber(), - JOHABProber(), - ] - self.reset() diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/mbcssm.py b/myenv/Lib/site-packages/pip/_vendor/chardet/mbcssm.py deleted file mode 100644 index 7bbe97e..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/mbcssm.py +++ /dev/null @@ -1,661 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 .codingstatemachinedict import CodingStateMachineDict -from .enums import MachineState - -# BIG5 - -# fmt: off -BIG5_CLS = ( - 1, 1, 1, 1, 1, 1, 1, 1, # 00 - 07 #allow 0x00 as legal value - 1, 1, 1, 1, 1, 1, 0, 0, # 08 - 0f - 1, 1, 1, 1, 1, 1, 1, 1, # 10 - 17 - 1, 1, 1, 0, 1, 1, 1, 1, # 18 - 1f - 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 27 - 1, 1, 1, 1, 1, 1, 1, 1, # 28 - 2f - 1, 1, 1, 1, 1, 1, 1, 1, # 30 - 37 - 1, 1, 1, 1, 1, 1, 1, 1, # 38 - 3f - 2, 2, 2, 2, 2, 2, 2, 2, # 40 - 47 - 2, 2, 2, 2, 2, 2, 2, 2, # 48 - 4f - 2, 2, 2, 2, 2, 2, 2, 2, # 50 - 57 - 2, 2, 2, 2, 2, 2, 2, 2, # 58 - 5f - 2, 2, 2, 2, 2, 2, 2, 2, # 60 - 67 - 2, 2, 2, 2, 2, 2, 2, 2, # 68 - 6f - 2, 2, 2, 2, 2, 2, 2, 2, # 70 - 77 - 2, 2, 2, 2, 2, 2, 2, 1, # 78 - 7f - 4, 4, 4, 4, 4, 4, 4, 4, # 80 - 87 - 4, 4, 4, 4, 4, 4, 4, 4, # 88 - 8f - 4, 4, 4, 4, 4, 4, 4, 4, # 90 - 97 - 4, 4, 4, 4, 4, 4, 4, 4, # 98 - 9f - 4, 3, 3, 3, 3, 3, 3, 3, # a0 - a7 - 3, 3, 3, 3, 3, 3, 3, 3, # a8 - af - 3, 3, 3, 3, 3, 3, 3, 3, # b0 - b7 - 3, 3, 3, 3, 3, 3, 3, 3, # b8 - bf - 3, 3, 3, 3, 3, 3, 3, 3, # c0 - c7 - 3, 3, 3, 3, 3, 3, 3, 3, # c8 - cf - 3, 3, 3, 3, 3, 3, 3, 3, # d0 - d7 - 3, 3, 3, 3, 3, 3, 3, 3, # d8 - df - 3, 3, 3, 3, 3, 3, 3, 3, # e0 - e7 - 3, 3, 3, 3, 3, 3, 3, 3, # e8 - ef - 3, 3, 3, 3, 3, 3, 3, 3, # f0 - f7 - 3, 3, 3, 3, 3, 3, 3, 0 # f8 - ff -) - -BIG5_ST = ( - MachineState.ERROR,MachineState.START,MachineState.START, 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 - MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,#08-0f - MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START#10-17 -) -# fmt: on - -BIG5_CHAR_LEN_TABLE = (0, 1, 1, 2, 0) - -BIG5_SM_MODEL: CodingStateMachineDict = { - "class_table": BIG5_CLS, - "class_factor": 5, - "state_table": BIG5_ST, - "char_len_table": BIG5_CHAR_LEN_TABLE, - "name": "Big5", -} - -# CP949 -# fmt: off -CP949_CLS = ( - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, # 00 - 0f - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, # 10 - 1f - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 2f - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, # 30 - 3f - 1, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, # 40 - 4f - 4, 4, 5, 5, 5, 5, 5, 5, 5, 5, 5, 1, 1, 1, 1, 1, # 50 - 5f - 1, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, # 60 - 6f - 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 1, 1, 1, 1, 1, # 70 - 7f - 0, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, # 80 - 8f - 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, # 90 - 9f - 6, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 8, 8, 8, # a0 - af - 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, # b0 - bf - 7, 7, 7, 7, 7, 7, 9, 2, 2, 3, 2, 2, 2, 2, 2, 2, # c0 - cf - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, # d0 - df - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, # e0 - ef - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 0, # f0 - ff -) - -CP949_ST = ( -#cls= 0 1 2 3 4 5 6 7 8 9 # previous state = - MachineState.ERROR,MachineState.START, 3,MachineState.ERROR,MachineState.START,MachineState.START, 4, 5,MachineState.ERROR, 6, # MachineState.START - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, # MachineState.ERROR - MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME, # MachineState.ITS_ME - MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START, # 3 - MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START, # 4 - MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START, # 5 - MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START, # 6 -) -# fmt: on - -CP949_CHAR_LEN_TABLE = (0, 1, 2, 0, 1, 1, 2, 2, 0, 2) - -CP949_SM_MODEL: CodingStateMachineDict = { - "class_table": CP949_CLS, - "class_factor": 10, - "state_table": CP949_ST, - "char_len_table": CP949_CHAR_LEN_TABLE, - "name": "CP949", -} - -# EUC-JP -# fmt: off -EUCJP_CLS = ( - 4, 4, 4, 4, 4, 4, 4, 4, # 00 - 07 - 4, 4, 4, 4, 4, 4, 5, 5, # 08 - 0f - 4, 4, 4, 4, 4, 4, 4, 4, # 10 - 17 - 4, 4, 4, 5, 4, 4, 4, 4, # 18 - 1f - 4, 4, 4, 4, 4, 4, 4, 4, # 20 - 27 - 4, 4, 4, 4, 4, 4, 4, 4, # 28 - 2f - 4, 4, 4, 4, 4, 4, 4, 4, # 30 - 37 - 4, 4, 4, 4, 4, 4, 4, 4, # 38 - 3f - 4, 4, 4, 4, 4, 4, 4, 4, # 40 - 47 - 4, 4, 4, 4, 4, 4, 4, 4, # 48 - 4f - 4, 4, 4, 4, 4, 4, 4, 4, # 50 - 57 - 4, 4, 4, 4, 4, 4, 4, 4, # 58 - 5f - 4, 4, 4, 4, 4, 4, 4, 4, # 60 - 67 - 4, 4, 4, 4, 4, 4, 4, 4, # 68 - 6f - 4, 4, 4, 4, 4, 4, 4, 4, # 70 - 77 - 4, 4, 4, 4, 4, 4, 4, 4, # 78 - 7f - 5, 5, 5, 5, 5, 5, 5, 5, # 80 - 87 - 5, 5, 5, 5, 5, 5, 1, 3, # 88 - 8f - 5, 5, 5, 5, 5, 5, 5, 5, # 90 - 97 - 5, 5, 5, 5, 5, 5, 5, 5, # 98 - 9f - 5, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 - 2, 2, 2, 2, 2, 2, 2, 2, # a8 - af - 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 - 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf - 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 - 2, 2, 2, 2, 2, 2, 2, 2, # c8 - cf - 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 - 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df - 0, 0, 0, 0, 0, 0, 0, 0, # e0 - e7 - 0, 0, 0, 0, 0, 0, 0, 0, # e8 - ef - 0, 0, 0, 0, 0, 0, 0, 0, # f0 - f7 - 0, 0, 0, 0, 0, 0, 0, 5 # f8 - ff -) - -EUCJP_ST = ( - 3, 4, 3, 5,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f - MachineState.ITS_ME,MachineState.ITS_ME,MachineState.START,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#10-17 - MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 3,MachineState.ERROR,#18-1f - 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START#20-27 -) -# fmt: on - -EUCJP_CHAR_LEN_TABLE = (2, 2, 2, 3, 1, 0) - -EUCJP_SM_MODEL: CodingStateMachineDict = { - "class_table": EUCJP_CLS, - "class_factor": 6, - "state_table": EUCJP_ST, - "char_len_table": EUCJP_CHAR_LEN_TABLE, - "name": "EUC-JP", -} - -# EUC-KR -# fmt: off -EUCKR_CLS = ( - 1, 1, 1, 1, 1, 1, 1, 1, # 00 - 07 - 1, 1, 1, 1, 1, 1, 0, 0, # 08 - 0f - 1, 1, 1, 1, 1, 1, 1, 1, # 10 - 17 - 1, 1, 1, 0, 1, 1, 1, 1, # 18 - 1f - 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 27 - 1, 1, 1, 1, 1, 1, 1, 1, # 28 - 2f - 1, 1, 1, 1, 1, 1, 1, 1, # 30 - 37 - 1, 1, 1, 1, 1, 1, 1, 1, # 38 - 3f - 1, 1, 1, 1, 1, 1, 1, 1, # 40 - 47 - 1, 1, 1, 1, 1, 1, 1, 1, # 48 - 4f - 1, 1, 1, 1, 1, 1, 1, 1, # 50 - 57 - 1, 1, 1, 1, 1, 1, 1, 1, # 58 - 5f - 1, 1, 1, 1, 1, 1, 1, 1, # 60 - 67 - 1, 1, 1, 1, 1, 1, 1, 1, # 68 - 6f - 1, 1, 1, 1, 1, 1, 1, 1, # 70 - 77 - 1, 1, 1, 1, 1, 1, 1, 1, # 78 - 7f - 0, 0, 0, 0, 0, 0, 0, 0, # 80 - 87 - 0, 0, 0, 0, 0, 0, 0, 0, # 88 - 8f - 0, 0, 0, 0, 0, 0, 0, 0, # 90 - 97 - 0, 0, 0, 0, 0, 0, 0, 0, # 98 - 9f - 0, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 - 2, 2, 2, 2, 2, 3, 3, 3, # a8 - af - 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 - 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf - 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 - 2, 3, 2, 2, 2, 2, 2, 2, # c8 - cf - 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 - 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df - 2, 2, 2, 2, 2, 2, 2, 2, # e0 - e7 - 2, 2, 2, 2, 2, 2, 2, 2, # e8 - ef - 2, 2, 2, 2, 2, 2, 2, 2, # f0 - f7 - 2, 2, 2, 2, 2, 2, 2, 0 # f8 - ff -) - -EUCKR_ST = ( - MachineState.ERROR,MachineState.START, 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 - MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #08-0f -) -# fmt: on - -EUCKR_CHAR_LEN_TABLE = (0, 1, 2, 0) - -EUCKR_SM_MODEL: CodingStateMachineDict = { - "class_table": EUCKR_CLS, - "class_factor": 4, - "state_table": EUCKR_ST, - "char_len_table": EUCKR_CHAR_LEN_TABLE, - "name": "EUC-KR", -} - -# JOHAB -# fmt: off -JOHAB_CLS = ( - 4,4,4,4,4,4,4,4, # 00 - 07 - 4,4,4,4,4,4,0,0, # 08 - 0f - 4,4,4,4,4,4,4,4, # 10 - 17 - 4,4,4,0,4,4,4,4, # 18 - 1f - 4,4,4,4,4,4,4,4, # 20 - 27 - 4,4,4,4,4,4,4,4, # 28 - 2f - 4,3,3,3,3,3,3,3, # 30 - 37 - 3,3,3,3,3,3,3,3, # 38 - 3f - 3,1,1,1,1,1,1,1, # 40 - 47 - 1,1,1,1,1,1,1,1, # 48 - 4f - 1,1,1,1,1,1,1,1, # 50 - 57 - 1,1,1,1,1,1,1,1, # 58 - 5f - 1,1,1,1,1,1,1,1, # 60 - 67 - 1,1,1,1,1,1,1,1, # 68 - 6f - 1,1,1,1,1,1,1,1, # 70 - 77 - 1,1,1,1,1,1,1,2, # 78 - 7f - 6,6,6,6,8,8,8,8, # 80 - 87 - 8,8,8,8,8,8,8,8, # 88 - 8f - 8,7,7,7,7,7,7,7, # 90 - 97 - 7,7,7,7,7,7,7,7, # 98 - 9f - 7,7,7,7,7,7,7,7, # a0 - a7 - 7,7,7,7,7,7,7,7, # a8 - af - 7,7,7,7,7,7,7,7, # b0 - b7 - 7,7,7,7,7,7,7,7, # b8 - bf - 7,7,7,7,7,7,7,7, # c0 - c7 - 7,7,7,7,7,7,7,7, # c8 - cf - 7,7,7,7,5,5,5,5, # d0 - d7 - 5,9,9,9,9,9,9,5, # d8 - df - 9,9,9,9,9,9,9,9, # e0 - e7 - 9,9,9,9,9,9,9,9, # e8 - ef - 9,9,9,9,9,9,9,9, # f0 - f7 - 9,9,5,5,5,5,5,0 # f8 - ff -) - -JOHAB_ST = ( -# cls = 0 1 2 3 4 5 6 7 8 9 - MachineState.ERROR ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.ERROR ,MachineState.ERROR ,3 ,3 ,4 , # MachineState.START - MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME, # MachineState.ITS_ME - MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR , # MachineState.ERROR - MachineState.ERROR ,MachineState.START ,MachineState.START ,MachineState.ERROR ,MachineState.ERROR ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.START , # 3 - MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START , # 4 -) -# fmt: on - -JOHAB_CHAR_LEN_TABLE = (0, 1, 1, 1, 1, 0, 0, 2, 2, 2) - -JOHAB_SM_MODEL: CodingStateMachineDict = { - "class_table": JOHAB_CLS, - "class_factor": 10, - "state_table": JOHAB_ST, - "char_len_table": JOHAB_CHAR_LEN_TABLE, - "name": "Johab", -} - -# EUC-TW -# fmt: off -EUCTW_CLS = ( - 2, 2, 2, 2, 2, 2, 2, 2, # 00 - 07 - 2, 2, 2, 2, 2, 2, 0, 0, # 08 - 0f - 2, 2, 2, 2, 2, 2, 2, 2, # 10 - 17 - 2, 2, 2, 0, 2, 2, 2, 2, # 18 - 1f - 2, 2, 2, 2, 2, 2, 2, 2, # 20 - 27 - 2, 2, 2, 2, 2, 2, 2, 2, # 28 - 2f - 2, 2, 2, 2, 2, 2, 2, 2, # 30 - 37 - 2, 2, 2, 2, 2, 2, 2, 2, # 38 - 3f - 2, 2, 2, 2, 2, 2, 2, 2, # 40 - 47 - 2, 2, 2, 2, 2, 2, 2, 2, # 48 - 4f - 2, 2, 2, 2, 2, 2, 2, 2, # 50 - 57 - 2, 2, 2, 2, 2, 2, 2, 2, # 58 - 5f - 2, 2, 2, 2, 2, 2, 2, 2, # 60 - 67 - 2, 2, 2, 2, 2, 2, 2, 2, # 68 - 6f - 2, 2, 2, 2, 2, 2, 2, 2, # 70 - 77 - 2, 2, 2, 2, 2, 2, 2, 2, # 78 - 7f - 0, 0, 0, 0, 0, 0, 0, 0, # 80 - 87 - 0, 0, 0, 0, 0, 0, 6, 0, # 88 - 8f - 0, 0, 0, 0, 0, 0, 0, 0, # 90 - 97 - 0, 0, 0, 0, 0, 0, 0, 0, # 98 - 9f - 0, 3, 4, 4, 4, 4, 4, 4, # a0 - a7 - 5, 5, 1, 1, 1, 1, 1, 1, # a8 - af - 1, 1, 1, 1, 1, 1, 1, 1, # b0 - b7 - 1, 1, 1, 1, 1, 1, 1, 1, # b8 - bf - 1, 1, 3, 1, 3, 3, 3, 3, # c0 - c7 - 3, 3, 3, 3, 3, 3, 3, 3, # c8 - cf - 3, 3, 3, 3, 3, 3, 3, 3, # d0 - d7 - 3, 3, 3, 3, 3, 3, 3, 3, # d8 - df - 3, 3, 3, 3, 3, 3, 3, 3, # e0 - e7 - 3, 3, 3, 3, 3, 3, 3, 3, # e8 - ef - 3, 3, 3, 3, 3, 3, 3, 3, # f0 - f7 - 3, 3, 3, 3, 3, 3, 3, 0 # f8 - ff -) - -EUCTW_ST = ( - MachineState.ERROR,MachineState.ERROR,MachineState.START, 3, 3, 3, 4,MachineState.ERROR,#00-07 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f - MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,MachineState.ERROR,#10-17 - MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#18-1f - 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.START,MachineState.START,#20-27 - MachineState.START,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START #28-2f -) -# fmt: on - -EUCTW_CHAR_LEN_TABLE = (0, 0, 1, 2, 2, 2, 3) - -EUCTW_SM_MODEL: CodingStateMachineDict = { - "class_table": EUCTW_CLS, - "class_factor": 7, - "state_table": EUCTW_ST, - "char_len_table": EUCTW_CHAR_LEN_TABLE, - "name": "x-euc-tw", -} - -# GB2312 -# fmt: off -GB2312_CLS = ( - 1, 1, 1, 1, 1, 1, 1, 1, # 00 - 07 - 1, 1, 1, 1, 1, 1, 0, 0, # 08 - 0f - 1, 1, 1, 1, 1, 1, 1, 1, # 10 - 17 - 1, 1, 1, 0, 1, 1, 1, 1, # 18 - 1f - 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 27 - 1, 1, 1, 1, 1, 1, 1, 1, # 28 - 2f - 3, 3, 3, 3, 3, 3, 3, 3, # 30 - 37 - 3, 3, 1, 1, 1, 1, 1, 1, # 38 - 3f - 2, 2, 2, 2, 2, 2, 2, 2, # 40 - 47 - 2, 2, 2, 2, 2, 2, 2, 2, # 48 - 4f - 2, 2, 2, 2, 2, 2, 2, 2, # 50 - 57 - 2, 2, 2, 2, 2, 2, 2, 2, # 58 - 5f - 2, 2, 2, 2, 2, 2, 2, 2, # 60 - 67 - 2, 2, 2, 2, 2, 2, 2, 2, # 68 - 6f - 2, 2, 2, 2, 2, 2, 2, 2, # 70 - 77 - 2, 2, 2, 2, 2, 2, 2, 4, # 78 - 7f - 5, 6, 6, 6, 6, 6, 6, 6, # 80 - 87 - 6, 6, 6, 6, 6, 6, 6, 6, # 88 - 8f - 6, 6, 6, 6, 6, 6, 6, 6, # 90 - 97 - 6, 6, 6, 6, 6, 6, 6, 6, # 98 - 9f - 6, 6, 6, 6, 6, 6, 6, 6, # a0 - a7 - 6, 6, 6, 6, 6, 6, 6, 6, # a8 - af - 6, 6, 6, 6, 6, 6, 6, 6, # b0 - b7 - 6, 6, 6, 6, 6, 6, 6, 6, # b8 - bf - 6, 6, 6, 6, 6, 6, 6, 6, # c0 - c7 - 6, 6, 6, 6, 6, 6, 6, 6, # c8 - cf - 6, 6, 6, 6, 6, 6, 6, 6, # d0 - d7 - 6, 6, 6, 6, 6, 6, 6, 6, # d8 - df - 6, 6, 6, 6, 6, 6, 6, 6, # e0 - e7 - 6, 6, 6, 6, 6, 6, 6, 6, # e8 - ef - 6, 6, 6, 6, 6, 6, 6, 6, # f0 - f7 - 6, 6, 6, 6, 6, 6, 6, 0 # f8 - ff -) - -GB2312_ST = ( - MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START, 3,MachineState.ERROR,#00-07 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f - MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,#10-17 - 4,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#18-1f - MachineState.ERROR,MachineState.ERROR, 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,#20-27 - MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START #28-2f -) -# fmt: on - -# To be accurate, the length of class 6 can be either 2 or 4. -# But it is not necessary to discriminate between the two since -# it is used for frequency analysis only, and we are validating -# each code range there as well. So it is safe to set it to be -# 2 here. -GB2312_CHAR_LEN_TABLE = (0, 1, 1, 1, 1, 1, 2) - -GB2312_SM_MODEL: CodingStateMachineDict = { - "class_table": GB2312_CLS, - "class_factor": 7, - "state_table": GB2312_ST, - "char_len_table": GB2312_CHAR_LEN_TABLE, - "name": "GB2312", -} - -# Shift_JIS -# fmt: off -SJIS_CLS = ( - 1, 1, 1, 1, 1, 1, 1, 1, # 00 - 07 - 1, 1, 1, 1, 1, 1, 0, 0, # 08 - 0f - 1, 1, 1, 1, 1, 1, 1, 1, # 10 - 17 - 1, 1, 1, 0, 1, 1, 1, 1, # 18 - 1f - 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 27 - 1, 1, 1, 1, 1, 1, 1, 1, # 28 - 2f - 1, 1, 1, 1, 1, 1, 1, 1, # 30 - 37 - 1, 1, 1, 1, 1, 1, 1, 1, # 38 - 3f - 2, 2, 2, 2, 2, 2, 2, 2, # 40 - 47 - 2, 2, 2, 2, 2, 2, 2, 2, # 48 - 4f - 2, 2, 2, 2, 2, 2, 2, 2, # 50 - 57 - 2, 2, 2, 2, 2, 2, 2, 2, # 58 - 5f - 2, 2, 2, 2, 2, 2, 2, 2, # 60 - 67 - 2, 2, 2, 2, 2, 2, 2, 2, # 68 - 6f - 2, 2, 2, 2, 2, 2, 2, 2, # 70 - 77 - 2, 2, 2, 2, 2, 2, 2, 1, # 78 - 7f - 3, 3, 3, 3, 3, 2, 2, 3, # 80 - 87 - 3, 3, 3, 3, 3, 3, 3, 3, # 88 - 8f - 3, 3, 3, 3, 3, 3, 3, 3, # 90 - 97 - 3, 3, 3, 3, 3, 3, 3, 3, # 98 - 9f - #0xa0 is illegal in sjis encoding, but some pages does - #contain such byte. We need to be more error forgiven. - 2, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 - 2, 2, 2, 2, 2, 2, 2, 2, # a8 - af - 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 - 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf - 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 - 2, 2, 2, 2, 2, 2, 2, 2, # c8 - cf - 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 - 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df - 3, 3, 3, 3, 3, 3, 3, 3, # e0 - e7 - 3, 3, 3, 3, 3, 4, 4, 4, # e8 - ef - 3, 3, 3, 3, 3, 3, 3, 3, # f0 - f7 - 3, 3, 3, 3, 3, 0, 0, 0, # f8 - ff -) - -SJIS_ST = ( - MachineState.ERROR,MachineState.START,MachineState.START, 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f - MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START #10-17 -) -# fmt: on - -SJIS_CHAR_LEN_TABLE = (0, 1, 1, 2, 0, 0) - -SJIS_SM_MODEL: CodingStateMachineDict = { - "class_table": SJIS_CLS, - "class_factor": 6, - "state_table": SJIS_ST, - "char_len_table": SJIS_CHAR_LEN_TABLE, - "name": "Shift_JIS", -} - -# UCS2-BE -# fmt: off -UCS2BE_CLS = ( - 0, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 - 0, 0, 1, 0, 0, 2, 0, 0, # 08 - 0f - 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 - 0, 0, 0, 3, 0, 0, 0, 0, # 18 - 1f - 0, 0, 0, 0, 0, 0, 0, 0, # 20 - 27 - 0, 3, 3, 3, 3, 3, 0, 0, # 28 - 2f - 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 - 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f - 0, 0, 0, 0, 0, 0, 0, 0, # 40 - 47 - 0, 0, 0, 0, 0, 0, 0, 0, # 48 - 4f - 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 - 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f - 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 - 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f - 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 - 0, 0, 0, 0, 0, 0, 0, 0, # 78 - 7f - 0, 0, 0, 0, 0, 0, 0, 0, # 80 - 87 - 0, 0, 0, 0, 0, 0, 0, 0, # 88 - 8f - 0, 0, 0, 0, 0, 0, 0, 0, # 90 - 97 - 0, 0, 0, 0, 0, 0, 0, 0, # 98 - 9f - 0, 0, 0, 0, 0, 0, 0, 0, # a0 - a7 - 0, 0, 0, 0, 0, 0, 0, 0, # a8 - af - 0, 0, 0, 0, 0, 0, 0, 0, # b0 - b7 - 0, 0, 0, 0, 0, 0, 0, 0, # b8 - bf - 0, 0, 0, 0, 0, 0, 0, 0, # c0 - c7 - 0, 0, 0, 0, 0, 0, 0, 0, # c8 - cf - 0, 0, 0, 0, 0, 0, 0, 0, # d0 - d7 - 0, 0, 0, 0, 0, 0, 0, 0, # d8 - df - 0, 0, 0, 0, 0, 0, 0, 0, # e0 - e7 - 0, 0, 0, 0, 0, 0, 0, 0, # e8 - ef - 0, 0, 0, 0, 0, 0, 0, 0, # f0 - f7 - 0, 0, 0, 0, 0, 0, 4, 5 # f8 - ff -) - -UCS2BE_ST = ( - 5, 7, 7,MachineState.ERROR, 4, 3,MachineState.ERROR,MachineState.ERROR,#00-07 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f - MachineState.ITS_ME,MachineState.ITS_ME, 6, 6, 6, 6,MachineState.ERROR,MachineState.ERROR,#10-17 - 6, 6, 6, 6, 6,MachineState.ITS_ME, 6, 6,#18-1f - 6, 6, 6, 6, 5, 7, 7,MachineState.ERROR,#20-27 - 5, 8, 6, 6,MachineState.ERROR, 6, 6, 6,#28-2f - 6, 6, 6, 6,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #30-37 -) -# fmt: on - -UCS2BE_CHAR_LEN_TABLE = (2, 2, 2, 0, 2, 2) - -UCS2BE_SM_MODEL: CodingStateMachineDict = { - "class_table": UCS2BE_CLS, - "class_factor": 6, - "state_table": UCS2BE_ST, - "char_len_table": UCS2BE_CHAR_LEN_TABLE, - "name": "UTF-16BE", -} - -# UCS2-LE -# fmt: off -UCS2LE_CLS = ( - 0, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 - 0, 0, 1, 0, 0, 2, 0, 0, # 08 - 0f - 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 - 0, 0, 0, 3, 0, 0, 0, 0, # 18 - 1f - 0, 0, 0, 0, 0, 0, 0, 0, # 20 - 27 - 0, 3, 3, 3, 3, 3, 0, 0, # 28 - 2f - 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 - 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f - 0, 0, 0, 0, 0, 0, 0, 0, # 40 - 47 - 0, 0, 0, 0, 0, 0, 0, 0, # 48 - 4f - 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 - 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f - 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 - 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f - 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 - 0, 0, 0, 0, 0, 0, 0, 0, # 78 - 7f - 0, 0, 0, 0, 0, 0, 0, 0, # 80 - 87 - 0, 0, 0, 0, 0, 0, 0, 0, # 88 - 8f - 0, 0, 0, 0, 0, 0, 0, 0, # 90 - 97 - 0, 0, 0, 0, 0, 0, 0, 0, # 98 - 9f - 0, 0, 0, 0, 0, 0, 0, 0, # a0 - a7 - 0, 0, 0, 0, 0, 0, 0, 0, # a8 - af - 0, 0, 0, 0, 0, 0, 0, 0, # b0 - b7 - 0, 0, 0, 0, 0, 0, 0, 0, # b8 - bf - 0, 0, 0, 0, 0, 0, 0, 0, # c0 - c7 - 0, 0, 0, 0, 0, 0, 0, 0, # c8 - cf - 0, 0, 0, 0, 0, 0, 0, 0, # d0 - d7 - 0, 0, 0, 0, 0, 0, 0, 0, # d8 - df - 0, 0, 0, 0, 0, 0, 0, 0, # e0 - e7 - 0, 0, 0, 0, 0, 0, 0, 0, # e8 - ef - 0, 0, 0, 0, 0, 0, 0, 0, # f0 - f7 - 0, 0, 0, 0, 0, 0, 4, 5 # f8 - ff -) - -UCS2LE_ST = ( - 6, 6, 7, 6, 4, 3,MachineState.ERROR,MachineState.ERROR,#00-07 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f - MachineState.ITS_ME,MachineState.ITS_ME, 5, 5, 5,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,#10-17 - 5, 5, 5,MachineState.ERROR, 5,MachineState.ERROR, 6, 6,#18-1f - 7, 6, 8, 8, 5, 5, 5,MachineState.ERROR,#20-27 - 5, 5, 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 5, 5,#28-2f - 5, 5, 5,MachineState.ERROR, 5,MachineState.ERROR,MachineState.START,MachineState.START #30-37 -) -# fmt: on - -UCS2LE_CHAR_LEN_TABLE = (2, 2, 2, 2, 2, 2) - -UCS2LE_SM_MODEL: CodingStateMachineDict = { - "class_table": UCS2LE_CLS, - "class_factor": 6, - "state_table": UCS2LE_ST, - "char_len_table": UCS2LE_CHAR_LEN_TABLE, - "name": "UTF-16LE", -} - -# UTF-8 -# fmt: off -UTF8_CLS = ( - 1, 1, 1, 1, 1, 1, 1, 1, # 00 - 07 #allow 0x00 as a legal value - 1, 1, 1, 1, 1, 1, 0, 0, # 08 - 0f - 1, 1, 1, 1, 1, 1, 1, 1, # 10 - 17 - 1, 1, 1, 0, 1, 1, 1, 1, # 18 - 1f - 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 27 - 1, 1, 1, 1, 1, 1, 1, 1, # 28 - 2f - 1, 1, 1, 1, 1, 1, 1, 1, # 30 - 37 - 1, 1, 1, 1, 1, 1, 1, 1, # 38 - 3f - 1, 1, 1, 1, 1, 1, 1, 1, # 40 - 47 - 1, 1, 1, 1, 1, 1, 1, 1, # 48 - 4f - 1, 1, 1, 1, 1, 1, 1, 1, # 50 - 57 - 1, 1, 1, 1, 1, 1, 1, 1, # 58 - 5f - 1, 1, 1, 1, 1, 1, 1, 1, # 60 - 67 - 1, 1, 1, 1, 1, 1, 1, 1, # 68 - 6f - 1, 1, 1, 1, 1, 1, 1, 1, # 70 - 77 - 1, 1, 1, 1, 1, 1, 1, 1, # 78 - 7f - 2, 2, 2, 2, 3, 3, 3, 3, # 80 - 87 - 4, 4, 4, 4, 4, 4, 4, 4, # 88 - 8f - 4, 4, 4, 4, 4, 4, 4, 4, # 90 - 97 - 4, 4, 4, 4, 4, 4, 4, 4, # 98 - 9f - 5, 5, 5, 5, 5, 5, 5, 5, # a0 - a7 - 5, 5, 5, 5, 5, 5, 5, 5, # a8 - af - 5, 5, 5, 5, 5, 5, 5, 5, # b0 - b7 - 5, 5, 5, 5, 5, 5, 5, 5, # b8 - bf - 0, 0, 6, 6, 6, 6, 6, 6, # c0 - c7 - 6, 6, 6, 6, 6, 6, 6, 6, # c8 - cf - 6, 6, 6, 6, 6, 6, 6, 6, # d0 - d7 - 6, 6, 6, 6, 6, 6, 6, 6, # d8 - df - 7, 8, 8, 8, 8, 8, 8, 8, # e0 - e7 - 8, 8, 8, 8, 8, 9, 8, 8, # e8 - ef - 10, 11, 11, 11, 11, 11, 11, 11, # f0 - f7 - 12, 13, 13, 13, 14, 15, 0, 0 # f8 - ff -) - -UTF8_ST = ( - MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 12, 10,#00-07 - 9, 11, 8, 7, 6, 5, 4, 3,#08-0f - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#10-17 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#18-1f - MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#20-27 - MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#28-2f - MachineState.ERROR,MachineState.ERROR, 5, 5, 5, 5,MachineState.ERROR,MachineState.ERROR,#30-37 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#38-3f - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 5, 5, 5,MachineState.ERROR,MachineState.ERROR,#40-47 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#48-4f - MachineState.ERROR,MachineState.ERROR, 7, 7, 7, 7,MachineState.ERROR,MachineState.ERROR,#50-57 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#58-5f - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 7, 7,MachineState.ERROR,MachineState.ERROR,#60-67 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#68-6f - MachineState.ERROR,MachineState.ERROR, 9, 9, 9, 9,MachineState.ERROR,MachineState.ERROR,#70-77 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#78-7f - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 9,MachineState.ERROR,MachineState.ERROR,#80-87 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#88-8f - MachineState.ERROR,MachineState.ERROR, 12, 12, 12, 12,MachineState.ERROR,MachineState.ERROR,#90-97 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#98-9f - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 12,MachineState.ERROR,MachineState.ERROR,#a0-a7 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#a8-af - MachineState.ERROR,MachineState.ERROR, 12, 12, 12,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#b0-b7 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#b8-bf - MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,#c0-c7 - MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR #c8-cf -) -# fmt: on - -UTF8_CHAR_LEN_TABLE = (0, 1, 0, 0, 0, 0, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6) - -UTF8_SM_MODEL: CodingStateMachineDict = { - "class_table": UTF8_CLS, - "class_factor": 16, - "state_table": UTF8_ST, - "char_len_table": UTF8_CHAR_LEN_TABLE, - "name": "UTF-8", -} diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/metadata/__init__.py b/myenv/Lib/site-packages/pip/_vendor/chardet/metadata/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-311.pyc deleted file mode 100644 index 6dc0f9f30917d827fa2a18090be93258d2b137fc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 221 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 LH5LDnrSpFQ>XZXc diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py b/myenv/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py deleted file mode 100644 index eb40c5f..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py +++ /dev/null @@ -1,352 +0,0 @@ -""" -Metadata about languages used by our model training code for our -SingleByteCharSetProbers. Could be used for other things in the future. - -This code is based on the language metadata from the uchardet project. -""" - -from string import ascii_letters -from typing import List, Optional - -# TODO: Add Ukrainian (KOI8-U) - - -class Language: - """Metadata about a language useful for training models - - :ivar name: The human name for the language, in English. - :type name: str - :ivar iso_code: 2-letter ISO 639-1 if possible, 3-letter ISO code otherwise, - or use another catalog as a last resort. - :type iso_code: str - :ivar use_ascii: Whether or not ASCII letters should be included in trained - models. - :type use_ascii: bool - :ivar charsets: The charsets we want to support and create data for. - :type charsets: list of str - :ivar alphabet: The characters in the language's alphabet. If `use_ascii` is - `True`, you only need to add those not in the ASCII set. - :type alphabet: str - :ivar wiki_start_pages: The Wikipedia pages to start from if we're crawling - Wikipedia for training data. - :type wiki_start_pages: list of str - """ - - def __init__( - self, - name: Optional[str] = None, - iso_code: Optional[str] = None, - use_ascii: bool = True, - charsets: Optional[List[str]] = None, - alphabet: Optional[str] = None, - wiki_start_pages: Optional[List[str]] = None, - ) -> None: - super().__init__() - self.name = name - self.iso_code = iso_code - self.use_ascii = use_ascii - self.charsets = charsets - if self.use_ascii: - if alphabet: - alphabet += ascii_letters - else: - alphabet = ascii_letters - elif not alphabet: - raise ValueError("Must supply alphabet if use_ascii is False") - self.alphabet = "".join(sorted(set(alphabet))) if alphabet else None - self.wiki_start_pages = wiki_start_pages - - def __repr__(self) -> str: - param_str = ", ".join( - f"{k}={v!r}" for k, v in self.__dict__.items() if not k.startswith("_") - ) - return f"{self.__class__.__name__}({param_str})" - - -LANGUAGES = { - "Arabic": Language( - name="Arabic", - iso_code="ar", - use_ascii=False, - # We only support encodings that use isolated - # forms, because the current recommendation is - # that the rendering system handles presentation - # forms. This means we purposefully skip IBM864. - charsets=["ISO-8859-6", "WINDOWS-1256", "CP720", "CP864"], - alphabet="ءآأؤإئابةتثجحخدذرزسشصضطظعغػؼؽؾؿـفقكلمنهوىيًٌٍَُِّ", - wiki_start_pages=["الصفحة_الرئيسية"], - ), - "Belarusian": Language( - name="Belarusian", - iso_code="be", - use_ascii=False, - charsets=["ISO-8859-5", "WINDOWS-1251", "IBM866", "MacCyrillic"], - alphabet="АБВГДЕЁЖЗІЙКЛМНОПРСТУЎФХЦЧШЫЬЭЮЯабвгдеёжзійклмнопрстуўфхцчшыьэюяʼ", - wiki_start_pages=["Галоўная_старонка"], - ), - "Bulgarian": Language( - name="Bulgarian", - iso_code="bg", - use_ascii=False, - charsets=["ISO-8859-5", "WINDOWS-1251", "IBM855"], - alphabet="АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя", - wiki_start_pages=["Начална_страница"], - ), - "Czech": Language( - name="Czech", - iso_code="cz", - use_ascii=True, - charsets=["ISO-8859-2", "WINDOWS-1250"], - alphabet="áčďéěíňóřšťúůýžÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ", - wiki_start_pages=["Hlavní_strana"], - ), - "Danish": Language( - name="Danish", - iso_code="da", - use_ascii=True, - charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], - alphabet="æøåÆØÅ", - wiki_start_pages=["Forside"], - ), - "German": Language( - name="German", - iso_code="de", - use_ascii=True, - charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], - alphabet="äöüßẞÄÖÜ", - wiki_start_pages=["Wikipedia:Hauptseite"], - ), - "Greek": Language( - name="Greek", - iso_code="el", - use_ascii=False, - charsets=["ISO-8859-7", "WINDOWS-1253"], - alphabet="αβγδεζηθικλμνξοπρσςτυφχψωάέήίόύώΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΣΤΥΦΧΨΩΆΈΉΊΌΎΏ", - wiki_start_pages=["Πύλη:Κύρια"], - ), - "English": Language( - name="English", - iso_code="en", - use_ascii=True, - charsets=["ISO-8859-1", "WINDOWS-1252", "MacRoman"], - wiki_start_pages=["Main_Page"], - ), - "Esperanto": Language( - name="Esperanto", - iso_code="eo", - # Q, W, X, and Y not used at all - use_ascii=False, - charsets=["ISO-8859-3"], - alphabet="abcĉdefgĝhĥijĵklmnoprsŝtuŭvzABCĈDEFGĜHĤIJĴKLMNOPRSŜTUŬVZ", - wiki_start_pages=["Vikipedio:Ĉefpaĝo"], - ), - "Spanish": Language( - name="Spanish", - iso_code="es", - use_ascii=True, - charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], - alphabet="ñáéíóúüÑÁÉÍÓÚÜ", - wiki_start_pages=["Wikipedia:Portada"], - ), - "Estonian": Language( - name="Estonian", - iso_code="et", - use_ascii=False, - charsets=["ISO-8859-4", "ISO-8859-13", "WINDOWS-1257"], - # C, F, Š, Q, W, X, Y, Z, Ž are only for - # loanwords - alphabet="ABDEGHIJKLMNOPRSTUVÕÄÖÜabdeghijklmnoprstuvõäöü", - wiki_start_pages=["Esileht"], - ), - "Finnish": Language( - name="Finnish", - iso_code="fi", - use_ascii=True, - charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], - alphabet="ÅÄÖŠŽåäöšž", - wiki_start_pages=["Wikipedia:Etusivu"], - ), - "French": Language( - name="French", - iso_code="fr", - use_ascii=True, - charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], - alphabet="œàâçèéîïùûêŒÀÂÇÈÉÎÏÙÛÊ", - wiki_start_pages=["Wikipédia:Accueil_principal", "Bœuf (animal)"], - ), - "Hebrew": Language( - name="Hebrew", - iso_code="he", - use_ascii=False, - charsets=["ISO-8859-8", "WINDOWS-1255"], - alphabet="אבגדהוזחטיךכלםמןנסעףפץצקרשתװױײ", - wiki_start_pages=["עמוד_ראשי"], - ), - "Croatian": Language( - name="Croatian", - iso_code="hr", - # Q, W, X, Y are only used for foreign words. - use_ascii=False, - charsets=["ISO-8859-2", "WINDOWS-1250"], - alphabet="abcčćdđefghijklmnoprsštuvzžABCČĆDĐEFGHIJKLMNOPRSŠTUVZŽ", - wiki_start_pages=["Glavna_stranica"], - ), - "Hungarian": Language( - name="Hungarian", - iso_code="hu", - # Q, W, X, Y are only used for foreign words. - use_ascii=False, - charsets=["ISO-8859-2", "WINDOWS-1250"], - alphabet="abcdefghijklmnoprstuvzáéíóöőúüűABCDEFGHIJKLMNOPRSTUVZÁÉÍÓÖŐÚÜŰ", - wiki_start_pages=["Kezdőlap"], - ), - "Italian": Language( - name="Italian", - iso_code="it", - use_ascii=True, - charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], - alphabet="ÀÈÉÌÒÓÙàèéìòóù", - wiki_start_pages=["Pagina_principale"], - ), - "Lithuanian": Language( - name="Lithuanian", - iso_code="lt", - use_ascii=False, - charsets=["ISO-8859-13", "WINDOWS-1257", "ISO-8859-4"], - # Q, W, and X not used at all - alphabet="AĄBCČDEĘĖFGHIĮYJKLMNOPRSŠTUŲŪVZŽaąbcčdeęėfghiįyjklmnoprsštuųūvzž", - wiki_start_pages=["Pagrindinis_puslapis"], - ), - "Latvian": Language( - name="Latvian", - iso_code="lv", - use_ascii=False, - charsets=["ISO-8859-13", "WINDOWS-1257", "ISO-8859-4"], - # Q, W, X, Y are only for loanwords - alphabet="AĀBCČDEĒFGĢHIĪJKĶLĻMNŅOPRSŠTUŪVZŽaābcčdeēfgģhiījkķlļmnņoprsštuūvzž", - wiki_start_pages=["Sākumlapa"], - ), - "Macedonian": Language( - name="Macedonian", - iso_code="mk", - use_ascii=False, - charsets=["ISO-8859-5", "WINDOWS-1251", "MacCyrillic", "IBM855"], - alphabet="АБВГДЃЕЖЗЅИЈКЛЉМНЊОПРСТЌУФХЦЧЏШабвгдѓежзѕијклљмнњопрстќуфхцчџш", - wiki_start_pages=["Главна_страница"], - ), - "Dutch": Language( - name="Dutch", - iso_code="nl", - use_ascii=True, - charsets=["ISO-8859-1", "WINDOWS-1252", "MacRoman"], - wiki_start_pages=["Hoofdpagina"], - ), - "Polish": Language( - name="Polish", - iso_code="pl", - # Q and X are only used for foreign words. - use_ascii=False, - charsets=["ISO-8859-2", "WINDOWS-1250"], - alphabet="AĄBCĆDEĘFGHIJKLŁMNŃOÓPRSŚTUWYZŹŻaąbcćdeęfghijklłmnńoóprsśtuwyzźż", - wiki_start_pages=["Wikipedia:Strona_główna"], - ), - "Portuguese": Language( - name="Portuguese", - iso_code="pt", - use_ascii=True, - charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], - alphabet="ÁÂÃÀÇÉÊÍÓÔÕÚáâãàçéêíóôõú", - wiki_start_pages=["Wikipédia:Página_principal"], - ), - "Romanian": Language( - name="Romanian", - iso_code="ro", - use_ascii=True, - charsets=["ISO-8859-2", "WINDOWS-1250"], - alphabet="ăâîșțĂÂÎȘȚ", - wiki_start_pages=["Pagina_principală"], - ), - "Russian": Language( - name="Russian", - iso_code="ru", - use_ascii=False, - charsets=[ - "ISO-8859-5", - "WINDOWS-1251", - "KOI8-R", - "MacCyrillic", - "IBM866", - "IBM855", - ], - alphabet="абвгдеёжзийклмнопрстуфхцчшщъыьэюяАБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ", - wiki_start_pages=["Заглавная_страница"], - ), - "Slovak": Language( - name="Slovak", - iso_code="sk", - use_ascii=True, - charsets=["ISO-8859-2", "WINDOWS-1250"], - alphabet="áäčďéíĺľňóôŕšťúýžÁÄČĎÉÍĹĽŇÓÔŔŠŤÚÝŽ", - wiki_start_pages=["Hlavná_stránka"], - ), - "Slovene": Language( - name="Slovene", - iso_code="sl", - # Q, W, X, Y are only used for foreign words. - use_ascii=False, - charsets=["ISO-8859-2", "WINDOWS-1250"], - alphabet="abcčdefghijklmnoprsštuvzžABCČDEFGHIJKLMNOPRSŠTUVZŽ", - wiki_start_pages=["Glavna_stran"], - ), - # Serbian can be written in both Latin and Cyrillic, but there's no - # simple way to get the Latin alphabet pages from Wikipedia through - # the API, so for now we just support Cyrillic. - "Serbian": Language( - name="Serbian", - iso_code="sr", - alphabet="АБВГДЂЕЖЗИЈКЛЉМНЊОПРСТЋУФХЦЧЏШабвгдђежзијклљмнњопрстћуфхцчџш", - charsets=["ISO-8859-5", "WINDOWS-1251", "MacCyrillic", "IBM855"], - wiki_start_pages=["Главна_страна"], - ), - "Thai": Language( - name="Thai", - iso_code="th", - use_ascii=False, - charsets=["ISO-8859-11", "TIS-620", "CP874"], - alphabet="กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛", - wiki_start_pages=["หน้าหลัก"], - ), - "Turkish": Language( - name="Turkish", - iso_code="tr", - # Q, W, and X are not used by Turkish - use_ascii=False, - charsets=["ISO-8859-3", "ISO-8859-9", "WINDOWS-1254"], - alphabet="abcçdefgğhıijklmnoöprsştuüvyzâîûABCÇDEFGĞHIİJKLMNOÖPRSŞTUÜVYZÂÎÛ", - wiki_start_pages=["Ana_Sayfa"], - ), - "Vietnamese": Language( - name="Vietnamese", - iso_code="vi", - use_ascii=False, - # Windows-1258 is the only common 8-bit - # Vietnamese encoding supported by Python. - # From Wikipedia: - # For systems that lack support for Unicode, - # dozens of 8-bit Vietnamese code pages are - # available.[1] The most common are VISCII - # (TCVN 5712:1993), VPS, and Windows-1258.[3] - # Where ASCII is required, such as when - # ensuring readability in plain text e-mail, - # Vietnamese letters are often encoded - # according to Vietnamese Quoted-Readable - # (VIQR) or VSCII Mnemonic (VSCII-MNEM),[4] - # though usage of either variable-width - # scheme has declined dramatically following - # the adoption of Unicode on the World Wide - # Web. - charsets=["WINDOWS-1258"], - alphabet="aăâbcdđeêghiklmnoôơpqrstuưvxyAĂÂBCDĐEÊGHIKLMNOÔƠPQRSTUƯVXY", - wiki_start_pages=["Chữ_Quốc_ngữ"], - ), -} diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/py.typed b/myenv/Lib/site-packages/pip/_vendor/chardet/py.typed deleted file mode 100644 index e69de29..0000000 diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/resultdict.py b/myenv/Lib/site-packages/pip/_vendor/chardet/resultdict.py deleted file mode 100644 index 7d36e64..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/resultdict.py +++ /dev/null @@ -1,16 +0,0 @@ -from typing import TYPE_CHECKING, Optional - -if TYPE_CHECKING: - # TypedDict was introduced in Python 3.8. - # - # TODO: Remove the else block and TYPE_CHECKING check when dropping support - # for Python 3.7. - from typing import TypedDict - - class ResultDict(TypedDict): - encoding: Optional[str] - confidence: float - language: Optional[str] - -else: - ResultDict = dict diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py deleted file mode 100644 index 0ffbcdd..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py +++ /dev/null @@ -1,162 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Universal charset detector code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 2001 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# Shy Shalom - original C code -# -# 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 Dict, List, NamedTuple, Optional, Union - -from .charsetprober import CharSetProber -from .enums import CharacterCategory, ProbingState, SequenceLikelihood - - -class SingleByteCharSetModel(NamedTuple): - charset_name: str - language: str - char_to_order_map: Dict[int, int] - language_model: Dict[int, Dict[int, int]] - typical_positive_ratio: float - keep_ascii_letters: bool - alphabet: str - - -class SingleByteCharSetProber(CharSetProber): - SAMPLE_SIZE = 64 - SB_ENOUGH_REL_THRESHOLD = 1024 # 0.25 * SAMPLE_SIZE^2 - POSITIVE_SHORTCUT_THRESHOLD = 0.95 - NEGATIVE_SHORTCUT_THRESHOLD = 0.05 - - def __init__( - self, - model: SingleByteCharSetModel, - is_reversed: bool = False, - name_prober: Optional[CharSetProber] = None, - ) -> None: - super().__init__() - self._model = model - # TRUE if we need to reverse every pair in the model lookup - self._reversed = is_reversed - # Optional auxiliary prober for name decision - self._name_prober = name_prober - self._last_order = 255 - self._seq_counters: List[int] = [] - self._total_seqs = 0 - self._total_char = 0 - self._control_char = 0 - self._freq_char = 0 - self.reset() - - def reset(self) -> None: - super().reset() - # char order of last character - self._last_order = 255 - self._seq_counters = [0] * SequenceLikelihood.get_num_categories() - self._total_seqs = 0 - self._total_char = 0 - self._control_char = 0 - # characters that fall in our sampling range - self._freq_char = 0 - - @property - def charset_name(self) -> Optional[str]: - if self._name_prober: - return self._name_prober.charset_name - return self._model.charset_name - - @property - def language(self) -> Optional[str]: - if self._name_prober: - return self._name_prober.language - return self._model.language - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - # TODO: Make filter_international_words keep things in self.alphabet - if not self._model.keep_ascii_letters: - byte_str = self.filter_international_words(byte_str) - else: - byte_str = self.remove_xml_tags(byte_str) - if not byte_str: - return self.state - char_to_order_map = self._model.char_to_order_map - language_model = self._model.language_model - for char in byte_str: - order = char_to_order_map.get(char, CharacterCategory.UNDEFINED) - # XXX: This was SYMBOL_CAT_ORDER before, with a value of 250, but - # CharacterCategory.SYMBOL is actually 253, so we use CONTROL - # to make it closer to the original intent. The only difference - # is whether or not we count digits and control characters for - # _total_char purposes. - if order < CharacterCategory.CONTROL: - self._total_char += 1 - if order < self.SAMPLE_SIZE: - self._freq_char += 1 - if self._last_order < self.SAMPLE_SIZE: - self._total_seqs += 1 - if not self._reversed: - lm_cat = language_model[self._last_order][order] - else: - lm_cat = language_model[order][self._last_order] - self._seq_counters[lm_cat] += 1 - self._last_order = order - - charset_name = self._model.charset_name - if self.state == ProbingState.DETECTING: - if self._total_seqs > self.SB_ENOUGH_REL_THRESHOLD: - confidence = self.get_confidence() - if confidence > self.POSITIVE_SHORTCUT_THRESHOLD: - self.logger.debug( - "%s confidence = %s, we have a winner", charset_name, confidence - ) - self._state = ProbingState.FOUND_IT - elif confidence < self.NEGATIVE_SHORTCUT_THRESHOLD: - self.logger.debug( - "%s confidence = %s, below negative shortcut threshold %s", - charset_name, - confidence, - self.NEGATIVE_SHORTCUT_THRESHOLD, - ) - self._state = ProbingState.NOT_ME - - return self.state - - def get_confidence(self) -> float: - r = 0.01 - if self._total_seqs > 0: - r = ( - ( - self._seq_counters[SequenceLikelihood.POSITIVE] - + 0.25 * self._seq_counters[SequenceLikelihood.LIKELY] - ) - / self._total_seqs - / self._model.typical_positive_ratio - ) - # The more control characters (proportionnaly to the size - # of the text), the less confident we become in the current - # charset. - r = r * (self._total_char - self._control_char) / self._total_char - r = r * self._freq_char / self._total_char - if r >= 1.0: - r = 0.99 - return r diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py deleted file mode 100644 index 890ae84..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py +++ /dev/null @@ -1,88 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Universal charset detector code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 2001 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# Shy Shalom - original C code -# -# 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 .charsetgroupprober import CharSetGroupProber -from .hebrewprober import HebrewProber -from .langbulgarianmodel import ISO_8859_5_BULGARIAN_MODEL, WINDOWS_1251_BULGARIAN_MODEL -from .langgreekmodel import ISO_8859_7_GREEK_MODEL, WINDOWS_1253_GREEK_MODEL -from .langhebrewmodel import WINDOWS_1255_HEBREW_MODEL - -# from .langhungarianmodel import (ISO_8859_2_HUNGARIAN_MODEL, -# WINDOWS_1250_HUNGARIAN_MODEL) -from .langrussianmodel import ( - IBM855_RUSSIAN_MODEL, - IBM866_RUSSIAN_MODEL, - ISO_8859_5_RUSSIAN_MODEL, - KOI8_R_RUSSIAN_MODEL, - MACCYRILLIC_RUSSIAN_MODEL, - WINDOWS_1251_RUSSIAN_MODEL, -) -from .langthaimodel import TIS_620_THAI_MODEL -from .langturkishmodel import ISO_8859_9_TURKISH_MODEL -from .sbcharsetprober import SingleByteCharSetProber - - -class SBCSGroupProber(CharSetGroupProber): - def __init__(self) -> None: - super().__init__() - hebrew_prober = HebrewProber() - logical_hebrew_prober = SingleByteCharSetProber( - WINDOWS_1255_HEBREW_MODEL, is_reversed=False, name_prober=hebrew_prober - ) - # TODO: See if using ISO-8859-8 Hebrew model works better here, since - # it's actually the visual one - visual_hebrew_prober = SingleByteCharSetProber( - WINDOWS_1255_HEBREW_MODEL, is_reversed=True, name_prober=hebrew_prober - ) - hebrew_prober.set_model_probers(logical_hebrew_prober, visual_hebrew_prober) - # TODO: ORDER MATTERS HERE. I changed the order vs what was in master - # and several tests failed that did not before. Some thought - # should be put into the ordering, and we should consider making - # order not matter here, because that is very counter-intuitive. - self.probers = [ - SingleByteCharSetProber(WINDOWS_1251_RUSSIAN_MODEL), - SingleByteCharSetProber(KOI8_R_RUSSIAN_MODEL), - SingleByteCharSetProber(ISO_8859_5_RUSSIAN_MODEL), - SingleByteCharSetProber(MACCYRILLIC_RUSSIAN_MODEL), - SingleByteCharSetProber(IBM866_RUSSIAN_MODEL), - SingleByteCharSetProber(IBM855_RUSSIAN_MODEL), - SingleByteCharSetProber(ISO_8859_7_GREEK_MODEL), - SingleByteCharSetProber(WINDOWS_1253_GREEK_MODEL), - SingleByteCharSetProber(ISO_8859_5_BULGARIAN_MODEL), - SingleByteCharSetProber(WINDOWS_1251_BULGARIAN_MODEL), - # TODO: Restore Hungarian encodings (iso-8859-2 and windows-1250) - # after we retrain model. - # SingleByteCharSetProber(ISO_8859_2_HUNGARIAN_MODEL), - # SingleByteCharSetProber(WINDOWS_1250_HUNGARIAN_MODEL), - SingleByteCharSetProber(TIS_620_THAI_MODEL), - SingleByteCharSetProber(ISO_8859_9_TURKISH_MODEL), - hebrew_prober, - logical_hebrew_prober, - visual_hebrew_prober, - ] - self.reset() diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/sjisprober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/sjisprober.py deleted file mode 100644 index 91df077..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/sjisprober.py +++ /dev/null @@ -1,105 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 Union - -from .chardistribution import SJISDistributionAnalysis -from .codingstatemachine import CodingStateMachine -from .enums import MachineState, ProbingState -from .jpcntx import SJISContextAnalysis -from .mbcharsetprober import MultiByteCharSetProber -from .mbcssm import SJIS_SM_MODEL - - -class SJISProber(MultiByteCharSetProber): - def __init__(self) -> None: - super().__init__() - self.coding_sm = CodingStateMachine(SJIS_SM_MODEL) - self.distribution_analyzer = SJISDistributionAnalysis() - self.context_analyzer = SJISContextAnalysis() - self.reset() - - def reset(self) -> None: - super().reset() - self.context_analyzer.reset() - - @property - def charset_name(self) -> str: - return self.context_analyzer.charset_name - - @property - def language(self) -> str: - return "Japanese" - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - assert self.coding_sm is not None - assert self.distribution_analyzer is not None - - for i, byte in enumerate(byte_str): - coding_state = self.coding_sm.next_state(byte) - if coding_state == MachineState.ERROR: - self.logger.debug( - "%s %s prober hit error at byte %s", - self.charset_name, - self.language, - i, - ) - self._state = ProbingState.NOT_ME - break - if coding_state == MachineState.ITS_ME: - self._state = ProbingState.FOUND_IT - break - if coding_state == MachineState.START: - char_len = self.coding_sm.get_current_charlen() - if i == 0: - self._last_char[1] = byte - self.context_analyzer.feed( - self._last_char[2 - char_len :], char_len - ) - self.distribution_analyzer.feed(self._last_char, char_len) - else: - self.context_analyzer.feed( - byte_str[i + 1 - char_len : i + 3 - char_len], char_len - ) - self.distribution_analyzer.feed(byte_str[i - 1 : i + 1], char_len) - - self._last_char[0] = byte_str[-1] - - if self.state == ProbingState.DETECTING: - if self.context_analyzer.got_enough_data() and ( - self.get_confidence() > self.SHORTCUT_THRESHOLD - ): - self._state = ProbingState.FOUND_IT - - return self.state - - def get_confidence(self) -> float: - assert self.distribution_analyzer is not None - - context_conf = self.context_analyzer.get_confidence() - distrib_conf = self.distribution_analyzer.get_confidence() - return max(context_conf, distrib_conf) diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/universaldetector.py b/myenv/Lib/site-packages/pip/_vendor/chardet/universaldetector.py deleted file mode 100644 index 30c441d..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/universaldetector.py +++ /dev/null @@ -1,362 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is Mozilla Universal charset detector code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 2001 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# Shy Shalom - original C code -# -# 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 ######################### -""" -Module containing the UniversalDetector detector class, which is the primary -class a user of ``chardet`` should use. - -:author: Mark Pilgrim (initial port to Python) -:author: Shy Shalom (original C code) -:author: Dan Blanchard (major refactoring for 3.0) -:author: Ian Cordasco -""" - - -import codecs -import logging -import re -from typing import List, Optional, Union - -from .charsetgroupprober import CharSetGroupProber -from .charsetprober import CharSetProber -from .enums import InputState, LanguageFilter, ProbingState -from .escprober import EscCharSetProber -from .latin1prober import Latin1Prober -from .macromanprober import MacRomanProber -from .mbcsgroupprober import MBCSGroupProber -from .resultdict import ResultDict -from .sbcsgroupprober import SBCSGroupProber -from .utf1632prober import UTF1632Prober - - -class UniversalDetector: - """ - The ``UniversalDetector`` class underlies the ``chardet.detect`` function - and coordinates all of the different charset probers. - - To get a ``dict`` containing an encoding and its confidence, you can simply - run: - - .. code:: - - u = UniversalDetector() - u.feed(some_bytes) - u.close() - detected = u.result - - """ - - MINIMUM_THRESHOLD = 0.20 - HIGH_BYTE_DETECTOR = re.compile(b"[\x80-\xFF]") - ESC_DETECTOR = re.compile(b"(\033|~{)") - WIN_BYTE_DETECTOR = re.compile(b"[\x80-\x9F]") - ISO_WIN_MAP = { - "iso-8859-1": "Windows-1252", - "iso-8859-2": "Windows-1250", - "iso-8859-5": "Windows-1251", - "iso-8859-6": "Windows-1256", - "iso-8859-7": "Windows-1253", - "iso-8859-8": "Windows-1255", - "iso-8859-9": "Windows-1254", - "iso-8859-13": "Windows-1257", - } - # Based on https://encoding.spec.whatwg.org/#names-and-labels - # but altered to match Python names for encodings and remove mappings - # that break tests. - LEGACY_MAP = { - "ascii": "Windows-1252", - "iso-8859-1": "Windows-1252", - "tis-620": "ISO-8859-11", - "iso-8859-9": "Windows-1254", - "gb2312": "GB18030", - "euc-kr": "CP949", - "utf-16le": "UTF-16", - } - - def __init__( - self, - lang_filter: LanguageFilter = LanguageFilter.ALL, - should_rename_legacy: bool = False, - ) -> None: - self._esc_charset_prober: Optional[EscCharSetProber] = None - self._utf1632_prober: Optional[UTF1632Prober] = None - self._charset_probers: List[CharSetProber] = [] - self.result: ResultDict = { - "encoding": None, - "confidence": 0.0, - "language": None, - } - self.done = False - self._got_data = False - self._input_state = InputState.PURE_ASCII - self._last_char = b"" - self.lang_filter = lang_filter - self.logger = logging.getLogger(__name__) - self._has_win_bytes = False - self.should_rename_legacy = should_rename_legacy - self.reset() - - @property - def input_state(self) -> int: - return self._input_state - - @property - def has_win_bytes(self) -> bool: - return self._has_win_bytes - - @property - def charset_probers(self) -> List[CharSetProber]: - return self._charset_probers - - def reset(self) -> None: - """ - Reset the UniversalDetector and all of its probers back to their - initial states. This is called by ``__init__``, so you only need to - call this directly in between analyses of different documents. - """ - self.result = {"encoding": None, "confidence": 0.0, "language": None} - self.done = False - self._got_data = False - self._has_win_bytes = False - self._input_state = InputState.PURE_ASCII - self._last_char = b"" - if self._esc_charset_prober: - self._esc_charset_prober.reset() - if self._utf1632_prober: - self._utf1632_prober.reset() - for prober in self._charset_probers: - prober.reset() - - def feed(self, byte_str: Union[bytes, bytearray]) -> None: - """ - Takes a chunk of a document and feeds it through all of the relevant - charset probers. - - After calling ``feed``, you can check the value of the ``done`` - attribute to see if you need to continue feeding the - ``UniversalDetector`` more data, or if it has made a prediction - (in the ``result`` attribute). - - .. note:: - You should always call ``close`` when you're done feeding in your - document if ``done`` is not already ``True``. - """ - if self.done: - return - - if not byte_str: - return - - if not isinstance(byte_str, bytearray): - byte_str = bytearray(byte_str) - - # First check for known BOMs, since these are guaranteed to be correct - if not self._got_data: - # If the data starts with BOM, we know it is UTF - if byte_str.startswith(codecs.BOM_UTF8): - # EF BB BF UTF-8 with BOM - self.result = { - "encoding": "UTF-8-SIG", - "confidence": 1.0, - "language": "", - } - elif byte_str.startswith((codecs.BOM_UTF32_LE, codecs.BOM_UTF32_BE)): - # FF FE 00 00 UTF-32, little-endian BOM - # 00 00 FE FF UTF-32, big-endian BOM - self.result = {"encoding": "UTF-32", "confidence": 1.0, "language": ""} - elif byte_str.startswith(b"\xFE\xFF\x00\x00"): - # FE FF 00 00 UCS-4, unusual octet order BOM (3412) - self.result = { - # TODO: This encoding is not supported by Python. Should remove? - "encoding": "X-ISO-10646-UCS-4-3412", - "confidence": 1.0, - "language": "", - } - elif byte_str.startswith(b"\x00\x00\xFF\xFE"): - # 00 00 FF FE UCS-4, unusual octet order BOM (2143) - self.result = { - # TODO: This encoding is not supported by Python. Should remove? - "encoding": "X-ISO-10646-UCS-4-2143", - "confidence": 1.0, - "language": "", - } - elif byte_str.startswith((codecs.BOM_LE, codecs.BOM_BE)): - # FF FE UTF-16, little endian BOM - # FE FF UTF-16, big endian BOM - self.result = {"encoding": "UTF-16", "confidence": 1.0, "language": ""} - - self._got_data = True - if self.result["encoding"] is not None: - self.done = True - return - - # If none of those matched and we've only see ASCII so far, check - # for high bytes and escape sequences - if self._input_state == InputState.PURE_ASCII: - if self.HIGH_BYTE_DETECTOR.search(byte_str): - self._input_state = InputState.HIGH_BYTE - elif ( - self._input_state == InputState.PURE_ASCII - and self.ESC_DETECTOR.search(self._last_char + byte_str) - ): - self._input_state = InputState.ESC_ASCII - - self._last_char = byte_str[-1:] - - # next we will look to see if it is appears to be either a UTF-16 or - # UTF-32 encoding - if not self._utf1632_prober: - self._utf1632_prober = UTF1632Prober() - - if self._utf1632_prober.state == ProbingState.DETECTING: - if self._utf1632_prober.feed(byte_str) == ProbingState.FOUND_IT: - self.result = { - "encoding": self._utf1632_prober.charset_name, - "confidence": self._utf1632_prober.get_confidence(), - "language": "", - } - self.done = True - return - - # If we've seen escape sequences, use the EscCharSetProber, which - # uses a simple state machine to check for known escape sequences in - # HZ and ISO-2022 encodings, since those are the only encodings that - # use such sequences. - if self._input_state == InputState.ESC_ASCII: - if not self._esc_charset_prober: - self._esc_charset_prober = EscCharSetProber(self.lang_filter) - if self._esc_charset_prober.feed(byte_str) == ProbingState.FOUND_IT: - self.result = { - "encoding": self._esc_charset_prober.charset_name, - "confidence": self._esc_charset_prober.get_confidence(), - "language": self._esc_charset_prober.language, - } - self.done = True - # If we've seen high bytes (i.e., those with values greater than 127), - # we need to do more complicated checks using all our multi-byte and - # single-byte probers that are left. The single-byte probers - # use character bigram distributions to determine the encoding, whereas - # the multi-byte probers use a combination of character unigram and - # bigram distributions. - elif self._input_state == InputState.HIGH_BYTE: - if not self._charset_probers: - self._charset_probers = [MBCSGroupProber(self.lang_filter)] - # If we're checking non-CJK encodings, use single-byte prober - if self.lang_filter & LanguageFilter.NON_CJK: - self._charset_probers.append(SBCSGroupProber()) - self._charset_probers.append(Latin1Prober()) - self._charset_probers.append(MacRomanProber()) - for prober in self._charset_probers: - if prober.feed(byte_str) == ProbingState.FOUND_IT: - self.result = { - "encoding": prober.charset_name, - "confidence": prober.get_confidence(), - "language": prober.language, - } - self.done = True - break - if self.WIN_BYTE_DETECTOR.search(byte_str): - self._has_win_bytes = True - - def close(self) -> ResultDict: - """ - Stop analyzing the current document and come up with a final - prediction. - - :returns: The ``result`` attribute, a ``dict`` with the keys - `encoding`, `confidence`, and `language`. - """ - # Don't bother with checks if we're already done - if self.done: - return self.result - self.done = True - - if not self._got_data: - self.logger.debug("no data received!") - - # Default to ASCII if it is all we've seen so far - elif self._input_state == InputState.PURE_ASCII: - self.result = {"encoding": "ascii", "confidence": 1.0, "language": ""} - - # If we have seen non-ASCII, return the best that met MINIMUM_THRESHOLD - elif self._input_state == InputState.HIGH_BYTE: - prober_confidence = None - max_prober_confidence = 0.0 - max_prober = None - for prober in self._charset_probers: - if not prober: - continue - prober_confidence = prober.get_confidence() - if prober_confidence > max_prober_confidence: - max_prober_confidence = prober_confidence - max_prober = prober - if max_prober and (max_prober_confidence > self.MINIMUM_THRESHOLD): - charset_name = max_prober.charset_name - assert charset_name is not None - lower_charset_name = charset_name.lower() - confidence = max_prober.get_confidence() - # Use Windows encoding name instead of ISO-8859 if we saw any - # extra Windows-specific bytes - if lower_charset_name.startswith("iso-8859"): - if self._has_win_bytes: - charset_name = self.ISO_WIN_MAP.get( - lower_charset_name, charset_name - ) - # Rename legacy encodings with superset encodings if asked - if self.should_rename_legacy: - charset_name = self.LEGACY_MAP.get( - (charset_name or "").lower(), charset_name - ) - self.result = { - "encoding": charset_name, - "confidence": confidence, - "language": max_prober.language, - } - - # Log all prober confidences if none met MINIMUM_THRESHOLD - if self.logger.getEffectiveLevel() <= logging.DEBUG: - if self.result["encoding"] is None: - self.logger.debug("no probers hit minimum threshold") - for group_prober in self._charset_probers: - if not group_prober: - continue - if isinstance(group_prober, CharSetGroupProber): - for prober in group_prober.probers: - self.logger.debug( - "%s %s confidence = %s", - prober.charset_name, - prober.language, - prober.get_confidence(), - ) - else: - self.logger.debug( - "%s %s confidence = %s", - group_prober.charset_name, - group_prober.language, - group_prober.get_confidence(), - ) - return self.result diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/utf1632prober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/utf1632prober.py deleted file mode 100644 index 6bdec63..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/utf1632prober.py +++ /dev/null @@ -1,225 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# -# Contributor(s): -# Jason Zavaglia -# -# 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 .charsetprober import CharSetProber -from .enums import ProbingState - - -class UTF1632Prober(CharSetProber): - """ - This class simply looks for occurrences of zero bytes, and infers - whether the file is UTF16 or UTF32 (low-endian or big-endian) - For instance, files looking like ( \0 \0 \0 [nonzero] )+ - have a good probability to be UTF32BE. Files looking like ( \0 [nonzero] )+ - may be guessed to be UTF16BE, and inversely for little-endian varieties. - """ - - # how many logical characters to scan before feeling confident of prediction - MIN_CHARS_FOR_DETECTION = 20 - # a fixed constant ratio of expected zeros or non-zeros in modulo-position. - EXPECTED_RATIO = 0.94 - - def __init__(self) -> None: - super().__init__() - self.position = 0 - self.zeros_at_mod = [0] * 4 - self.nonzeros_at_mod = [0] * 4 - self._state = ProbingState.DETECTING - self.quad = [0, 0, 0, 0] - self.invalid_utf16be = False - self.invalid_utf16le = False - self.invalid_utf32be = False - self.invalid_utf32le = False - self.first_half_surrogate_pair_detected_16be = False - self.first_half_surrogate_pair_detected_16le = False - self.reset() - - def reset(self) -> None: - super().reset() - self.position = 0 - self.zeros_at_mod = [0] * 4 - self.nonzeros_at_mod = [0] * 4 - self._state = ProbingState.DETECTING - self.invalid_utf16be = False - self.invalid_utf16le = False - self.invalid_utf32be = False - self.invalid_utf32le = False - self.first_half_surrogate_pair_detected_16be = False - self.first_half_surrogate_pair_detected_16le = False - self.quad = [0, 0, 0, 0] - - @property - def charset_name(self) -> str: - if self.is_likely_utf32be(): - return "utf-32be" - if self.is_likely_utf32le(): - return "utf-32le" - if self.is_likely_utf16be(): - return "utf-16be" - if self.is_likely_utf16le(): - return "utf-16le" - # default to something valid - return "utf-16" - - @property - def language(self) -> str: - return "" - - def approx_32bit_chars(self) -> float: - return max(1.0, self.position / 4.0) - - def approx_16bit_chars(self) -> float: - return max(1.0, self.position / 2.0) - - def is_likely_utf32be(self) -> bool: - approx_chars = self.approx_32bit_chars() - return approx_chars >= self.MIN_CHARS_FOR_DETECTION and ( - self.zeros_at_mod[0] / approx_chars > self.EXPECTED_RATIO - and self.zeros_at_mod[1] / approx_chars > self.EXPECTED_RATIO - and self.zeros_at_mod[2] / approx_chars > self.EXPECTED_RATIO - and self.nonzeros_at_mod[3] / approx_chars > self.EXPECTED_RATIO - and not self.invalid_utf32be - ) - - def is_likely_utf32le(self) -> bool: - approx_chars = self.approx_32bit_chars() - return approx_chars >= self.MIN_CHARS_FOR_DETECTION and ( - self.nonzeros_at_mod[0] / approx_chars > self.EXPECTED_RATIO - and self.zeros_at_mod[1] / approx_chars > self.EXPECTED_RATIO - and self.zeros_at_mod[2] / approx_chars > self.EXPECTED_RATIO - and self.zeros_at_mod[3] / approx_chars > self.EXPECTED_RATIO - and not self.invalid_utf32le - ) - - def is_likely_utf16be(self) -> bool: - approx_chars = self.approx_16bit_chars() - return approx_chars >= self.MIN_CHARS_FOR_DETECTION and ( - (self.nonzeros_at_mod[1] + self.nonzeros_at_mod[3]) / approx_chars - > self.EXPECTED_RATIO - and (self.zeros_at_mod[0] + self.zeros_at_mod[2]) / approx_chars - > self.EXPECTED_RATIO - and not self.invalid_utf16be - ) - - def is_likely_utf16le(self) -> bool: - approx_chars = self.approx_16bit_chars() - return approx_chars >= self.MIN_CHARS_FOR_DETECTION and ( - (self.nonzeros_at_mod[0] + self.nonzeros_at_mod[2]) / approx_chars - > self.EXPECTED_RATIO - and (self.zeros_at_mod[1] + self.zeros_at_mod[3]) / approx_chars - > self.EXPECTED_RATIO - and not self.invalid_utf16le - ) - - def validate_utf32_characters(self, quad: List[int]) -> None: - """ - Validate if the quad of bytes is valid UTF-32. - - UTF-32 is valid in the range 0x00000000 - 0x0010FFFF - excluding 0x0000D800 - 0x0000DFFF - - https://en.wikipedia.org/wiki/UTF-32 - """ - if ( - quad[0] != 0 - or quad[1] > 0x10 - or (quad[0] == 0 and quad[1] == 0 and 0xD8 <= quad[2] <= 0xDF) - ): - self.invalid_utf32be = True - if ( - quad[3] != 0 - or quad[2] > 0x10 - or (quad[3] == 0 and quad[2] == 0 and 0xD8 <= quad[1] <= 0xDF) - ): - self.invalid_utf32le = True - - def validate_utf16_characters(self, pair: List[int]) -> None: - """ - Validate if the pair of bytes is valid UTF-16. - - UTF-16 is valid in the range 0x0000 - 0xFFFF excluding 0xD800 - 0xFFFF - with an exception for surrogate pairs, which must be in the range - 0xD800-0xDBFF followed by 0xDC00-0xDFFF - - https://en.wikipedia.org/wiki/UTF-16 - """ - if not self.first_half_surrogate_pair_detected_16be: - if 0xD8 <= pair[0] <= 0xDB: - self.first_half_surrogate_pair_detected_16be = True - elif 0xDC <= pair[0] <= 0xDF: - self.invalid_utf16be = True - else: - if 0xDC <= pair[0] <= 0xDF: - self.first_half_surrogate_pair_detected_16be = False - else: - self.invalid_utf16be = True - - if not self.first_half_surrogate_pair_detected_16le: - if 0xD8 <= pair[1] <= 0xDB: - self.first_half_surrogate_pair_detected_16le = True - elif 0xDC <= pair[1] <= 0xDF: - self.invalid_utf16le = True - else: - if 0xDC <= pair[1] <= 0xDF: - self.first_half_surrogate_pair_detected_16le = False - else: - self.invalid_utf16le = True - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - for c in byte_str: - mod4 = self.position % 4 - self.quad[mod4] = c - if mod4 == 3: - self.validate_utf32_characters(self.quad) - self.validate_utf16_characters(self.quad[0:2]) - self.validate_utf16_characters(self.quad[2:4]) - if c == 0: - self.zeros_at_mod[mod4] += 1 - else: - self.nonzeros_at_mod[mod4] += 1 - self.position += 1 - return self.state - - @property - def state(self) -> ProbingState: - if self._state in {ProbingState.NOT_ME, ProbingState.FOUND_IT}: - # terminal, decided states - return self._state - if self.get_confidence() > 0.80: - self._state = ProbingState.FOUND_IT - elif self.position > 4 * 1024: - # if we get to 4kb into the file, and we can't conclude it's UTF, - # let's give up - self._state = ProbingState.NOT_ME - return self._state - - def get_confidence(self) -> float: - return ( - 0.85 - if ( - self.is_likely_utf16le() - or self.is_likely_utf16be() - or self.is_likely_utf32le() - or self.is_likely_utf32be() - ) - else 0.00 - ) diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/utf8prober.py b/myenv/Lib/site-packages/pip/_vendor/chardet/utf8prober.py deleted file mode 100644 index d96354d..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/utf8prober.py +++ /dev/null @@ -1,82 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# The Original Code is mozilla.org code. -# -# The Initial Developer of the Original Code is -# Netscape Communications Corporation. -# Portions created by the Initial Developer are Copyright (C) 1998 -# the Initial Developer. All Rights Reserved. -# -# Contributor(s): -# Mark Pilgrim - port to Python -# -# 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 Union - -from .charsetprober import CharSetProber -from .codingstatemachine import CodingStateMachine -from .enums import MachineState, ProbingState -from .mbcssm import UTF8_SM_MODEL - - -class UTF8Prober(CharSetProber): - ONE_CHAR_PROB = 0.5 - - def __init__(self) -> None: - super().__init__() - self.coding_sm = CodingStateMachine(UTF8_SM_MODEL) - self._num_mb_chars = 0 - self.reset() - - def reset(self) -> None: - super().reset() - self.coding_sm.reset() - self._num_mb_chars = 0 - - @property - def charset_name(self) -> str: - return "utf-8" - - @property - def language(self) -> str: - return "" - - def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: - for c in byte_str: - coding_state = self.coding_sm.next_state(c) - if coding_state == MachineState.ERROR: - self._state = ProbingState.NOT_ME - break - if coding_state == MachineState.ITS_ME: - self._state = ProbingState.FOUND_IT - break - if coding_state == MachineState.START: - if self.coding_sm.get_current_charlen() >= 2: - self._num_mb_chars += 1 - - if self.state == ProbingState.DETECTING: - if self.get_confidence() > self.SHORTCUT_THRESHOLD: - self._state = ProbingState.FOUND_IT - - return self.state - - def get_confidence(self) -> float: - unlike = 0.99 - if self._num_mb_chars < 6: - unlike *= self.ONE_CHAR_PROB**self._num_mb_chars - return 1.0 - unlike - return unlike diff --git a/myenv/Lib/site-packages/pip/_vendor/chardet/version.py b/myenv/Lib/site-packages/pip/_vendor/chardet/version.py deleted file mode 100644 index c5e9d85..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/chardet/version.py +++ /dev/null @@ -1,9 +0,0 @@ -""" -This module exists only to simplify retrieving the version number of chardet -from within setuptools and from chardet subpackages. - -:author: Dan Blanchard (dan.blanchard@gmail.com) -""" - -__version__ = "5.1.0" -VERSION = __version__.split(".") diff --git a/myenv/Lib/site-packages/pip/_vendor/colorama/__init__.py b/myenv/Lib/site-packages/pip/_vendor/colorama/__init__.py deleted file mode 100644 index 383101c..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/colorama/__init__.py +++ /dev/null @@ -1,7 +0,0 @@ -# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. -from .initialise import init, deinit, reinit, colorama_text, just_fix_windows_console -from .ansi import Fore, Back, Style, Cursor -from .ansitowin32 import AnsiToWin32 - -__version__ = '0.4.6' - diff --git a/myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-311.pyc deleted file mode 100644 index d6abb4b3430d2fc88be2cc32910fe454b956351d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 588 zcma)2y=ojW5SDJWdp~>UA|#N~MViIrF4!SO2m$*{z#(ySF#)k4lv_Dgte-{N^Z8u) z3DV{fj9-PEe8k z0wz?Xfk-2pkX7Q|x_djAT4f#AoHgRO2~WSxe8cwTF`G+M*|}#^YrIvWAc4HIP6V>W zr-vb(Gz%p{Hl8_eU4cWsX}tVoKTET*ev-Zzz8t>VEmlG=l1Z+l7cPN09Ep%d$Re}> z0^#u2bzmi{w+G|b+<14hc{6D=!Ys-J>C3?2}Td!80oaXVlM?m=- DTve_I diff --git a/myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-311.pyc deleted file mode 100644 index ed2a4c0beab75a41b3599619d3d775110b05ed16..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4586 zcmc&%TW=f36`sBDeih}5D7y_EJ9Qa5l9K>MtOPYEl9E+Zlp#uXvyr>qaMluSid1LU zb|feOAN*heMj;0dtVb89-57q!Z|E-&0Y3->_^D6(Mnf)8_^Id2l9Wg}EsECY5cBQK zIdeI4<~wJXe~Cnb1WNX=f4t5Eg!~OVo#JUXcB2v@j|e3ip^_$1S(B-vDO9~nG?jV) zJ@gRu-IX*iJpJ(W$z+nyz+FOvrvIrz$aAP}(E>sj0$uokE+}*n&_&Ha-@K5}#XuK7 zpbHD#0O%42bP<`Dp{KC<^NtBbi-IiNCyRkB(kF|9EZ8R-po1lnKD^cl&Mj4})N-BP zs+y@qvt}~GHmy{qSeiubY;dpY9OUut>u4GG7T(NAHmbfa8g5y(f zXm)I2-ZGiBP+BtX7}bTGY2CEzD+^Q8x$#uVgp)1cn%^Iz*gC#=bze4Yj` z%#^ZR8P6BM3m&^-S4~T}fkDI&9RnuU)Rc5AHW9Y&JR2D)&o8E~zmxMX&Fs#4d zWkJ`LY6XI37<8!LX9@JWrNhtNLm+xYOacjrKmw8=?I=_Rt|~l`0m5YQygi5T!whlr zKZ>b#XDR6QlRrnU<-e8IrN{fmz_50qQg5hOBX%b@!iaUUES+&GXoc~hWgE=4?o{k0?pri%!?qds0r9XQ0t4KjT4wb+ zS8K+y$vwA?>Mhg4e_ zj0w1x+ZjCi=)!jw9)H>#JpE$ubc@K5v6n;dJysvn=FpiJLuWQUFXKnI)GhjC`o|BN zr#^de>a%A2{EPVc?fChBw0xbF1lx*fm4iKKtFH5)uDf{@+F@P)!!4ugYS=HpqGv8a z#Ua>n5C}-3!6${m4KNyiE!pP*YY&3hQp_sDgl_3vSUXd8x#g!ayu=jhrwTk(c&hO9 zz|#XyFAY#HJbly$>xN$8rJTaGQ z7H-nHSb6^PT4c|Pk@?FXfVPt+V~OueTLTZSJiM~8zEy6|kP{u~(4 zW22gzxmsL{?XwaEr(qcT6hWk*cVSTWCk*mU%*cF)fRS z+x9a-nqPvPiF^74TNqyKJi-?U;|L!jAg|oaaTZ$$r=VKj0AS8=e=S+^yx$_dp!Rl! z_CJt)jO)D>T%*vGo^;fC_w3GsX8)@WUv!X$6i7iTq#qBY9cy$KJon7zOZhn-DNIdXoD)mv`QP%8=)zLiadl!z z>_&yoT^jr0_SE@2_F|&f-fB;cTVl^$OKc6@e%|EZXbjpsL&?D; zzP8K-#6>93PZrSvoJ{a@h?8mnAicx?!*&rYpMZ1mpnMB zn3fn?lumG;uG4y1*O?dkEQ)}CR>bF{`0FD66^IXV?yY})!z|nG=a$Hv$V72P!WOP# z8i61No^X#iJ@;nCOSI4aH~uf&Z@XW!4Ojw`oOJ`RrAU(0QWZ&s?@NFn@kJZTjyHl3 zY$z?SB%Od1+5zaE!fqS-v|`-bWPZN{pM(ct)B6ggulH0(f)ZrwgRptz6-r<4sfGuo zWQ!bxd#kTd`g%`wc2F9|k^SI~9LAAt)mc?aw8%l&47@_=>pfMN1QYj$HiqvHH`JZL fz+N+PFS&8-{;`HhyyHR@2xc>SlADFW&}uH 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-311.pyc deleted file mode 100644 index 444d6bd6923effa7762ea8c694a411d052f920c6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3949 zcmc&%O>7&-6`tYll1r{gnUd&;){oZ;(}u2Nx3P<~Mbp4>EZcR%i{u0r1QToRN?MsB ziP@DY1uQ@pI)PN4D8bdkwRPMZB&{Jb~wX7;`BJ^nr(j}a)BK7X+Ij{!pdiXE?ndX4?xK;se7iB1b-&VAE4 z%KM?YkRH;7g0L#iiInK#CYh6T320bP=<+6=i|A44$$AWE)SxSTKU`T?HpvdWcd^6E zoT3i^*MJ@e8V?ae3eLm&bcSRHze4WZR}^TLI?BbOWzLq~H;db?yG z_1Cb1-dYH%pi@nRDn*GM?@7RGCE~U1V_u7p9oTCZ_u~chAT#7;Vh?#Egk%VV^WWq% z6|yeeBo&$s<)*VSM=3FLDR0?&Y0WqfI3e(DEL-!{8`#7&?wy|#7dA(FLoYbPZ z4y+ZksFx~MexX#fN(I9SyF5;8t;mce)3OcbM44e3c3vwKoWw=jX6EfR+qleFi9I3v zsPi`~mwqyT!!npPKeMb=w8H#5hIPj-mFKU$`_9|yj8U}BRUqocqE^_jOly91!zkXJ z|Al#b-ZE|DwX(KwM_V$i`LbC)m%nR(PVC%5sZe6ts&>vSnzpGGOv^Z1-f$*C=dzJE zi=Y}T2Zsff^NS^xw++j-*f1y*g=!f9sdOy|?cq^AG%?i> z(_K-L;?LzoOHMz|Hswr9&NRH=K}ShT5*q(>LbkIV!`(`{@;DP3$wYye?mh^B=KGTxVG`wF| zAo5Az@C%{)*atJFNJe zniv?DJb5h~829;W0yt@;n6dE=dc~H#7U7zKe!>o{wCk_79@stauck!;yZHQkm*|mQ z&^mer&;K8H@mJHL_J}75UunXA>9DuruWFw-91Y$bm_$g6p-EuP3b_x?AVR!3traXo z1&?1Wm?sFq0@-e`=TZ;o7Oja+btJBiUo z`bsl#wUxNqkgvXok>TSXovvN)45je(JQCadpb<&8(-ZYXJ@Fz;;-in1?e{-5p5FYE z*c`ar8o1mQXmpx>DBO>2-TGhoU&v(OB}9+0j-0qZ_&C~>r&{tc+}{iE`(EbR3rm4eR&p^U4Q+;o z=6>ceYy~033F`*`HW`?^2-SKOh>t2M74NPGF>a?GtH%Op5;!$#%}=dzEa^Yz3XHf# zr+1KtFbKgjq~9ldBYkJDMf&~yo-3jB7J^q`2VV}-67ZtWgdMn_UH^`LNveIJoefk2 z(s^In{?GcZiewVVY&Od9 z^Eq<4pxF>7R~c%>UDfqYJeK=$xg>tvY{-cfjf$5^cx~`=3k}Qj#?h5E%g#e4aWs!$ z-vh3zP_2hRY6N^rRyM0!m1mJj2p(-YQ4e<_W&@d@NzrX*+LxH zSO$3E1Bd{`fVFoj_zqlq+)IrhYRsay$$4V@YKk2QLbm;oLk@V&)W?NQnD?_ z>k>YY?EG53FW32V@L|~NU^;{5wIycAC&w-b0iXOoBN6JwP1!Y89$Ee^5-}HvegOQ- zP<2AyuXAKJx+L zUI`iji&Ui*AFUBtz@I}o_Fdra<#CQ;Etl2`kgY>N#DI&DH5+CZfaQp{vr{nUM3Auz z`8evX^5W)w<0yfo1l76%q(<5irAtI9(;1rhc(FY)w*AAW*C5;tzx6c%@^>Wl$euFv zr849&%rz00pHD^BNfkT$rXJ_g|&?XzIsb^%Dy;IEZk z;yC5zrC;8{V%?Vm1EkkxV1_>xM@tr20NN8=|j4VD?BXO(9MP$&W;O3U1IN zi4?Yca+ZV!TJ%IWB++D-0Qp)Vp)r5tm`F1y+#`uF9qJOFj1YRVK_;6-Z4tHM{rF}7 E6WLZ2>Hq)$ diff --git a/myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-311.pyc deleted file mode 100644 index 3ac8f33e9a73eea2834fd086d233f9f19f52947f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7937 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 U;!g0UpZe18z1eU5vX2J(|4aXKhX4Qo diff --git a/myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-311.pyc deleted file mode 100644 index 5c5fef61cef92fc3435e1c3136a20c28d279f264..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9163 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/ansi_test.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/ansi_test.cpython-311.pyc deleted file mode 100644 index f86bb8c4abdd3676328f7072c08e1a5b45a01992..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5864 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 LvGzq54e7Af$XWNwzB8d$xOh(AK5z- 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/isatty_test.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/isatty_test.cpython-311.pyc deleted file mode 100644 index 4e0581b37d5209a0a2df51cadd79c11fc5db6932..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6723 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/winterm_test.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/winterm_test.cpython-311.pyc deleted file mode 100644 index 2333386aad91b9428c8a530aaaf43f03d79182f2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7251 zcmeHM+iw%u89#HgkL`)EfLx)$>4IQZn*_oZXjyfY8)+&CEis~4kt~y$fP*jDGZV6j zf|N=;1cY{335liJs!<=ZAhr?@?Q0+QFR;-_YmJ12RPm5EBWQ(ImD=w+j>p#+s!h9n z*pr!W&hp?>PhJ{j6HZw0DL*^dQi7q5b6u)9pNQqG~ zB}Ju_9F+y)!&)h+q&!hi${Y0xB)#h$V$l7B1%zUouiSQ#q~!(jv2>9v2)e8*Nq;I3 z4W!hlnrex*2t*`fMEBevy4MibB|;v-TTIcQu|uaYb5Y*lLX#6&Vg;>OzSw~wr|I(`RX{g zG+Z@*UB6(%eu27vJ9KrDXe~})6FP{)rM77VRy-B&TS%lW02F?Y4oth-2|FsoiQsv&S)S|)2H7?-;6@3J)ODOKoV zHRJ@+WRweM0B#jfn~rj!uh+mE?FTHQGO>{XaW;_q1`4);BQzhwyc1X$v@DjmG;bNE z(=}#T!}3-GaV(=?bh`q6wm=_s+8 z3^U+!DGp}A6EjiyAIgqw8p#>QmjYt}yLoiLp_s)<9T|7g#61f``j!pJdhRg zd{_Ht$L=0mrTKlmtJJ1@^B;_?`fU21O@I1yN88QC+l#Amo~qx_jwiI^^W9%`t^GPj z58Cu#mL7bY`aNs$96e;yL)p^v5+){&1Trs$nDNnkf*EEQ#MCnj=Cli4=z}}SVZREn zX$pG*U@w$m&r2@sdC7%702Q~UE-edZIIRu~t0Lz%od=O}kSik85_SY8yytHI%B6{M_(J z6ATx1BLqYXaFfB>AXTp|XGI{#|#jQ?om@2S;+W*QUK$+WWlqM|Wdy+W2+`f=pfK;F{DKHszN{;@BP zt;#m-$hV@Zg5nlGZ5^l~xo@K!KKJD^9Fc0hSsd~$_B083zZ9)7$(M~~a|c((Ku z)d^R+l+b~4$NUe-G*u_Ta!q?JU@M(djf)l*H*W9{bgJKA ztUUuv*a;*(K&pb@A9RdpB^|?fs)3GS(BmllMAmE%d>BIUOPi(E+W3iA{|5M&&D5+I zI-#2RZ~5;G+zj3ht_CaBY|q-I9Mx>9WvTYI1{I^cQgTl^hrqx!HK_ly_ynR3H##Ya ziQjd2%jY3(g55ZwvL9SLxRJoD8^1uU8#llVuCK2gSv|vym>@HC*9|-p5Q`?bnbY^c zDN_fp&TTRe%iAa2%YcaSF^{YHHG$(ppC5~}%ckR*jEtN;A7KYTtVS_FkR!_Fv(!}w zE4OVLSeQ3~RK)?|Esxqy+qyoRxjVDz@rxclN4sp=m8D%SaiD!M_ul_K`gHNDn%mFs6@i-uDxwLF zFO!DLA>ClC2_D%XBFY6LLkG`>fpEx;o;$ZC!(RAos zGHyYHm4X|5E6yx)Az@u%?_#F`B*&4QMDih$Q6%F)9u~bV59e76)*`{zyblVn;{H8T z{43|Pfp>Dsep}gJ5WR|4AV6M7#B;!{*-1R1mFOMmuKG>r;FHk72TCr~XNUT-hlg^? zu&oRi#9ay=P?6%$5usf9F7X7a<_IY#3Is@b4y@V#<~b-11X3{rR_*?NMppkQRRJRe zr2M0>W^e6pZ`=(B^3mLI@x4OG;J> 4) & 7 - self._style = value & (WinStyle.BRIGHT | WinStyle.BRIGHT_BACKGROUND) - - def reset_all(self, on_stderr=None): - self.set_attrs(self._default) - self.set_console(attrs=self._default) - self._light = 0 - - def fore(self, fore=None, light=False, on_stderr=False): - if fore is None: - fore = self._default_fore - self._fore = fore - # Emulate LIGHT_EX with BRIGHT Style - if light: - self._light |= WinStyle.BRIGHT - else: - self._light &= ~WinStyle.BRIGHT - self.set_console(on_stderr=on_stderr) - - def back(self, back=None, light=False, on_stderr=False): - if back is None: - back = self._default_back - self._back = back - # Emulate LIGHT_EX with BRIGHT_BACKGROUND Style - if light: - self._light |= WinStyle.BRIGHT_BACKGROUND - else: - self._light &= ~WinStyle.BRIGHT_BACKGROUND - self.set_console(on_stderr=on_stderr) - - def style(self, style=None, on_stderr=False): - if style is None: - style = self._default_style - self._style = style - self.set_console(on_stderr=on_stderr) - - def set_console(self, attrs=None, on_stderr=False): - if attrs is None: - attrs = self.get_attrs() - handle = win32.STDOUT - if on_stderr: - handle = win32.STDERR - win32.SetConsoleTextAttribute(handle, attrs) - - def get_position(self, handle): - position = win32.GetConsoleScreenBufferInfo(handle).dwCursorPosition - # Because Windows coordinates are 0-based, - # and win32.SetConsoleCursorPosition expects 1-based. - position.X += 1 - position.Y += 1 - return position - - def set_cursor_position(self, position=None, on_stderr=False): - if position is None: - # I'm not currently tracking the position, so there is no default. - # position = self.get_position() - return - handle = win32.STDOUT - if on_stderr: - handle = win32.STDERR - win32.SetConsoleCursorPosition(handle, position) - - def cursor_adjust(self, x, y, on_stderr=False): - handle = win32.STDOUT - if on_stderr: - handle = win32.STDERR - position = self.get_position(handle) - adjusted_position = (position.Y + y, position.X + x) - win32.SetConsoleCursorPosition(handle, adjusted_position, adjust=False) - - def erase_screen(self, mode=0, on_stderr=False): - # 0 should clear from the cursor to the end of the screen. - # 1 should clear from the cursor to the beginning of the screen. - # 2 should clear the entire screen, and move cursor to (1,1) - handle = win32.STDOUT - if on_stderr: - handle = win32.STDERR - csbi = win32.GetConsoleScreenBufferInfo(handle) - # get the number of character cells in the current buffer - cells_in_screen = csbi.dwSize.X * csbi.dwSize.Y - # get number of character cells before current cursor position - cells_before_cursor = csbi.dwSize.X * csbi.dwCursorPosition.Y + csbi.dwCursorPosition.X - if mode == 0: - from_coord = csbi.dwCursorPosition - cells_to_erase = cells_in_screen - cells_before_cursor - elif mode == 1: - from_coord = win32.COORD(0, 0) - cells_to_erase = cells_before_cursor - elif mode == 2: - from_coord = win32.COORD(0, 0) - cells_to_erase = cells_in_screen - else: - # invalid mode - return - # fill the entire screen with blanks - win32.FillConsoleOutputCharacter(handle, ' ', cells_to_erase, from_coord) - # now set the buffer's attributes accordingly - win32.FillConsoleOutputAttribute(handle, self.get_attrs(), cells_to_erase, from_coord) - if mode == 2: - # put the cursor where needed - win32.SetConsoleCursorPosition(handle, (1, 1)) - - def erase_line(self, mode=0, on_stderr=False): - # 0 should clear from the cursor to the end of the line. - # 1 should clear from the cursor to the beginning of the line. - # 2 should clear the entire line. - handle = win32.STDOUT - if on_stderr: - handle = win32.STDERR - csbi = win32.GetConsoleScreenBufferInfo(handle) - if mode == 0: - from_coord = csbi.dwCursorPosition - cells_to_erase = csbi.dwSize.X - csbi.dwCursorPosition.X - elif mode == 1: - from_coord = win32.COORD(0, csbi.dwCursorPosition.Y) - cells_to_erase = csbi.dwCursorPosition.X - elif mode == 2: - from_coord = win32.COORD(0, csbi.dwCursorPosition.Y) - cells_to_erase = csbi.dwSize.X - else: - # invalid mode - return - # fill the entire screen with blanks - win32.FillConsoleOutputCharacter(handle, ' ', cells_to_erase, from_coord) - # now set the buffer's attributes accordingly - win32.FillConsoleOutputAttribute(handle, self.get_attrs(), cells_to_erase, from_coord) - - def set_title(self, title): - win32.SetConsoleTitle(title) - - -def enable_vt_processing(fd): - if win32.windll is None or not win32.winapi_test(): - return False - - try: - handle = get_osfhandle(fd) - mode = win32.GetConsoleMode(handle) - win32.SetConsoleMode( - handle, - mode | win32.ENABLE_VIRTUAL_TERMINAL_PROCESSING, - ) - - mode = win32.GetConsoleMode(handle) - if mode & win32.ENABLE_VIRTUAL_TERMINAL_PROCESSING: - return True - # Can get TypeError in testsuite where 'fd' is a Mock() - except (OSError, TypeError): - return False diff --git a/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-311.pyc index 172ba15a65ad39934fa80456b927a40a0dca7b48..21bcc8b480dd8c92ada88de36bf6ce1c33d9e136 100644 GIT binary patch delta 19 ZcmX@feUh7NIWI340}!~J+{m?`6#z3L1quKF delta 19 ZcmX@feUh7NIWI340}wbL+Q_w^6#z2%1p)v7 diff --git a/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-311.pyc index 3560f0aae8cb7b66d5b8275dabc4f489d4fb9b1d..334bcc0f156958ba7139d48e583a6651313e357e 100644 GIT binary patch delta 21 bcmX>!lljn0X0GMDyj%=G;Bs;!*N!s)N;d}H delta 21 bcmX>!lljn0X0GMDyj%=G;CyH!*N!s)N)86r diff --git a/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-311.pyc index fdc57d76c327b86f37598f3564dfe0fe59a7aa75..8b50860273a385cd092c8c1573bd552ab83eefbc 100644 GIT binary patch delta 24 ecmZqQ!qUElg=;x4FBbz4xSVX{+RDZFR}uhL(+0u- delta 24 ecmZqQ!qUElg=;x4FBbz4I3H@{+RDZFR}uhLk_Nf} diff --git a/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-311.pyc index d65f3eb90609c32e7b8c49926210c3c4c7930b37..8dd2955d710c3912ab631532eec618a1f8046f2f 100644 GIT binary patch delta 21 bcmdmSfpNzLMy}<&yj%=G;Bs;!mtF<{PUZ$i delta 21 bcmdmSfpNzLMy}<&yj%=G;CyH!mtF<{PQ3;` diff --git a/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-311.pyc index 93ee688b697e9aa4dbad3a4fa842923e1fa17135..b7dca9055ee465978729a26410e7b2c79cc8e295 100644 GIT binary patch delta 24 ecmeBeV(D#S;abki%f$c$E+-qgwsJ8tGXeljZv|KY delta 24 ecmeBeV(D#S;abki%f$c$&W9SgwsJ8tGXeljE(K5k diff --git a/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-311.pyc index 25701fe11b7efcd631dd273de461a6499eea7ffc..9695a0d69e7cd9f3abe045cc108c76742856891c 100644 GIT binary patch delta 21 bcmZo`Wo&C@; delta 21 bcmZo`Wo&C@v5IWI340}!~J+{l%s2mn9s1(g5* delta 19 Zcmez3^u>v5IWI340}wbL+Q^lq2mn9D1&sgz diff --git a/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-311.pyc index 33983c9192b09cdca2e4ab29d38b18487da2425c..5a81b293cdbb08d034e1df9b4aa6e8231c15a376 100644 GIT binary patch delta 21 bcmccmiRtPmCa&eYyj%=G;Bs;!m-kKpSm_5e delta 21 bcmccmiRtPmCa&eYyj%=G;CyH!m-kKpSilD? diff --git a/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-311.pyc index a7d6f91c2e0dcb7d023094fcd8c91be4ac09bb49..b57a741607774eeab93476c3ccee89ff6a36a989 100644 GIT binary patch delta 21 bcmdltg>l~$My}<&yj%=G;Bs;!mx&huM-m0X delta 21 bcmdltg>l~$My}<&yj%=G;CyH!mx&huM(G8* diff --git a/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-311.pyc index 9913eca4daef58549530416b56d36540e980827b..649fbf6e87bb8c6f5bcc3a351f982673b0c72a6e 100644 GIT binary patch delta 2652 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 delta 19 ZcmdnRxr>u)IWI340}wbL+Q_wm1pqL51keBg diff --git a/myenv/Lib/site-packages/pip/_vendor/distro/__pycache__/__main__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distro/__pycache__/__main__.cpython-311.pyc index 6a73c2d1c9412c6e896b911276ae7ea8fe557048..85fbac93d8faa4288da03bf04ab5ee3e353f1e29 100644 GIT binary patch delta 19 Zcmcb?bc2a&IWI340}!~J+{op}2mmuC1fc)` delta 19 Zcmcb?bc2a&IWI340}wbL+Q{X{2mmtu1epK; diff --git a/myenv/Lib/site-packages/pip/_vendor/distro/__pycache__/distro.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/distro/__pycache__/distro.cpython-311.pyc index d705e8ec50bfe459e368a6cdfa2e4356bcbd85e9..79fc756dc548b7675028b601b5358a500d2dc9bc 100644 GIT binary patch delta 4031 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/distro/distro.py b/myenv/Lib/site-packages/pip/_vendor/distro/distro.py index 89e1868..78ccdfa 100644 --- a/myenv/Lib/site-packages/pip/_vendor/distro/distro.py +++ b/myenv/Lib/site-packages/pip/_vendor/distro/distro.py @@ -1,5 +1,5 @@ #!/usr/bin/env python -# Copyright 2015,2016,2017 Nir Cohen +# Copyright 2015-2021 Nir Cohen # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -55,7 +55,7 @@ # Python 3.7 TypedDict = dict -__version__ = "1.8.0" +__version__ = "1.9.0" class VersionDict(TypedDict): @@ -125,6 +125,7 @@ class InfoDict(TypedDict): # Base file names to be looked up for if _UNIXCONFDIR is not readable. _DISTRO_RELEASE_BASENAMES = [ "SuSE-release", + "altlinux-release", "arch-release", "base-release", "centos-release", @@ -151,6 +152,8 @@ class InfoDict(TypedDict): "system-release", "plesk-release", "iredmail-release", + "board-release", + "ec2_version", ) @@ -243,6 +246,7 @@ def id() -> str: "rocky" Rocky Linux "aix" AIX "guix" Guix System + "altlinux" ALT Linux ============== ========================================= If you have a need to get distros for reliable IDs added into this set, @@ -991,10 +995,10 @@ def info(self, pretty: bool = False, best: bool = False) -> InfoDict: For details, see :func:`distro.info`. """ - return dict( + return InfoDict( id=self.id(), version=self.version(pretty, best), - version_parts=dict( + version_parts=VersionDict( major=self.major_version(best), minor=self.minor_version(best), build_number=self.build_number(best), diff --git a/myenv/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-311.pyc index fe7cb8baeb0e3149c09706778e51ab63b813815a..3f1f2c8e710a1fb8c010e0fd37c67eb6d7229fff 100644 GIT binary patch delta 19 Zcmcc4ah-!}IWI340}!~J+{oq20su451g!u7 delta 19 Zcmcc4ah-!}IWI340}wbL+Q{Y00su3n1f>7~ diff --git a/myenv/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-311.pyc index d878b0b65033b419ddf5056f4c2a598bd34b5528..b2e35169da237673e088f173d0383b11abffc7a9 100644 GIT binary patch delta 2309 zcmZ`)UrbY17(chY|N6g|7D@|33ka}3zWb<-zbw(q-_0%P*g`#azH&hMV{ zedqqp;ogp=cF)%ykCT86{<<)B?zSh)>9^b7c2BxSTpY0xO&WLK*28li8#zi;@g`9v zO&s^)3usGrLLR|m*@)L<$-r^|%U6kSV);#$6Id=_DO<3rOqLs19?i=-xcWIW;Dvxs z^TLb4wHJ9v0v^jof~sGuRuv5=uc<`C6^D%RYSm4CBm}jIFg5MA=*p!gZlL2MeY*Ed0Cacg?q^M+S^5}mHOGZ{W)I^E<0;`BH}L5 z0ON$RaFu$~e>K9$xJPKvp#uR+_` zu%olVO*P~4L}v8dbVf4_)EZR1YEb-_j*BCaVj!H|^QRK~O=)|kv_0VSN_#ne=IM@=J}$pF8ATGFSabl%<6{{ z4%&bfH6lb2VgM!n+|<+r#X@KkLNh`SLJPwBS8K&?EBSq^>kn1@M$x!C0J{EaH385z zOb!oU3UygA5gZie%fDHt^fCL9_ngRJY}J-P0FO`vrWyVWDq+=TIFFabZ@N;b~}wSH*St8loy;TowC??wGL~lH~)_h9l?6tfnCxl!u)VM;>MNTt(s z8~8K<@S58wcjv0yk?BkuY2C;q^^|66f$qe2-a=?cz^$^5cn5fII1!`{2%X5=gf;2XRvN>^F;SzcK`v`hC3VC22KZ;Ibg|WXi1v7FgkWwPi4|mI>nQpM$)?g z*GW-w&0l>cg_osp(HEG{thkhdtFGu#R(!$FuH3qE>srNO538EYjY))AzAD;z5~sIO ztt4iqFQ)bL)cnBaXLaF_l$x5nn4ZuqU3yqwpw>~j`&*&6{m1~&ti6n(hY6YKm1L@& zPa7HdC((kjwOj19+&4L;UY^hn(96rfmkBhB@dtYfJNFlw`poWTh!D6vyv<^FHS5@#Y&w24;#N87kCBQ3Q&ULKQWcRGVsKVFP_{$RNz%ozVmn zBa1FgEj^1iU72Vw=*FZ`yKIb2x+EzJ`l2Q_apA^{X;-@W&L?$Zgm9p>;FM$JYB_evUJRImTjyEL3c5gERImeqNc4D(qEe>lc`9 zIQpWwezV;&r4&Rdgi;$xmXyLMMNo>N6pu?OijwJ=C?=qdx0?y6wxMb{CWLt|XUEW( zdbD3fvEvui*|Z%v!-@&G#$V#f^}GB7&P{kD(94Uk5*XCmaJaDG%fMZpgiq8TUo=Tb zAT|}3i6AzLsxU~Tm4!-36EcWK08uCuLb&963{h8w8X znt}$)1vZ(Wp`wEjm4He8qAtZK{1zFyY=qkbj$To+X!S}ZXlv+?0Y{9^gm-K-xLT!J zn_CjG>t*8>e||Gm7QP4KDI6d=5r6)J-8l;fe}XtBZMBpUOalKOUS|RvD8erR`_DL#jyG=AgdeGvbuTp_VCu} zGq*>7J}3K6gtv6>|3@_mrD!m=&v8147uQpwA3J``$S^=SN_du_6J%ZtQfmm&phtqq zv0E@lx~*}Zf>~=Eez1NW_p;^CK#3Pb1;!^V9JvF88nsKK>qFTN9SB0lozTh5&Ah_X0AlMXCY zB8@OljY)#Mbdp32aUMUvkni+f?tg{2!kYfi2xE(W+vZKppTRa5e3n=<)v8^aD;lm^ zn_G4um$cuJFU)^@GPlGi&hvaLQS0%ux{(E^DVzldAML7m9S2nKYmirK?2kx%JJPvh zCgHE-uza$`4D_c812brL72&vgb9JR!Tk!6WlE5|2*OynSOOBT{QTQlT;Jt7q)mM_? zE#VmP8iDpYaF~a|iRHTe;gT~c-b5=o-}o5W3UJPMAfA32@@XB8r&F1pEq2I1*y*Wv z3oVxC2XQsCogMp|3=j6KCwVu=ocS+yN2B4vp7rGA%(m&dbZi00b^4H*)=A1^_911hW7D delta 19 ZcmZqSXyM>m&dbZi00hp5Hgf%91^_8j1gii5 diff --git a/myenv/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-311.pyc index 5ff1ead41a31616016458914e27047e3433de994..21ad3cc9a68482e084aa26aa96c4578f446368e7 100644 GIT binary patch delta 1517 zcmb`HZA@EL7{|}Ky|?rQXiMKlYoVnS+Lh9=f=V+O&?ZJgUsYBv-rxNWlk zm!azlRcfH@G>bn;Wh#y`GCENaxqrI{w|A&P(bf+uw$JcE7^|8SJtvr8*6xJv>X-36 zY*g8>1kTxwxSD3M6nd%!aU5ST3J&*Eq2Z#%fH@OQbDKR&7bz=GAGnYfbISA*RTi)wxz{ z5B^Xa_^vjP)s!aeliioQlYR55=>tptW$nVg>-#oE*xmR$BC?6F-b;FVZw_IVHzy(n zcg3i<98T3}An5uA&TEVXPhy0okQAn+4tTS60{-xnNrgf(HQL~!p&a7w4x{MV3>Sz6 zL!lGJ`vZrEN6kVcVjhizM;sEk?{*sa*GYAzcrY+ZpAJU(;Ul3j-bF3icR6GiNartd z$3BKvc7@Gk7MwE9rCHq?t6ODt*%I?ixq)R+0SKS99d=}F67UMZOj3Ht+ z^CcwkXSSszRn+h~i?2Ysv0ph!vzMp0G0J z`4)3akwBOHpEiz$@WT}+QP^Zf0=r#-P$lA(7zqWip??hScqH(C8%Ne()#Sz;v^F`4 zw&{@}Ne(Q2Eqv-zz&lM^TmUzlI@*(dc!a{g7~oDszY9v1f+o}piv;bPIzkdRRh9t($pk)h$ip@5$4Es_f6z2DkltaqfN#JLx%u(5b2dWmYyPNEZ*cg!sl$C4afvf7Y z+_WY)X7Am^Gh`S5f%EI;AddgUnze8AAIlkxT2KY(|K|^hUMzB ziqeGTYF}DmSyNcZF_fAg0YY6*^z6X8__0JE`LmR+ jns%@0Jvl^DD{MYIDvv9%K2E$zNZ9h>QK?Ghy7c&Ob#kA@ delta 1758 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 Lr@I2llPCWlr<;Ow literal 38987 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 delta 23 dcmaFP_?(ezIWI340}wbLn#g6qXfn}y4FE~J1|t9f diff --git a/myenv/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-311.pyc index a038e9fc6416ec0d7d5880d1d6311eb99002c44e..2503b9043a6a324d026b695349a502404fd3bfa9 100644 GIT binary patch delta 13023 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 G@c#gEVRT{u delta 13048 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

kIl^jly{WG%gcTGoX><(BnS zmE@mHJK<*UTs^?g?9+*QOWO8&>doj2lAnd}Ap7z9Dk9j~j+Pj9M>le;)5uJ2o~r8e z@l>@{|4lbO?a}l8O}(F5T40{{Zvo8n{yzZoynh>Dp7-wn;y5W?P2|1lY9OuWlnm94 zHt?(rl}{h=g$y-`{^6H1)gbzeFJ!8!)Q`imbjoe+o29bTkH~UhwcEnDm{wYVd>I;6Zp{~-;+ZyUYS!xG2 zQhHEnowenOGr)goeU zny;47*Zfnyni_ptj_^$22-Xigx|JFf{jPXx_%|G0pmJyrH!V;N_2b!y0^PMA+1m=# zF*8&-RwN=j(J+Lpea|UTX|Jq((LHq52^JGdZrK z{&T2>?sr>|M|5o56U@X7%f{b27b^|L^S3Je3I9+cQUHF2k!HJ!8 z2b{Baby5Qro#(nQsc-2!4)3DQ(`5doi=JjvxM){Bg{JZ=UDf0&Mf4GFRCHE+bPtXS z`b!m1v9P~_{^ynBx~cb^2c977w)0X#U$s_6=Oxv7advmR8@S!A+U}-ocl))w&Dz~i z?QV*8cgkAT^$EFKVBKx3ma}2i-I3~UJau=JTC*H;_IA3PFWpU(*2Q4`=c~I3(8|@< zg}bT9@;Lu-OW9}N5<*atOi(2j))#KLp&gTox%SGqqvh(tr^Wxl0E$3$CUbFg=(*JX&tvfH= pF|vyAZ{1aWin8N+D60&$=B52q&2oD6K=<|kd+lX^K18h!{XcPEU*-S+ diff --git a/myenv/Lib/site-packages/pip/_vendor/idna/codec.py b/myenv/Lib/site-packages/pip/_vendor/idna/codec.py index 1ca9ba6..c855a4d 100644 --- a/myenv/Lib/site-packages/pip/_vendor/idna/codec.py +++ b/myenv/Lib/site-packages/pip/_vendor/idna/codec.py @@ -1,7 +1,7 @@ from .core import encode, decode, alabel, ulabel, IDNAError import codecs import re -from typing import Tuple, Optional +from typing import Any, Tuple, Optional _unicode_dots_re = re.compile('[\u002e\u3002\uff0e\uff61]') @@ -26,24 +26,24 @@ def decode(self, data: bytes, errors: str = 'strict') -> Tuple[str, int]: return decode(data), len(data) class IncrementalEncoder(codecs.BufferedIncrementalEncoder): - def _buffer_encode(self, data: str, errors: str, final: bool) -> Tuple[str, int]: # type: ignore + 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 "", 0 + return b'', 0 labels = _unicode_dots_re.split(data) - trailing_dot = '' + trailing_dot = b'' if labels: if not labels[-1]: - trailing_dot = '.' + trailing_dot = b'.' del labels[-1] elif not final: # Keep potentially unfinished label until the next call del labels[-1] if labels: - trailing_dot = '.' + trailing_dot = b'.' result = [] size = 0 @@ -54,18 +54,21 @@ def _buffer_encode(self, data: str, errors: str, final: bool) -> Tuple[str, int] size += len(label) # Join with U+002E - result_str = '.'.join(result) + trailing_dot # type: ignore + result_bytes = b'.'.join(result) + trailing_dot size += len(trailing_dot) - return result_str, size + return result_bytes, size class IncrementalDecoder(codecs.BufferedIncrementalDecoder): - def _buffer_decode(self, data: str, errors: str, final: bool) -> Tuple[str, int]: # type: ignore + 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: @@ -99,14 +102,17 @@ class StreamReader(Codec, codecs.StreamReader): pass -def getregentry() -> codecs.CodecInfo: - # Compatibility as a search_function for codecs.register() +def search_function(name: str) -> Optional[codecs.CodecInfo]: + if name != 'idna2008': + return None return codecs.CodecInfo( - name='idna', - encode=Codec().encode, # type: ignore - decode=Codec().decode, # type: ignore + name=name, + encode=Codec().encode, + decode=Codec().decode, incrementalencoder=IncrementalEncoder, incrementaldecoder=IncrementalDecoder, streamwriter=StreamWriter, streamreader=StreamReader, ) + +codecs.register(search_function) diff --git a/myenv/Lib/site-packages/pip/_vendor/idna/core.py b/myenv/Lib/site-packages/pip/_vendor/idna/core.py index 4f30037..0dae61a 100644 --- a/myenv/Lib/site-packages/pip/_vendor/idna/core.py +++ b/myenv/Lib/site-packages/pip/_vendor/idna/core.py @@ -150,9 +150,11 @@ def valid_contextj(label: str, pos: int) -> bool: joining_type = idnadata.joining_types.get(ord(label[i])) if joining_type == ord('T'): continue - if joining_type in [ord('L'), ord('D')]: + elif joining_type in [ord('L'), ord('D')]: ok = True break + else: + break if not ok: return False @@ -162,9 +164,11 @@ def valid_contextj(label: str, pos: int) -> bool: joining_type = idnadata.joining_types.get(ord(label[i])) if joining_type == ord('T'): continue - if joining_type in [ord('R'), ord('D')]: + elif joining_type in [ord('R'), ord('D')]: ok = True break + else: + break return ok if cp_value == 0x200d: @@ -236,12 +240,8 @@ def check_label(label: Union[str, bytes, bytearray]) -> None: 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( + if not valid_contextj(label, pos): + raise InvalidCodepointContext('Joiner {} not allowed 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): @@ -262,13 +262,8 @@ def alabel(label: str) -> bytes: except UnicodeEncodeError: pass - if not label: - raise IDNAError('No Input') - - label = str(label) check_label(label) - label_bytes = _punycode(label) - label_bytes = _alabel_prefix + label_bytes + label_bytes = _alabel_prefix + _punycode(label) if not valid_label_length(label_bytes): raise IDNAError('Label too long') @@ -318,7 +313,7 @@ def uts46_remap(domain: str, std3_rules: bool = True, transitional: bool = False status = uts46row[1] replacement = None # type: Optional[str] if len(uts46row) == 3: - replacement = uts46row[2] # type: ignore + replacement = uts46row[2] if (status == 'V' or (status == 'D' and not transitional) or (status == '3' and not std3_rules and replacement is None)): @@ -338,9 +333,9 @@ def uts46_remap(domain: str, std3_rules: bool = True, transitional: bool = False def encode(s: Union[str, bytes, bytearray], strict: bool = False, uts46: bool = False, std3_rules: bool = False, transitional: bool = False) -> bytes: - if isinstance(s, (bytes, bytearray)): + if not isinstance(s, str): try: - s = s.decode('ascii') + s = str(s, 'ascii') except UnicodeDecodeError: raise IDNAError('should pass a unicode string to the function rather than a byte string.') if uts46: @@ -372,8 +367,8 @@ def encode(s: Union[str, bytes, bytearray], strict: bool = False, uts46: bool = def decode(s: Union[str, bytes, bytearray], strict: bool = False, uts46: bool = False, std3_rules: bool = False) -> str: try: - if isinstance(s, (bytes, bytearray)): - s = s.decode('ascii') + if not isinstance(s, str): + s = str(s, 'ascii') except UnicodeDecodeError: raise IDNAError('Invalid ASCII in A-label') if uts46: diff --git a/myenv/Lib/site-packages/pip/_vendor/idna/idnadata.py b/myenv/Lib/site-packages/pip/_vendor/idna/idnadata.py index 67db462..c61dcf9 100644 --- a/myenv/Lib/site-packages/pip/_vendor/idna/idnadata.py +++ b/myenv/Lib/site-packages/pip/_vendor/idna/idnadata.py @@ -1,6 +1,6 @@ # This file is automatically generated by tools/idna-data -__version__ = '15.0.0' +__version__ = '15.1.0' scripts = { 'Greek': ( 0x37000000374, @@ -59,6 +59,7 @@ 0x2b7400002b81e, 0x2b8200002cea2, 0x2ceb00002ebe1, + 0x2ebf00002ee5e, 0x2f8000002fa1e, 0x300000003134b, 0x31350000323b0, @@ -100,16 +101,190 @@ ), } joining_types = { - 0x600: 85, - 0x601: 85, - 0x602: 85, - 0x603: 85, - 0x604: 85, - 0x605: 85, - 0x608: 85, - 0x60b: 85, + 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, - 0x621: 85, 0x622: 82, 0x623: 82, 0x624: 82, @@ -151,12 +326,33 @@ 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, - 0x674: 85, 0x675: 82, 0x676: 82, 0x677: 82, @@ -253,7 +449,25 @@ 0x6d2: 82, 0x6d3: 82, 0x6d5: 82, - 0x6dd: 85, + 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, @@ -262,6 +476,7 @@ 0x6ff: 68, 0x70f: 84, 0x710: 82, + 0x711: 84, 0x712: 68, 0x713: 68, 0x714: 68, @@ -292,6 +507,33 @@ 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, @@ -343,6 +585,17 @@ 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, @@ -376,7 +629,38 @@ 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, @@ -402,13 +686,14 @@ 0x856: 82, 0x857: 82, 0x858: 82, + 0x859: 84, + 0x85a: 84, + 0x85b: 84, 0x860: 68, - 0x861: 85, 0x862: 68, 0x863: 68, 0x864: 68, 0x865: 68, - 0x866: 85, 0x867: 82, 0x868: 68, 0x869: 82, @@ -436,16 +721,20 @@ 0x884: 67, 0x885: 67, 0x886: 68, - 0x887: 85, - 0x888: 85, 0x889: 68, 0x88a: 68, 0x88b: 68, 0x88c: 68, 0x88d: 68, 0x88e: 82, - 0x890: 85, - 0x891: 85, + 0x898: 84, + 0x899: 84, + 0x89a: 84, + 0x89b: 84, + 0x89c: 84, + 0x89d: 84, + 0x89e: 84, + 0x89f: 84, 0x8a0: 68, 0x8a1: 68, 0x8a2: 68, @@ -459,7 +748,6 @@ 0x8aa: 82, 0x8ab: 82, 0x8ac: 82, - 0x8ad: 85, 0x8ae: 82, 0x8af: 68, 0x8b0: 68, @@ -487,11 +775,357 @@ 0x8c6: 68, 0x8c7: 68, 0x8c8: 68, - 0x8e2: 85, - 0x1806: 85, + 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, - 0x180e: 85, + 0x180b: 84, + 0x180c: 84, + 0x180d: 84, + 0x180f: 84, 0x1820: 68, 0x1821: 68, 0x1822: 68, @@ -581,11 +1215,6 @@ 0x1876: 68, 0x1877: 68, 0x1878: 68, - 0x1880: 85, - 0x1881: 85, - 0x1882: 85, - 0x1883: 85, - 0x1884: 85, 0x1885: 84, 0x1886: 84, 0x1887: 68, @@ -622,14 +1251,339 @@ 0x18a6: 68, 0x18a7: 68, 0x18a8: 68, + 0x18a9: 84, 0x18aa: 68, - 0x200c: 85, + 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, - 0x202f: 85, - 0x2066: 85, - 0x2067: 85, - 0x2068: 85, - 0x2069: 85, + 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, @@ -681,20 +1635,151 @@ 0xa870: 68, 0xa871: 68, 0xa872: 76, - 0xa873: 85, + 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, - 0x10ac6: 85, 0x10ac7: 82, - 0x10ac8: 85, 0x10ac9: 82, 0x10aca: 82, - 0x10acb: 85, - 0x10acc: 85, 0x10acd: 76, 0x10ace: 82, 0x10acf: 82, @@ -716,9 +1801,9 @@ 0x10adf: 68, 0x10ae0: 68, 0x10ae1: 82, - 0x10ae2: 85, - 0x10ae3: 85, 0x10ae4: 82, + 0x10ae5: 84, + 0x10ae6: 84, 0x10aeb: 68, 0x10aec: 68, 0x10aed: 68, @@ -748,7 +1833,6 @@ 0x10bac: 82, 0x10bad: 68, 0x10bae: 68, - 0x10baf: 85, 0x10d00: 76, 0x10d01: 68, 0x10d02: 68, @@ -785,6 +1869,15 @@ 0x10d21: 68, 0x10d22: 82, 0x10d23: 68, + 0x10d24: 84, + 0x10d25: 84, + 0x10d26: 84, + 0x10d27: 84, + 0x10eab: 84, + 0x10eac: 84, + 0x10efd: 84, + 0x10efe: 84, + 0x10eff: 84, 0x10f30: 68, 0x10f31: 68, 0x10f32: 68, @@ -806,7 +1899,17 @@ 0x10f42: 68, 0x10f43: 68, 0x10f44: 68, - 0x10f45: 85, + 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, @@ -829,14 +1932,16 @@ 0x10f7f: 68, 0x10f80: 68, 0x10f81: 68, + 0x10f82: 84, + 0x10f83: 84, + 0x10f84: 84, + 0x10f85: 84, 0x10fb0: 68, - 0x10fb1: 85, 0x10fb2: 68, 0x10fb3: 68, 0x10fb4: 82, 0x10fb5: 82, 0x10fb6: 82, - 0x10fb7: 85, 0x10fb8: 68, 0x10fb9: 82, 0x10fba: 82, @@ -845,20 +1950,668 @@ 0x10fbd: 82, 0x10fbe: 68, 0x10fbf: 68, - 0x10fc0: 85, 0x10fc1: 68, 0x10fc2: 82, 0x10fc3: 82, 0x10fc4: 68, - 0x10fc5: 85, - 0x10fc6: 85, - 0x10fc7: 85, - 0x10fc8: 85, 0x10fc9: 82, 0x10fca: 68, 0x10fcb: 76, - 0x110bd: 85, - 0x110cd: 85, + 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, + 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, + 0x1171e: 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, + 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, + 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, + 0x1e8d0: 84, + 0x1e8d1: 84, + 0x1e8d2: 84, + 0x1e8d3: 84, + 0x1e8d4: 84, + 0x1e8d5: 84, + 0x1e8d6: 84, 0x1e900: 68, 0x1e901: 68, 0x1e902: 68, @@ -927,7 +2680,351 @@ 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': ( @@ -1834,7 +3931,6 @@ 0xa7d50000a7d6, 0xa7d70000a7d8, 0xa7d90000a7da, - 0xa7f20000a7f5, 0xa7f60000a7f8, 0xa7fa0000a828, 0xa82c0000a82d, @@ -1907,9 +4003,7 @@ 0x1060000010737, 0x1074000010756, 0x1076000010768, - 0x1078000010786, - 0x10787000107b1, - 0x107b2000107bb, + 0x1078000010781, 0x1080000010806, 0x1080800010809, 0x1080a00010836, @@ -2112,7 +4206,6 @@ 0x1e01b0001e022, 0x1e0230001e025, 0x1e0260001e02b, - 0x1e0300001e06e, 0x1e08f0001e090, 0x1e1000001e12d, 0x1e1300001e13e, @@ -2134,6 +4227,7 @@ 0x2b7400002b81e, 0x2b8200002cea2, 0x2ceb00002ebe1, + 0x2ebf00002ee5e, 0x300000003134b, 0x31350000323b0, ), diff --git a/myenv/Lib/site-packages/pip/_vendor/idna/package_data.py b/myenv/Lib/site-packages/pip/_vendor/idna/package_data.py index 8501893..ed81113 100644 --- a/myenv/Lib/site-packages/pip/_vendor/idna/package_data.py +++ b/myenv/Lib/site-packages/pip/_vendor/idna/package_data.py @@ -1,2 +1,2 @@ -__version__ = '3.4' +__version__ = '3.7' diff --git a/myenv/Lib/site-packages/pip/_vendor/idna/uts46data.py b/myenv/Lib/site-packages/pip/_vendor/idna/uts46data.py index 186796c..6a1eddb 100644 --- a/myenv/Lib/site-packages/pip/_vendor/idna/uts46data.py +++ b/myenv/Lib/site-packages/pip/_vendor/idna/uts46data.py @@ -7,7 +7,7 @@ """IDNA Mapping Table from UTS46.""" -__version__ = '15.0.0' +__version__ = '15.1.0' def _seg_0() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x0, '3'), @@ -1899,7 +1899,7 @@ def _seg_18() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1E9A, 'M', 'aʾ'), (0x1E9B, 'M', 'ṡ'), (0x1E9C, 'V'), - (0x1E9E, 'M', 'ss'), + (0x1E9E, 'M', 'ß'), (0x1E9F, 'V'), (0x1EA0, 'M', 'ạ'), (0x1EA1, 'V'), @@ -2418,10 +2418,6 @@ def _seg_23() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x222F, 'M', '∮∮'), (0x2230, 'M', '∮∮∮'), (0x2231, 'V'), - (0x2260, '3'), - (0x2261, 'V'), - (0x226E, '3'), - (0x2270, 'V'), (0x2329, 'M', '〈'), (0x232A, 'M', '〉'), (0x232B, 'V'), @@ -2502,14 +2498,14 @@ def _seg_23() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x24BA, 'M', 'e'), (0x24BB, 'M', 'f'), (0x24BC, 'M', 'g'), - ] - -def _seg_24() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x24BD, 'M', 'h'), (0x24BE, 'M', 'i'), (0x24BF, 'M', 'j'), (0x24C0, 'M', 'k'), + ] + +def _seg_24() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x24C1, 'M', 'l'), (0x24C2, 'M', 'm'), (0x24C3, 'M', 'n'), @@ -2606,14 +2602,14 @@ def _seg_24() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x2C26, 'M', 'ⱖ'), (0x2C27, 'M', 'ⱗ'), (0x2C28, 'M', 'ⱘ'), - ] - -def _seg_25() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x2C29, 'M', 'ⱙ'), (0x2C2A, 'M', 'ⱚ'), (0x2C2B, 'M', 'ⱛ'), (0x2C2C, 'M', 'ⱜ'), + ] + +def _seg_25() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2C2D, 'M', 'ⱝ'), (0x2C2E, 'M', 'ⱞ'), (0x2C2F, 'M', 'ⱟ'), @@ -2710,14 +2706,14 @@ def _seg_25() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x2CC0, 'M', 'ⳁ'), (0x2CC1, 'V'), (0x2CC2, 'M', 'ⳃ'), - ] - -def _seg_26() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x2CC3, 'V'), (0x2CC4, 'M', 'ⳅ'), (0x2CC5, 'V'), (0x2CC6, 'M', 'ⳇ'), + ] + +def _seg_26() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2CC7, 'V'), (0x2CC8, 'M', 'ⳉ'), (0x2CC9, 'V'), @@ -2814,14 +2810,14 @@ def _seg_26() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x2F13, 'M', '勹'), (0x2F14, 'M', '匕'), (0x2F15, 'M', '匚'), - ] - -def _seg_27() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x2F16, 'M', '匸'), (0x2F17, 'M', '十'), (0x2F18, 'M', '卜'), (0x2F19, 'M', '卩'), + ] + +def _seg_27() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2F1A, 'M', '厂'), (0x2F1B, 'M', '厶'), (0x2F1C, 'M', '又'), @@ -2918,14 +2914,14 @@ def _seg_27() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x2F77, 'M', '糸'), (0x2F78, 'M', '缶'), (0x2F79, 'M', '网'), - ] - -def _seg_28() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x2F7A, 'M', '羊'), (0x2F7B, 'M', '羽'), (0x2F7C, 'M', '老'), (0x2F7D, 'M', '而'), + ] + +def _seg_28() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2F7E, 'M', '耒'), (0x2F7F, 'M', '耳'), (0x2F80, 'M', '聿'), @@ -3022,14 +3018,14 @@ def _seg_28() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x3036, 'M', '〒'), (0x3037, 'V'), (0x3038, 'M', '十'), - ] - -def _seg_29() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x3039, 'M', '卄'), (0x303A, 'M', '卅'), (0x303B, 'V'), (0x3040, 'X'), + ] + +def _seg_29() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x3041, 'V'), (0x3097, 'X'), (0x3099, 'V'), @@ -3126,14 +3122,14 @@ def _seg_29() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x3182, 'M', 'ᇱ'), (0x3183, 'M', 'ᇲ'), (0x3184, 'M', 'ᅗ'), - ] - -def _seg_30() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x3185, 'M', 'ᅘ'), (0x3186, 'M', 'ᅙ'), (0x3187, 'M', 'ᆄ'), (0x3188, 'M', 'ᆅ'), + ] + +def _seg_30() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x3189, 'M', 'ᆈ'), (0x318A, 'M', 'ᆑ'), (0x318B, 'M', 'ᆒ'), @@ -3230,14 +3226,14 @@ def _seg_30() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x3244, 'M', '問'), (0x3245, 'M', '幼'), (0x3246, 'M', '文'), - ] - -def _seg_31() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x3247, 'M', '箏'), (0x3248, 'V'), (0x3250, 'M', 'pte'), (0x3251, 'M', '21'), + ] + +def _seg_31() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x3252, 'M', '22'), (0x3253, 'M', '23'), (0x3254, 'M', '24'), @@ -3334,14 +3330,14 @@ def _seg_31() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x32AF, 'M', '協'), (0x32B0, 'M', '夜'), (0x32B1, 'M', '36'), - ] - -def _seg_32() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x32B2, 'M', '37'), (0x32B3, 'M', '38'), (0x32B4, 'M', '39'), (0x32B5, 'M', '40'), + ] + +def _seg_32() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x32B6, 'M', '41'), (0x32B7, 'M', '42'), (0x32B8, 'M', '43'), @@ -3438,14 +3434,14 @@ def _seg_32() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x3313, 'M', 'ギルダー'), (0x3314, 'M', 'キロ'), (0x3315, 'M', 'キログラム'), - ] - -def _seg_33() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x3316, 'M', 'キロメートル'), (0x3317, 'M', 'キロワット'), (0x3318, 'M', 'グラム'), (0x3319, 'M', 'グラムトン'), + ] + +def _seg_33() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x331A, 'M', 'クルゼイロ'), (0x331B, 'M', 'クローネ'), (0x331C, 'M', 'ケース'), @@ -3542,14 +3538,14 @@ def _seg_33() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x3377, 'M', 'dm'), (0x3378, 'M', 'dm2'), (0x3379, 'M', 'dm3'), - ] - -def _seg_34() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x337A, 'M', 'iu'), (0x337B, 'M', '平成'), (0x337C, 'M', '昭和'), (0x337D, 'M', '大正'), + ] + +def _seg_34() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x337E, 'M', '明治'), (0x337F, 'M', '株式会社'), (0x3380, 'M', 'pa'), @@ -3646,14 +3642,14 @@ def _seg_34() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x33DB, 'M', 'sr'), (0x33DC, 'M', 'sv'), (0x33DD, 'M', 'wb'), - ] - -def _seg_35() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x33DE, 'M', 'v∕m'), (0x33DF, 'M', 'a∕m'), (0x33E0, 'M', '1日'), (0x33E1, 'M', '2日'), + ] + +def _seg_35() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x33E2, 'M', '3日'), (0x33E3, 'M', '4日'), (0x33E4, 'M', '5日'), @@ -3750,14 +3746,14 @@ def _seg_35() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xA68B, 'V'), (0xA68C, 'M', 'ꚍ'), (0xA68D, 'V'), - ] - -def _seg_36() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xA68E, 'M', 'ꚏ'), (0xA68F, 'V'), (0xA690, 'M', 'ꚑ'), (0xA691, 'V'), + ] + +def _seg_36() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xA692, 'M', 'ꚓ'), (0xA693, 'V'), (0xA694, 'M', 'ꚕ'), @@ -3854,14 +3850,14 @@ def _seg_36() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xA779, 'M', 'ꝺ'), (0xA77A, 'V'), (0xA77B, 'M', 'ꝼ'), - ] - -def _seg_37() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xA77C, 'V'), (0xA77D, 'M', 'ᵹ'), (0xA77E, 'M', 'ꝿ'), (0xA77F, 'V'), + ] + +def _seg_37() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xA780, 'M', 'ꞁ'), (0xA781, 'V'), (0xA782, 'M', 'ꞃ'), @@ -3958,14 +3954,14 @@ def _seg_37() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xA878, 'X'), (0xA880, 'V'), (0xA8C6, 'X'), - ] - -def _seg_38() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xA8CE, 'V'), (0xA8DA, 'X'), (0xA8E0, 'V'), (0xA954, 'X'), + ] + +def _seg_38() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xA95F, 'V'), (0xA97D, 'X'), (0xA980, 'V'), @@ -4062,14 +4058,14 @@ def _seg_38() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xABA8, 'M', 'Ꮨ'), (0xABA9, 'M', 'Ꮩ'), (0xABAA, 'M', 'Ꮪ'), - ] - -def _seg_39() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xABAB, 'M', 'Ꮫ'), (0xABAC, 'M', 'Ꮬ'), (0xABAD, 'M', 'Ꮭ'), (0xABAE, 'M', 'Ꮮ'), + ] + +def _seg_39() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xABAF, 'M', 'Ꮯ'), (0xABB0, 'M', 'Ꮰ'), (0xABB1, 'M', 'Ꮱ'), @@ -4166,14 +4162,14 @@ def _seg_39() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xF943, 'M', '弄'), (0xF944, 'M', '籠'), (0xF945, 'M', '聾'), - ] - -def _seg_40() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xF946, 'M', '牢'), (0xF947, 'M', '磊'), (0xF948, 'M', '賂'), (0xF949, 'M', '雷'), + ] + +def _seg_40() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xF94A, 'M', '壘'), (0xF94B, 'M', '屢'), (0xF94C, 'M', '樓'), @@ -4270,14 +4266,14 @@ def _seg_40() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xF9A7, 'M', '獵'), (0xF9A8, 'M', '令'), (0xF9A9, 'M', '囹'), - ] - -def _seg_41() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xF9AA, 'M', '寧'), (0xF9AB, 'M', '嶺'), (0xF9AC, 'M', '怜'), (0xF9AD, 'M', '玲'), + ] + +def _seg_41() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xF9AE, 'M', '瑩'), (0xF9AF, 'M', '羚'), (0xF9B0, 'M', '聆'), @@ -4374,14 +4370,14 @@ def _seg_41() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFA0B, 'M', '廓'), (0xFA0C, 'M', '兀'), (0xFA0D, 'M', '嗀'), - ] - -def _seg_42() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFA0E, 'V'), (0xFA10, 'M', '塚'), (0xFA11, 'V'), (0xFA12, 'M', '晴'), + ] + +def _seg_42() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFA13, 'V'), (0xFA15, 'M', '凞'), (0xFA16, 'M', '猪'), @@ -4478,14 +4474,14 @@ def _seg_42() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFA76, 'M', '勇'), (0xFA77, 'M', '勺'), (0xFA78, 'M', '喝'), - ] - -def _seg_43() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFA79, 'M', '啕'), (0xFA7A, 'M', '喙'), (0xFA7B, 'M', '嗢'), (0xFA7C, 'M', '塚'), + ] + +def _seg_43() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFA7D, 'M', '墳'), (0xFA7E, 'M', '奄'), (0xFA7F, 'M', '奔'), @@ -4582,14 +4578,14 @@ def _seg_43() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFADA, 'X'), (0xFB00, 'M', 'ff'), (0xFB01, 'M', 'fi'), - ] - -def _seg_44() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFB02, 'M', 'fl'), (0xFB03, 'M', 'ffi'), (0xFB04, 'M', 'ffl'), (0xFB05, 'M', 'st'), + ] + +def _seg_44() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFB07, 'X'), (0xFB13, 'M', 'մն'), (0xFB14, 'M', 'մե'), @@ -4686,14 +4682,14 @@ def _seg_44() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFBDB, 'M', 'ۈ'), (0xFBDD, 'M', 'ۇٴ'), (0xFBDE, 'M', 'ۋ'), - ] - -def _seg_45() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFBE0, 'M', 'ۅ'), (0xFBE2, 'M', 'ۉ'), (0xFBE4, 'M', 'ې'), (0xFBE8, 'M', 'ى'), + ] + +def _seg_45() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFBEA, 'M', 'ئا'), (0xFBEC, 'M', 'ئە'), (0xFBEE, 'M', 'ئو'), @@ -4790,14 +4786,14 @@ def _seg_45() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFC54, 'M', 'هي'), (0xFC55, 'M', 'يج'), (0xFC56, 'M', 'يح'), - ] - -def _seg_46() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFC57, 'M', 'يخ'), (0xFC58, 'M', 'يم'), (0xFC59, 'M', 'يى'), (0xFC5A, 'M', 'يي'), + ] + +def _seg_46() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFC5B, 'M', 'ذٰ'), (0xFC5C, 'M', 'رٰ'), (0xFC5D, 'M', 'ىٰ'), @@ -4894,14 +4890,14 @@ def _seg_46() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFCB8, 'M', 'طح'), (0xFCB9, 'M', 'ظم'), (0xFCBA, 'M', 'عج'), - ] - -def _seg_47() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFCBB, 'M', 'عم'), (0xFCBC, 'M', 'غج'), (0xFCBD, 'M', 'غم'), (0xFCBE, 'M', 'فج'), + ] + +def _seg_47() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFCBF, 'M', 'فح'), (0xFCC0, 'M', 'فخ'), (0xFCC1, 'M', 'فم'), @@ -4998,14 +4994,14 @@ def _seg_47() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFD1C, 'M', 'حي'), (0xFD1D, 'M', 'جى'), (0xFD1E, 'M', 'جي'), - ] - -def _seg_48() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFD1F, 'M', 'خى'), (0xFD20, 'M', 'خي'), (0xFD21, 'M', 'صى'), (0xFD22, 'M', 'صي'), + ] + +def _seg_48() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFD23, 'M', 'ضى'), (0xFD24, 'M', 'ضي'), (0xFD25, 'M', 'شج'), @@ -5102,14 +5098,14 @@ def _seg_48() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFDA4, 'M', 'تمى'), (0xFDA5, 'M', 'جمي'), (0xFDA6, 'M', 'جحى'), - ] - -def _seg_49() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFDA7, 'M', 'جمى'), (0xFDA8, 'M', 'سخى'), (0xFDA9, 'M', 'صحي'), (0xFDAA, 'M', 'شحي'), + ] + +def _seg_49() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFDAB, 'M', 'ضحي'), (0xFDAC, 'M', 'لجي'), (0xFDAD, 'M', 'لمي'), @@ -5206,14 +5202,14 @@ def _seg_49() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFE5B, '3', '{'), (0xFE5C, '3', '}'), (0xFE5D, 'M', '〔'), - ] - -def _seg_50() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFE5E, 'M', '〕'), (0xFE5F, '3', '#'), (0xFE60, '3', '&'), (0xFE61, '3', '*'), + ] + +def _seg_50() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFE62, '3', '+'), (0xFE63, 'M', '-'), (0xFE64, '3', '<'), @@ -5310,14 +5306,14 @@ def _seg_50() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFF18, 'M', '8'), (0xFF19, 'M', '9'), (0xFF1A, '3', ':'), - ] - -def _seg_51() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFF1B, '3', ';'), (0xFF1C, '3', '<'), (0xFF1D, '3', '='), (0xFF1E, '3', '>'), + ] + +def _seg_51() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFF1F, '3', '?'), (0xFF20, '3', '@'), (0xFF21, 'M', 'a'), @@ -5414,14 +5410,14 @@ def _seg_51() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFF7C, 'M', 'シ'), (0xFF7D, 'M', 'ス'), (0xFF7E, 'M', 'セ'), - ] - -def _seg_52() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFF7F, 'M', 'ソ'), (0xFF80, 'M', 'タ'), (0xFF81, 'M', 'チ'), (0xFF82, 'M', 'ツ'), + ] + +def _seg_52() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFF83, 'M', 'テ'), (0xFF84, 'M', 'ト'), (0xFF85, 'M', 'ナ'), @@ -5518,14 +5514,14 @@ def _seg_52() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0xFFE7, 'X'), (0xFFE8, 'M', '│'), (0xFFE9, 'M', '←'), - ] - -def _seg_53() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0xFFEA, 'M', '↑'), (0xFFEB, 'M', '→'), (0xFFEC, 'M', '↓'), (0xFFED, 'M', '■'), + ] + +def _seg_53() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFFEE, 'M', '○'), (0xFFEF, 'X'), (0x10000, 'V'), @@ -5622,14 +5618,14 @@ def _seg_53() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x104B3, 'M', '𐓛'), (0x104B4, 'M', '𐓜'), (0x104B5, 'M', '𐓝'), - ] - -def _seg_54() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x104B6, 'M', '𐓞'), (0x104B7, 'M', '𐓟'), (0x104B8, 'M', '𐓠'), (0x104B9, 'M', '𐓡'), + ] + +def _seg_54() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x104BA, 'M', '𐓢'), (0x104BB, 'M', '𐓣'), (0x104BC, 'M', '𐓤'), @@ -5726,14 +5722,14 @@ def _seg_54() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x10786, 'X'), (0x10787, 'M', 'ʣ'), (0x10788, 'M', 'ꭦ'), - ] - -def _seg_55() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x10789, 'M', 'ʥ'), (0x1078A, 'M', 'ʤ'), (0x1078B, 'M', 'ɖ'), (0x1078C, 'M', 'ɗ'), + ] + +def _seg_55() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1078D, 'M', 'ᶑ'), (0x1078E, 'M', 'ɘ'), (0x1078F, 'M', 'ɞ'), @@ -5830,14 +5826,14 @@ def _seg_55() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x10A60, 'V'), (0x10AA0, 'X'), (0x10AC0, 'V'), - ] - -def _seg_56() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x10AE7, 'X'), (0x10AEB, 'V'), (0x10AF7, 'X'), (0x10B00, 'V'), + ] + +def _seg_56() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x10B36, 'X'), (0x10B39, 'V'), (0x10B56, 'X'), @@ -5934,14 +5930,14 @@ def _seg_56() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1107F, 'V'), (0x110BD, 'X'), (0x110BE, 'V'), - ] - -def _seg_57() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x110C3, 'X'), (0x110D0, 'V'), (0x110E9, 'X'), (0x110F0, 'V'), + ] + +def _seg_57() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x110FA, 'X'), (0x11100, 'V'), (0x11135, 'X'), @@ -6038,14 +6034,14 @@ def _seg_57() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x118A4, 'M', '𑣄'), (0x118A5, 'M', '𑣅'), (0x118A6, 'M', '𑣆'), - ] - -def _seg_58() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x118A7, 'M', '𑣇'), (0x118A8, 'M', '𑣈'), (0x118A9, 'M', '𑣉'), (0x118AA, 'M', '𑣊'), + ] + +def _seg_58() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x118AB, 'M', '𑣋'), (0x118AC, 'M', '𑣌'), (0x118AD, 'M', '𑣍'), @@ -6142,14 +6138,14 @@ def _seg_58() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x11EE0, 'V'), (0x11EF9, 'X'), (0x11F00, 'V'), - ] - -def _seg_59() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x11F11, 'X'), (0x11F12, 'V'), (0x11F3B, 'X'), (0x11F3E, 'V'), + ] + +def _seg_59() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x11F5A, 'X'), (0x11FB0, 'V'), (0x11FB1, 'X'), @@ -6246,14 +6242,14 @@ def _seg_59() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x18D00, 'V'), (0x18D09, 'X'), (0x1AFF0, 'V'), - ] - -def _seg_60() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1AFF4, 'X'), (0x1AFF5, 'V'), (0x1AFFC, 'X'), (0x1AFFD, 'V'), + ] + +def _seg_60() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1AFFF, 'X'), (0x1B000, 'V'), (0x1B123, 'X'), @@ -6350,14 +6346,14 @@ def _seg_60() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1D41E, 'M', 'e'), (0x1D41F, 'M', 'f'), (0x1D420, 'M', 'g'), - ] - -def _seg_61() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1D421, 'M', 'h'), (0x1D422, 'M', 'i'), (0x1D423, 'M', 'j'), (0x1D424, 'M', 'k'), + ] + +def _seg_61() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D425, 'M', 'l'), (0x1D426, 'M', 'm'), (0x1D427, 'M', 'n'), @@ -6454,14 +6450,14 @@ def _seg_61() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1D482, 'M', 'a'), (0x1D483, 'M', 'b'), (0x1D484, 'M', 'c'), - ] - -def _seg_62() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1D485, 'M', 'd'), (0x1D486, 'M', 'e'), (0x1D487, 'M', 'f'), (0x1D488, 'M', 'g'), + ] + +def _seg_62() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D489, 'M', 'h'), (0x1D48A, 'M', 'i'), (0x1D48B, 'M', 'j'), @@ -6558,14 +6554,14 @@ def _seg_62() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1D4E9, 'M', 'z'), (0x1D4EA, 'M', 'a'), (0x1D4EB, 'M', 'b'), - ] - -def _seg_63() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1D4EC, 'M', 'c'), (0x1D4ED, 'M', 'd'), (0x1D4EE, 'M', 'e'), (0x1D4EF, 'M', 'f'), + ] + +def _seg_63() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D4F0, 'M', 'g'), (0x1D4F1, 'M', 'h'), (0x1D4F2, 'M', 'i'), @@ -6662,14 +6658,14 @@ def _seg_63() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1D550, 'M', 'y'), (0x1D551, 'X'), (0x1D552, 'M', 'a'), - ] - -def _seg_64() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1D553, 'M', 'b'), (0x1D554, 'M', 'c'), (0x1D555, 'M', 'd'), (0x1D556, 'M', 'e'), + ] + +def _seg_64() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D557, 'M', 'f'), (0x1D558, 'M', 'g'), (0x1D559, 'M', 'h'), @@ -6766,14 +6762,14 @@ def _seg_64() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1D5B4, 'M', 'u'), (0x1D5B5, 'M', 'v'), (0x1D5B6, 'M', 'w'), - ] - -def _seg_65() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1D5B7, 'M', 'x'), (0x1D5B8, 'M', 'y'), (0x1D5B9, 'M', 'z'), (0x1D5BA, 'M', 'a'), + ] + +def _seg_65() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D5BB, 'M', 'b'), (0x1D5BC, 'M', 'c'), (0x1D5BD, 'M', 'd'), @@ -6870,14 +6866,14 @@ def _seg_65() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1D618, 'M', 'q'), (0x1D619, 'M', 'r'), (0x1D61A, 'M', 's'), - ] - -def _seg_66() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1D61B, 'M', 't'), (0x1D61C, 'M', 'u'), (0x1D61D, 'M', 'v'), (0x1D61E, 'M', 'w'), + ] + +def _seg_66() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D61F, 'M', 'x'), (0x1D620, 'M', 'y'), (0x1D621, 'M', 'z'), @@ -6974,14 +6970,14 @@ def _seg_66() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1D67C, 'M', 'm'), (0x1D67D, 'M', 'n'), (0x1D67E, 'M', 'o'), - ] - -def _seg_67() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1D67F, 'M', 'p'), (0x1D680, 'M', 'q'), (0x1D681, 'M', 'r'), (0x1D682, 'M', 's'), + ] + +def _seg_67() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D683, 'M', 't'), (0x1D684, 'M', 'u'), (0x1D685, 'M', 'v'), @@ -7078,14 +7074,14 @@ def _seg_67() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1D6E2, 'M', 'α'), (0x1D6E3, 'M', 'β'), (0x1D6E4, 'M', 'γ'), - ] - -def _seg_68() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1D6E5, 'M', 'δ'), (0x1D6E6, 'M', 'ε'), (0x1D6E7, 'M', 'ζ'), (0x1D6E8, 'M', 'η'), + ] + +def _seg_68() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D6E9, 'M', 'θ'), (0x1D6EA, 'M', 'ι'), (0x1D6EB, 'M', 'κ'), @@ -7182,14 +7178,14 @@ def _seg_68() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1D747, 'M', 'σ'), (0x1D749, 'M', 'τ'), (0x1D74A, 'M', 'υ'), - ] - -def _seg_69() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1D74B, 'M', 'φ'), (0x1D74C, 'M', 'χ'), (0x1D74D, 'M', 'ψ'), (0x1D74E, 'M', 'ω'), + ] + +def _seg_69() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D74F, 'M', '∂'), (0x1D750, 'M', 'ε'), (0x1D751, 'M', 'θ'), @@ -7286,14 +7282,14 @@ def _seg_69() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1D7AD, 'M', 'δ'), (0x1D7AE, 'M', 'ε'), (0x1D7AF, 'M', 'ζ'), - ] - -def _seg_70() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1D7B0, 'M', 'η'), (0x1D7B1, 'M', 'θ'), (0x1D7B2, 'M', 'ι'), (0x1D7B3, 'M', 'κ'), + ] + +def _seg_70() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D7B4, 'M', 'λ'), (0x1D7B5, 'M', 'μ'), (0x1D7B6, 'M', 'ν'), @@ -7390,14 +7386,14 @@ def _seg_70() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1E030, 'M', 'а'), (0x1E031, 'M', 'б'), (0x1E032, 'M', 'в'), - ] - -def _seg_71() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1E033, 'M', 'г'), (0x1E034, 'M', 'д'), (0x1E035, 'M', 'е'), (0x1E036, 'M', 'ж'), + ] + +def _seg_71() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1E037, 'M', 'з'), (0x1E038, 'M', 'и'), (0x1E039, 'M', 'к'), @@ -7494,14 +7490,14 @@ def _seg_71() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1E907, 'M', '𞤩'), (0x1E908, 'M', '𞤪'), (0x1E909, 'M', '𞤫'), - ] - -def _seg_72() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1E90A, 'M', '𞤬'), (0x1E90B, 'M', '𞤭'), (0x1E90C, 'M', '𞤮'), (0x1E90D, 'M', '𞤯'), + ] + +def _seg_72() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1E90E, 'M', '𞤰'), (0x1E90F, 'M', '𞤱'), (0x1E910, 'M', '𞤲'), @@ -7598,14 +7594,14 @@ def _seg_72() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1EE48, 'X'), (0x1EE49, 'M', 'ي'), (0x1EE4A, 'X'), - ] - -def _seg_73() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1EE4B, 'M', 'ل'), (0x1EE4C, 'X'), (0x1EE4D, 'M', 'ن'), (0x1EE4E, 'M', 'س'), + ] + +def _seg_73() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1EE4F, 'M', 'ع'), (0x1EE50, 'X'), (0x1EE51, 'M', 'ص'), @@ -7702,14 +7698,14 @@ def _seg_73() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1EEB2, 'M', 'ق'), (0x1EEB3, 'M', 'ر'), (0x1EEB4, 'M', 'ش'), - ] - -def _seg_74() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1EEB5, 'M', 'ت'), (0x1EEB6, 'M', 'ث'), (0x1EEB7, 'M', 'خ'), (0x1EEB8, 'M', 'ذ'), + ] + +def _seg_74() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1EEB9, 'M', 'ض'), (0x1EEBA, 'M', 'ظ'), (0x1EEBB, 'M', 'غ'), @@ -7806,14 +7802,14 @@ def _seg_74() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1F150, 'V'), (0x1F16A, 'M', 'mc'), (0x1F16B, 'M', 'md'), - ] - -def _seg_75() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1F16C, 'M', 'mr'), (0x1F16D, 'V'), (0x1F190, 'M', 'dj'), (0x1F191, 'V'), + ] + +def _seg_75() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1F1AE, 'X'), (0x1F1E6, 'V'), (0x1F200, 'M', 'ほか'), @@ -7910,14 +7906,14 @@ def _seg_75() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x1FA54, 'X'), (0x1FA60, 'V'), (0x1FA6E, 'X'), - ] - -def _seg_76() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ (0x1FA70, 'V'), (0x1FA7D, 'X'), (0x1FA80, 'V'), (0x1FA89, 'X'), + ] + +def _seg_76() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1FA90, 'V'), (0x1FABE, 'X'), (0x1FABF, 'V'), @@ -7953,6 +7949,8 @@ def _seg_76() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x2CEA2, 'X'), (0x2CEB0, 'V'), (0x2EBE1, 'X'), + (0x2EBF0, 'V'), + (0x2EE5E, 'X'), (0x2F800, 'M', '丽'), (0x2F801, 'M', '丸'), (0x2F802, 'M', '乁'), @@ -8014,12 +8012,12 @@ def _seg_76() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x2F83C, 'M', '咞'), (0x2F83D, 'M', '吸'), (0x2F83E, 'M', '呈'), + (0x2F83F, 'M', '周'), + (0x2F840, 'M', '咢'), ] def _seg_77() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ - (0x2F83F, 'M', '周'), - (0x2F840, 'M', '咢'), (0x2F841, 'M', '哶'), (0x2F842, 'M', '唐'), (0x2F843, 'M', '啓'), @@ -8118,12 +8116,12 @@ def _seg_77() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x2F8A4, 'M', '𢛔'), (0x2F8A5, 'M', '惇'), (0x2F8A6, 'M', '慈'), + (0x2F8A7, 'M', '慌'), + (0x2F8A8, 'M', '慎'), ] def _seg_78() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ - (0x2F8A7, 'M', '慌'), - (0x2F8A8, 'M', '慎'), (0x2F8A9, 'M', '慌'), (0x2F8AA, 'M', '慺'), (0x2F8AB, 'M', '憎'), @@ -8222,12 +8220,12 @@ def _seg_78() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x2F908, 'M', '港'), (0x2F909, 'M', '湮'), (0x2F90A, 'M', '㴳'), + (0x2F90B, 'M', '滋'), + (0x2F90C, 'M', '滇'), ] def _seg_79() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ - (0x2F90B, 'M', '滋'), - (0x2F90C, 'M', '滇'), (0x2F90D, 'M', '𣻑'), (0x2F90E, 'M', '淹'), (0x2F90F, 'M', '潮'), @@ -8326,12 +8324,12 @@ def _seg_79() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x2F96F, 'M', '縂'), (0x2F970, 'M', '繅'), (0x2F971, 'M', '䌴'), + (0x2F972, 'M', '𦈨'), + (0x2F973, 'M', '𦉇'), ] def _seg_80() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ - (0x2F972, 'M', '𦈨'), - (0x2F973, 'M', '𦉇'), (0x2F974, 'M', '䍙'), (0x2F975, 'M', '𦋙'), (0x2F976, 'M', '罺'), @@ -8430,12 +8428,12 @@ def _seg_80() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: (0x2F9D3, 'M', '𧲨'), (0x2F9D4, 'M', '貫'), (0x2F9D5, 'M', '賁'), + (0x2F9D6, 'M', '贛'), + (0x2F9D7, 'M', '起'), ] def _seg_81() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ - (0x2F9D6, 'M', '贛'), - (0x2F9D7, 'M', '起'), (0x2F9D8, 'M', '𧼯'), (0x2F9D9, 'M', '𠠄'), (0x2F9DA, 'M', '跋'), diff --git a/myenv/Lib/site-packages/pip/_vendor/msgpack/__init__.py b/myenv/Lib/site-packages/pip/_vendor/msgpack/__init__.py index 1300b86..919b86f 100644 --- a/myenv/Lib/site-packages/pip/_vendor/msgpack/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/msgpack/__init__.py @@ -1,16 +1,14 @@ -# coding: utf-8 from .exceptions import * from .ext import ExtType, Timestamp import os -import sys -version = (1, 0, 5) -__version__ = "1.0.5" +version = (1, 0, 8) +__version__ = "1.0.8" -if os.environ.get("MSGPACK_PUREPYTHON") or sys.version_info[0] == 2: +if os.environ.get("MSGPACK_PUREPYTHON"): from .fallback import Packer, unpackb, Unpacker else: try: diff --git a/myenv/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-311.pyc index 31aedbc038d4d774649c9938c3c971d418b567b0..99929fc7f123d699322c0762d86ff476f24bdb09 100644 GIT binary patch delta 494 zcmZ8dyGjE=6rIWL&c3p460^n-2~k%x65Y{W1> zU?)bewg8!#CpX)3VkaNyE(kf0t@w-r>3i$%O-8<6NkTPV+$S40b^ z?=G;8u_=17Ys-Zemyi~#%J;GZtQh0wzY07dc?zH%11J=D8cJVlRd)|+JOey0LUj&% z;#A3sd-Y>Meo;~3Nhp!8ud?bx98Np9KxWZu@|r3dZB&{u_C$$nn@ekWz+e79OlFmlj?rzF#W7Ufu zibo;LrN`bB!IKw{Mm&m$^icMsN5MnSBI0~2UivNjzQ>#I&AjhZ>UG+BX;}tR)%ftD z=M1f4gyP}l@_E8FM`t?M8Re8kZEY(CQ&5L-In;8)LFTESvGuLc4LT=9Xkqc#b_9q> zaKz(I!Zn%cTFi2jEQygf8AqX>I;H0?B0D{WgoXc|pYpYkr|qFfq=oh{H}=bjWq4vA zu`D+g=Ik6hV_Ph5XIR0`va?)UMHNfN@cfjnvOLk}W@cv=g6zH3o6UOTZo9dDf2rA8 zyS1|X1H!&#IEt|$yOBd94cP$-(j>nZl8RL#0#*%G#WTQj3ViUEN+PdXpzm}xw!2~s zBzaxCf(vqm6ye46(X{#g}y-Jo!yR4VD!J84m`L(Ou(!>&}V4@*qHpRmk9A6 z%b)tCJLW@M_?vyNz3KJ(L9EwtoGzHcbnuEW6$J72hU-6o>w?5>cc(9QmxSnxFn<_O zOvq(=p$5ANcqZK7SL~YG=L5%H6w^w>>i2IbJRun4Z}NcF;>XB%7Jl+0E$3d%A62iu ss~=St-%oz6HojCF$MS@plYc0cM)XYq_8p~-`ZyYmr|Q#WRKp7Y0^|*fg8%>k diff --git a/myenv/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-311.pyc index 3c155bec5ebf0da9ee6654c16cfcd4410b630749..e286cfd05bfe04da1b72b7779664c56388e44a22 100644 GIT binary patch delta 19 ZcmcaEbX|yRIWI340}!~J+{oq22>>-H1jYaW delta 19 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 delta 10651 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 Bk~9DS diff --git a/myenv/Lib/site-packages/pip/_vendor/msgpack/ext.py b/myenv/Lib/site-packages/pip/_vendor/msgpack/ext.py index 23e0d6b..02c2c43 100644 --- a/myenv/Lib/site-packages/pip/_vendor/msgpack/ext.py +++ b/myenv/Lib/site-packages/pip/_vendor/msgpack/ext.py @@ -1,23 +1,8 @@ -# coding: utf-8 from collections import namedtuple import datetime -import sys import struct -PY2 = sys.version_info[0] == 2 - -if PY2: - int_types = (int, long) - _utc = None -else: - int_types = int - try: - _utc = datetime.timezone.utc - except AttributeError: - _utc = datetime.timezone(datetime.timedelta(0)) - - class ExtType(namedtuple("ExtType", "code data")): """ExtType represents ext type in msgpack.""" @@ -28,14 +13,15 @@ def __new__(cls, code, data): raise TypeError("data must be bytes") if not 0 <= code <= 127: raise ValueError("code must be 0~127") - return super(ExtType, cls).__new__(cls, code, data) + return super().__new__(cls, code, data) -class Timestamp(object): +class Timestamp: """Timestamp represents the Timestamp extension type in msgpack. - When built with Cython, msgpack uses C methods to pack and unpack `Timestamp`. When using pure-Python - msgpack, :func:`to_bytes` and :func:`from_bytes` are used to pack and unpack `Timestamp`. + When built with Cython, msgpack uses C methods to pack and unpack `Timestamp`. + When using pure-Python msgpack, :func:`to_bytes` and :func:`from_bytes` are used to pack and + unpack `Timestamp`. This class is immutable: Do not override seconds and nanoseconds. """ @@ -53,31 +39,25 @@ def __init__(self, seconds, nanoseconds=0): Number of nanoseconds to add to `seconds` to get fractional time. Maximum is 999_999_999. Default is 0. - Note: Negative times (before the UNIX epoch) are represented as negative seconds + positive ns. + Note: Negative times (before the UNIX epoch) are represented as neg. seconds + pos. ns. """ - if not isinstance(seconds, int_types): + if not isinstance(seconds, int): raise TypeError("seconds must be an integer") - if not isinstance(nanoseconds, int_types): + if not isinstance(nanoseconds, int): raise TypeError("nanoseconds must be an integer") if not (0 <= nanoseconds < 10**9): - raise ValueError( - "nanoseconds must be a non-negative integer less than 999999999." - ) + raise ValueError("nanoseconds must be a non-negative integer less than 999999999.") self.seconds = seconds self.nanoseconds = nanoseconds def __repr__(self): """String representation of Timestamp.""" - return "Timestamp(seconds={0}, nanoseconds={1})".format( - self.seconds, self.nanoseconds - ) + return f"Timestamp(seconds={self.seconds}, nanoseconds={self.nanoseconds})" def __eq__(self, other): """Check for equality with another Timestamp object""" if type(other) is self.__class__: - return ( - self.seconds == other.seconds and self.nanoseconds == other.nanoseconds - ) + return self.seconds == other.seconds and self.nanoseconds == other.nanoseconds return False def __ne__(self, other): @@ -140,7 +120,7 @@ def from_unix(unix_sec): """Create a Timestamp from posix timestamp in seconds. :param unix_float: Posix timestamp in seconds. - :type unix_float: int or float. + :type unix_float: int or float """ seconds = int(unix_sec // 1) nanoseconds = int((unix_sec % 1) * 10**9) @@ -174,20 +154,15 @@ def to_unix_nano(self): def to_datetime(self): """Get the timestamp as a UTC datetime. - Python 2 is not supported. - - :rtype: datetime. + :rtype: `datetime.datetime` """ - return datetime.datetime.fromtimestamp(0, _utc) + datetime.timedelta( - seconds=self.to_unix() - ) + utc = datetime.timezone.utc + return datetime.datetime.fromtimestamp(0, utc) + datetime.timedelta(seconds=self.to_unix()) @staticmethod def from_datetime(dt): """Create a Timestamp from datetime with tzinfo. - Python 2 is not supported. - :rtype: Timestamp """ return Timestamp.from_unix(dt.timestamp()) diff --git a/myenv/Lib/site-packages/pip/_vendor/msgpack/fallback.py b/myenv/Lib/site-packages/pip/_vendor/msgpack/fallback.py index e8cebc1..a174162 100644 --- a/myenv/Lib/site-packages/pip/_vendor/msgpack/fallback.py +++ b/myenv/Lib/site-packages/pip/_vendor/msgpack/fallback.py @@ -4,39 +4,6 @@ import struct -PY2 = sys.version_info[0] == 2 -if PY2: - int_types = (int, long) - - def dict_iteritems(d): - return d.iteritems() - -else: - int_types = int - unicode = str - xrange = range - - def dict_iteritems(d): - return d.items() - - -if sys.version_info < (3, 5): - # Ugly hack... - RecursionError = RuntimeError - - def _is_recursionerror(e): - return ( - len(e.args) == 1 - and isinstance(e.args[0], str) - and e.args[0].startswith("maximum recursion depth exceeded") - ) - -else: - - def _is_recursionerror(e): - return True - - if hasattr(sys, "pypy_version_info"): # StringIO is slow on PyPy, StringIO is faster. However: PyPy's own # StringBuilder is fastest. @@ -48,7 +15,7 @@ def _is_recursionerror(e): from __pypy__.builders import StringBuilder USING_STRINGBUILDER = True - class StringIO(object): + class StringIO: def __init__(self, s=b""): if s: self.builder = StringBuilder(len(s)) @@ -125,24 +92,13 @@ def unpackb(packed, **kwargs): ret = unpacker._unpack() except OutOfData: raise ValueError("Unpack failed: incomplete input") - except RecursionError as e: - if _is_recursionerror(e): - raise StackError - raise + except RecursionError: + raise StackError if unpacker._got_extradata(): raise ExtraData(ret, unpacker._get_extradata()) return ret -if sys.version_info < (2, 7, 6): - - def _unpack_from(f, b, o=0): - """Explicit type cast for legacy struct.unpack_from""" - return struct.unpack_from(f, bytes(b), o) - -else: - _unpack_from = struct.unpack_from - _NO_FORMAT_USED = "" _MSGPACK_HEADERS = { 0xC4: (1, _NO_FORMAT_USED, TYPE_BIN), @@ -176,14 +132,14 @@ def _unpack_from(f, b, o=0): } -class Unpacker(object): +class Unpacker: """Streaming unpacker. Arguments: :param file_like: File-like object having `.read(n)` method. - If specified, unpacker reads serialized data from it and :meth:`feed()` is not usable. + If specified, unpacker reads serialized data from it and `.feed()` is not usable. :param int read_size: Used as `file_like.read(read_size)`. (default: `min(16*1024, max_buffer_size)`) @@ -202,17 +158,17 @@ class Unpacker(object): 0 - Timestamp 1 - float (Seconds from the EPOCH) 2 - int (Nanoseconds from the EPOCH) - 3 - datetime.datetime (UTC). Python 2 is not supported. + 3 - datetime.datetime (UTC). :param bool strict_map_key: If true (default), only str or bytes are accepted for map (dict) keys. - :param callable object_hook: + :param object_hook: When specified, it should be callable. Unpacker calls it with a dict argument after unpacking msgpack map. (See also simplejson) - :param callable object_pairs_hook: + :param object_pairs_hook: When specified, it should be callable. Unpacker calls it with a list of key-value pairs after unpacking msgpack map. (See also simplejson) @@ -359,9 +315,7 @@ def __init__( if object_pairs_hook is not None and not callable(object_pairs_hook): raise TypeError("`object_pairs_hook` is not callable") if object_hook is not None and object_pairs_hook is not None: - raise TypeError( - "object_pairs_hook and object_hook are mutually " "exclusive" - ) + raise TypeError("object_pairs_hook and object_hook are mutually exclusive") if not callable(ext_hook): raise TypeError("`ext_hook` is not callable") @@ -453,20 +407,18 @@ def _read_header(self): n = b & 0b00011111 typ = TYPE_RAW if n > self._max_str_len: - raise ValueError("%s exceeds max_str_len(%s)" % (n, self._max_str_len)) + raise ValueError(f"{n} exceeds max_str_len({self._max_str_len})") obj = self._read(n) elif b & 0b11110000 == 0b10010000: n = b & 0b00001111 typ = TYPE_ARRAY if n > self._max_array_len: - raise ValueError( - "%s exceeds max_array_len(%s)" % (n, self._max_array_len) - ) + raise ValueError(f"{n} exceeds max_array_len({self._max_array_len})") elif b & 0b11110000 == 0b10000000: n = b & 0b00001111 typ = TYPE_MAP if n > self._max_map_len: - raise ValueError("%s exceeds max_map_len(%s)" % (n, self._max_map_len)) + raise ValueError(f"{n} exceeds max_map_len({self._max_map_len})") elif b == 0xC0: obj = None elif b == 0xC2: @@ -477,65 +429,61 @@ def _read_header(self): size, fmt, typ = _MSGPACK_HEADERS[b] self._reserve(size) if len(fmt) > 0: - n = _unpack_from(fmt, self._buffer, self._buff_i)[0] + n = struct.unpack_from(fmt, self._buffer, self._buff_i)[0] else: n = self._buffer[self._buff_i] self._buff_i += size if n > self._max_bin_len: - raise ValueError("%s exceeds max_bin_len(%s)" % (n, self._max_bin_len)) + raise ValueError(f"{n} exceeds max_bin_len({self._max_bin_len})") obj = self._read(n) elif 0xC7 <= b <= 0xC9: size, fmt, typ = _MSGPACK_HEADERS[b] self._reserve(size) - L, n = _unpack_from(fmt, self._buffer, self._buff_i) + L, n = struct.unpack_from(fmt, self._buffer, self._buff_i) self._buff_i += size if L > self._max_ext_len: - raise ValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len)) + raise ValueError(f"{L} exceeds max_ext_len({self._max_ext_len})") obj = self._read(L) elif 0xCA <= b <= 0xD3: size, fmt = _MSGPACK_HEADERS[b] self._reserve(size) if len(fmt) > 0: - obj = _unpack_from(fmt, self._buffer, self._buff_i)[0] + obj = struct.unpack_from(fmt, self._buffer, self._buff_i)[0] else: obj = self._buffer[self._buff_i] self._buff_i += size elif 0xD4 <= b <= 0xD8: size, fmt, typ = _MSGPACK_HEADERS[b] if self._max_ext_len < size: - raise ValueError( - "%s exceeds max_ext_len(%s)" % (size, self._max_ext_len) - ) + raise ValueError(f"{size} exceeds max_ext_len({self._max_ext_len})") self._reserve(size + 1) - n, obj = _unpack_from(fmt, self._buffer, self._buff_i) + n, obj = struct.unpack_from(fmt, self._buffer, self._buff_i) self._buff_i += size + 1 elif 0xD9 <= b <= 0xDB: size, fmt, typ = _MSGPACK_HEADERS[b] self._reserve(size) if len(fmt) > 0: - (n,) = _unpack_from(fmt, self._buffer, self._buff_i) + (n,) = struct.unpack_from(fmt, self._buffer, self._buff_i) else: n = self._buffer[self._buff_i] self._buff_i += size if n > self._max_str_len: - raise ValueError("%s exceeds max_str_len(%s)" % (n, self._max_str_len)) + raise ValueError(f"{n} exceeds max_str_len({self._max_str_len})") obj = self._read(n) elif 0xDC <= b <= 0xDD: size, fmt, typ = _MSGPACK_HEADERS[b] self._reserve(size) - (n,) = _unpack_from(fmt, self._buffer, self._buff_i) + (n,) = struct.unpack_from(fmt, self._buffer, self._buff_i) self._buff_i += size if n > self._max_array_len: - raise ValueError( - "%s exceeds max_array_len(%s)" % (n, self._max_array_len) - ) + raise ValueError(f"{n} exceeds max_array_len({self._max_array_len})") elif 0xDE <= b <= 0xDF: size, fmt, typ = _MSGPACK_HEADERS[b] self._reserve(size) - (n,) = _unpack_from(fmt, self._buffer, self._buff_i) + (n,) = struct.unpack_from(fmt, self._buffer, self._buff_i) self._buff_i += size if n > self._max_map_len: - raise ValueError("%s exceeds max_map_len(%s)" % (n, self._max_map_len)) + raise ValueError(f"{n} exceeds max_map_len({self._max_map_len})") else: raise FormatError("Unknown header: 0x%x" % b) return typ, n, obj @@ -554,12 +502,12 @@ def _unpack(self, execute=EX_CONSTRUCT): # TODO should we eliminate the recursion? if typ == TYPE_ARRAY: if execute == EX_SKIP: - for i in xrange(n): + for i in range(n): # TODO check whether we need to call `list_hook` self._unpack(EX_SKIP) return ret = newlist_hint(n) - for i in xrange(n): + for i in range(n): ret.append(self._unpack(EX_CONSTRUCT)) if self._list_hook is not None: ret = self._list_hook(ret) @@ -567,25 +515,22 @@ def _unpack(self, execute=EX_CONSTRUCT): return ret if self._use_list else tuple(ret) if typ == TYPE_MAP: if execute == EX_SKIP: - for i in xrange(n): + for i in range(n): # TODO check whether we need to call hooks self._unpack(EX_SKIP) self._unpack(EX_SKIP) return if self._object_pairs_hook is not None: ret = self._object_pairs_hook( - (self._unpack(EX_CONSTRUCT), self._unpack(EX_CONSTRUCT)) - for _ in xrange(n) + (self._unpack(EX_CONSTRUCT), self._unpack(EX_CONSTRUCT)) for _ in range(n) ) else: ret = {} - for _ in xrange(n): + for _ in range(n): key = self._unpack(EX_CONSTRUCT) - if self._strict_map_key and type(key) not in (unicode, bytes): - raise ValueError( - "%s is not allowed for map key" % str(type(key)) - ) - if not PY2 and type(key) is str: + if self._strict_map_key and type(key) not in (str, bytes): + raise ValueError("%s is not allowed for map key" % str(type(key))) + if isinstance(key, str): key = sys.intern(key) ret[key] = self._unpack(EX_CONSTRUCT) if self._object_hook is not None: @@ -659,7 +604,7 @@ def tell(self): return self._stream_offset -class Packer(object): +class Packer: """ MessagePack Packer @@ -671,7 +616,8 @@ class Packer(object): Packer's constructor has some keyword arguments: - :param callable default: + :param default: + When specified, it should be callable. Convert user type to builtin type that Packer supports. See also simplejson's document. @@ -698,7 +644,6 @@ class Packer(object): If set to true, datetime with tzinfo is packed into Timestamp type. Note that the tzinfo is stripped in the timestamp. You can get UTC datetime with `timestamp=3` option of the Unpacker. - (Python 2 is not supported). :param str unicode_errors: The error handler for encoding unicode. (default: 'strict') @@ -743,8 +688,6 @@ def __init__( self._autoreset = autoreset self._use_bin_type = use_bin_type self._buffer = StringIO() - if PY2 and datetime: - raise ValueError("datetime is not supported in Python 2") self._datetime = bool(datetime) self._unicode_errors = unicode_errors or "strict" if default is not None: @@ -774,7 +717,7 @@ def _pack( if obj: return self._buffer.write(b"\xc3") return self._buffer.write(b"\xc2") - if check(obj, int_types): + if check(obj, int): if 0 <= obj < 0x80: return self._buffer.write(struct.pack("B", obj)) if -0x20 <= obj < 0: @@ -806,7 +749,7 @@ def _pack( raise ValueError("%s is too large" % type(obj).__name__) self._pack_bin_header(n) return self._buffer.write(obj) - if check(obj, unicode): + if check(obj, str): obj = obj.encode("utf-8", self._unicode_errors) n = len(obj) if n >= 2**32: @@ -855,13 +798,11 @@ def _pack( if check(obj, list_types): n = len(obj) self._pack_array_header(n) - for i in xrange(n): + for i in range(n): self._pack(obj[i], nest_limit - 1) return if check(obj, dict): - return self._pack_map_pairs( - len(obj), dict_iteritems(obj), nest_limit - 1 - ) + return self._pack_map_pairs(len(obj), obj.items(), nest_limit - 1) if self._datetime and check(obj, _DateTime) and obj.tzinfo is not None: obj = Timestamp.from_datetime(obj) @@ -874,9 +815,9 @@ def _pack( continue if self._datetime and check(obj, _DateTime): - raise ValueError("Cannot serialize %r where tzinfo=None" % (obj,)) + raise ValueError(f"Cannot serialize {obj!r} where tzinfo=None") - raise TypeError("Cannot serialize %r" % (obj,)) + raise TypeError(f"Cannot serialize {obj!r}") def pack(self, obj): try: @@ -963,7 +904,7 @@ def _pack_map_header(self, n): def _pack_map_pairs(self, n, pairs, nest_limit=DEFAULT_RECURSE_LIMIT): self._pack_map_header(n) - for (k, v) in pairs: + for k, v in pairs: self._pack(k, nest_limit - 1) self._pack(v, nest_limit - 1) @@ -1004,7 +945,7 @@ def reset(self): def getbuffer(self): """Return view of internal buffer.""" - if USING_STRINGBUILDER or PY2: + if USING_STRINGBUILDER: return memoryview(self.bytes()) else: return self._buffer.getbuffer() diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/__about__.py b/myenv/Lib/site-packages/pip/_vendor/packaging/__about__.py deleted file mode 100644 index 3551bc2..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/packaging/__about__.py +++ /dev/null @@ -1,26 +0,0 @@ -# This file is dual licensed under the terms of the Apache License, Version -# 2.0, and the BSD License. See the LICENSE file in the root of this repository -# for complete details. - -__all__ = [ - "__title__", - "__summary__", - "__uri__", - "__version__", - "__author__", - "__email__", - "__license__", - "__copyright__", -] - -__title__ = "packaging" -__summary__ = "Core utilities for Python packages" -__uri__ = "https://github.com/pypa/packaging" - -__version__ = "21.3" - -__author__ = "Donald Stufft and individual contributors" -__email__ = "donald@stufft.io" - -__license__ = "BSD-2-Clause or Apache-2.0" -__copyright__ = "2014-2019 %s" % __author__ diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/__init__.py b/myenv/Lib/site-packages/pip/_vendor/packaging/__init__.py index 3c50c5d..9ba41d8 100644 --- a/myenv/Lib/site-packages/pip/_vendor/packaging/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/packaging/__init__.py @@ -2,24 +2,14 @@ # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. -from .__about__ import ( - __author__, - __copyright__, - __email__, - __license__, - __summary__, - __title__, - __uri__, - __version__, -) +__title__ = "packaging" +__summary__ = "Core utilities for Python packages" +__uri__ = "https://github.com/pypa/packaging" -__all__ = [ - "__title__", - "__summary__", - "__uri__", - "__version__", - "__author__", - "__email__", - "__license__", - "__copyright__", -] +__version__ = "24.1" + +__author__ = "Donald Stufft and individual contributors" +__email__ = "donald@stufft.io" + +__license__ = "BSD-2-Clause or Apache-2.0" +__copyright__ = "2014 %s" % __author__ diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-311.pyc deleted file mode 100644 index 9ded7055e27a73fdb4f652e7f41ff7f7f29e43cd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 655 zcmYL_PixyS7{=xNbDY#!4r7cSiZ|FH8&2A+hpmjUHn|kGF$lXDgHR$RR%=^Ek~8d+ zKf!Ke*Rjjk*Vs4ME%X%F7YOv$(_SZpzQRBIl^#Emo?o`zLQtbWU+3Q{2>mOYeL=si z+f#UbM+-#JPs2mh@C;hu(SuR%@Eq)k@O8whz#YE4kD)ob2Z7;COW zhVe}sW0gh`kr^~5#;N4H*(H;Tix`>~#w68&knjzEvWW0-rwRFt#j3QiF`kJelY9~A zQkIa}HCga@kv|;?$(&U4kZaDAGZ)hNl!0CB>_klEPXetIbv76*xDL{3ee*&Rm_27oP&M9++qJXKNudLoVtM5&NKC~XO&Tq5Uwf9#AUTatwg;9q=}?iqFKTM z{6@Dxbayp6^FJ%d&YuM23km%(Q`cG~{^f`9g)?EX<`KX-hkIm-D?iFuy!7Amsjs+Z z?miPg;mH6mSxkkzk6{3(nu-)6?kCw@^GzgZ8nUr+qb>oPs$m$LmesCo&>n@k xd4%l8g|+Goi}tGJ7UsJ1uxPLCS4C@ea8y|9&U0Ak9{o7{+kH{k<&ZYG{Rck2$d3R3 diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-311.pyc index 2d52078513a29ad1cba1b36c651f1446f185a50d..472f6a39cb7c87e0be73c8f8b2774e41a173b6a3 100644 GIT binary patch delta 437 zcmXAlzfQw25XKW4nkFSx2L{T33=&91v}q%TiV0{Z287fti)CWBu}I^{e~^-;c>*NF z0B^ukAh9yCRh{|>eFR);>rVdee)q}txAkRtpPuI$dX0WwChJ$PHNVi}-M~g@U^6uF zPPl_BVFg>Eg?GbUTn($(CRR~3jL^olvC(#xPKKfY1n7I*X#bdWf^M&{gI@m75*m?IY#r8s0(aEE+*sU$~vpUN!d1`pO%W?qct#bXJXX T-DtKx?tYtRrMKC9PY?eA_5+QE literal 576 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 F{{W@50qXz& literal 13242 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 I3&_^}KZ%~W9RL6T diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/_musllinux.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/_musllinux.cpython-311.pyc index 14daf5325509a9bec4b170661b19aa8c49452651..dc1436cee97d8a00e2e97baaaea46ff7080330e2 100644 GIT binary patch delta 2683 zcmZ`)Z)_X46({db|0P?pBwMl_N3qkoniJ3SusAI;d3EEg$yzsq-2l`2@CIc5 z(mkFe$8I(r`S|$mJ@WDK$H%{>{+8@`FA(q|C`bSD)9f|x^^Wce-gFBHtssKZh+rb9 zI4`6H%z052)1uu=Y02&#X@}iA(@y9m)s=Ur-FZ*illP{*VB;W8)tC3D{TK=8yNI~1 zBI2f=yCOpOp*2f7K=zTqRVm#;#l`u~wwMf(&a2X07~XG-P&!D4NElQ@w2MT31dbxa zeq*~3PKO0V!;6u&@>eXQGE5mX7KYh+NDqzPg;nm` zD{*bU5s=4#2B~u~W?qSPn<=T|Q0qsW^nTFyKTJYkAT7pQD+c#pGk_A`?x`wVrb0r z&M0|G=1N7CTJBkTzC;Td`iMsW%v{s296Od%X{PNR?_0-%H}}I}1yPj7014rB00I?> za0H|_C)%7eJB*SJ%P+rL($!Ox>EMDT<_d=8$SaHBfFqwPXly1anOz;v^mNMd4p(LQ zeYDBfG_Ohd3gdvZNf$8sAdu>guP${|PgGA_IkC;~Aq%&SET>j7iY3Dmb%R+>MvW3H zY=w6^mMAA?v;xg+0|0E@&|u4W^TEd*zru&{W;X~{&;lx>dFN$Z#ve*$d|g;}%_7GA zvdQ~`C5(<)xS(@wEKKG1ris)P=K>S}1> z`A6KGaq>t4Vo7<3;-yF{j)~{akdfq>QM+R}bYqQgg0TMlP7mKvXdQT~8sm<%9vqh$5sIFTgD-|s1 ziHw#nLRvhl(gb%WXV46!1*(sF`Qh<0caA2qIi?#4$P5YnoT93Uvov9VIHPJh zg&&4y4;3&~)Lru=lmcmM7ZqkCyjr$Bvq|HF=Fj4B_qO0({8{s}c=Czh%XqG0VL9ov z(E^F`@#bTQ@~qp(6C`Rmoe4{Hg8AQ9aoZ+tb=P+j7ft zUdfr?>pN083chXOgKP@=ORiSDV9z|8F`kcE4<|7ot=sstl*flnZtH%B>-JkNSteRW zmMyO=XG{F(Wts7;XnC@wLdMWERcEhrShERErui?Yaj}>yEHHk@nS&Fa^}u1OX0z~I z+DWGQTJdCRc~n-CGfL(hwa?LxIqNVd`VUp?%ppRCftR4D<_rrP%~!;Jws>0Jav#ZS zq@>amI|D=hH0l2Y3NgdDAxKziAWr-U57p4%&iW7qYwcP`o~r%TQK;6g^%s!0YJYX~ zjoSaO57D05?%Hsg@9Y_UrGZ@d7~VxANbs%WNJ9wY0}a$BUx-MEZi^2DF<@jjdDi^? Hz<>S=IfS0m literal 8010 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 So^m^4x?y?cZPmU+3j81Ogo4xn diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-311.pyc index 687fd18d31b437fda34669229182e15c05e7f48f..3b9c33156cd88a8d026f07d5ab4276fdb7658438 100644 GIT binary patch delta 19 Zcmew)^GSwlIWI340}!~J+{l%|2LL*Q1uy^r delta 19 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 B_=W%g literal 16538 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 CddkcI diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-311.pyc index 008d3600f817374089a2b3f041d284ce8d7f5271..1d8f6edab353eee5239379bfedf6a1a173430d33 100644 GIT binary patch literal 4739 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 literal 34376 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 delta 7592 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 DQ6*sQ delta 2484 zcmaJ?YiwK99Y5zj?d$j3v5D=HLhL5(g1WY9Rr*-V+OlHOb{m@kMJD%zIQ2{C-lS^e zD(PdaOo*19PDDbLybpANB2ffLrF^N-CQZ`>iR2I6m4=W&8P-UD(-?CBO((?R|a}FsEA0! zL%eUiKCs{u5D|5icy9;@-Gtt01;2ofAl-2Z=}r>3Ap#G2mlw2o8t_~X@j`GOnhE!0 zb@vU>;wJR&-bg=xLHBGBi0WSA)qTW2CF%Z4QX!@X;Q4Oiof6g*K*09`KM4G|9n z;s+@o5s2e~+?2GQ*25q_uwH&@blstFU<3pbIzEMR(SPv==X0{<{4uS~lj=ZmY{P>fAT1$A1Vje9u^nI$vCq|=8B3ib)F{>Z zAIXE)e&m-d;>=^rbZ2f5zl_ca4Lrj&u$zug+c8528v^sYqMO$<--2+yF7*2zqmE$8 z^z_a^Xl6}E9_6~+bb$U5Rk;LO&N$g$v|)BM=*c{E5}vVBj30D)%ngd2SA-It~7Am8#pmpgDc%^)HMj)wI|y9nl8TYjw{{0Bh1u<|F`Zd zu6Z^4!nU#8$Yu+%EAAMC%4?q8+B-P^4z@(Yr0n1BW5@TxO-2^rTlg)am9cU7-#++p z=+=o3q8~*&^Yv&)SN@^E;f{mz_oTM~K}R@j1+ZP5$

I7z1E#PYxeoKJQN#M)?}o zlyXB@GO5=lr!A#eual~736#(bUzcWTrK+V;QYJ-%SYn+LORCol(-L(uXUXN-WU-tR z>1Hmh)Qi+0x+TMC8U_!7O!s;#JXx&PswI#v&6A0_cqh8(evo+_x^WSbVG;dTV?p1= zeGVjRzdnB9`0s+(qDxxyN6X^-j&~g$L)?x2F$L7>*mw&tJKoBUuLe%E0w-3blP&4w zigc3w!}qsXpN)8m*l~+K^aozW?5*IIR0Hdt({|mXziJ4&`k-K(Q_LXyL1nIOi}2d%GaN1wA;x0$M!oY)B2c;b=IgBuMg5eqP#kX1YAToo$N5*(ZrGTMBz{ ziromG73g91Ok`}2&vJlgjWZ>4n!=|CTs~Qwt(ul>)XOE4?zERGMH8Yx{aOClp=S?2 zMTcOKy4jt`&a6fca0x{(8q>s}`}oAktJws1wq024AYjSpu*5Tv9f>}!{Q`&+(2aN5 zndrCSzk4HB$WJPh%fEV#jr#%VgMPyR7ly-S{stOD0kpXsk>L zps&KNBu*(Q5Sfp&-zTCk?aAa6dJN{4SSD4w{8}32FDsc)#JY+AKc{x|a88xVWWq2> zg`Tpv8KiExyESivN(Qe)?9JqmYXXQ_=*BmQ{VDlHmFrVp^$xYXL!gV>e|7ls{uL=< zYm-ZMY^s=N>!s?;lq*9e4qP>=aNq~i=Q!|>Kjmh#jcDg&Cp*Xanw_lAvi4wV!BQt{ zl{!40ra33i!FChRB+Bhg`70?eQ=M-S&;I+4y_K3iTPFMHBux2-$M`E?Tf`W*HH5WA zC;#0;yI212-?_$SpQYy5Yv~|+Iz19Zu}xQBx;E1sSdEUfq9ZFP#J)<07eqX~bf}GB zXy)xA!8YCh01{;!)c^nh diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-311.pyc index 2e6da78b0398a6a41f918ff5dba0e9777d2c70a7..069f7308dc982bd3ebea58da533cc6710b4d82e9 100644 GIT binary patch literal 20844 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 None: - def unpack(fmt: str) -> int: - try: - data = file.read(struct.calcsize(fmt)) - result: Tuple[int, ...] = struct.unpack(fmt, data) - except struct.error: - raise _ELFFileHeader._InvalidELFFileHeader() - return result[0] - - self.e_ident_magic = unpack(">I") - if self.e_ident_magic != self.ELF_MAGIC_NUMBER: - raise _ELFFileHeader._InvalidELFFileHeader() - self.e_ident_class = unpack("B") - if self.e_ident_class not in {self.ELFCLASS32, self.ELFCLASS64}: - raise _ELFFileHeader._InvalidELFFileHeader() - self.e_ident_data = unpack("B") - if self.e_ident_data not in {self.ELFDATA2LSB, self.ELFDATA2MSB}: - raise _ELFFileHeader._InvalidELFFileHeader() - self.e_ident_version = unpack("B") - self.e_ident_osabi = unpack("B") - self.e_ident_abiversion = unpack("B") - self.e_ident_pad = file.read(7) - format_h = "H" - format_i = "I" - format_q = "Q" - format_p = format_i if self.e_ident_class == self.ELFCLASS32 else format_q - self.e_type = unpack(format_h) - self.e_machine = unpack(format_h) - self.e_version = unpack(format_i) - self.e_entry = unpack(format_p) - self.e_phoff = unpack(format_p) - self.e_shoff = unpack(format_p) - self.e_flags = unpack(format_i) - self.e_ehsize = unpack(format_h) - self.e_phentsize = unpack(format_h) - self.e_phnum = unpack(format_h) - self.e_shentsize = unpack(format_h) - self.e_shnum = unpack(format_h) - self.e_shstrndx = unpack(format_h) - - -def _get_elf_header() -> Optional[_ELFFileHeader]: +from typing import Generator, Iterator, NamedTuple, Sequence + +from ._elffile import EIClass, EIData, ELFFile, EMachine + +EF_ARM_ABIMASK = 0xFF000000 +EF_ARM_ABI_VER5 = 0x05000000 +EF_ARM_ABI_FLOAT_HARD = 0x00000400 + + +# `os.PathLike` not a generic type until Python 3.9, so sticking with `str` +# as the type for `path` until then. +@contextlib.contextmanager +def _parse_elf(path: str) -> Generator[ELFFile | None, None, None]: try: - with open(sys.executable, "rb") as f: - elf_header = _ELFFileHeader(f) - except (OSError, TypeError, _ELFFileHeader._InvalidELFFileHeader): - return None - return elf_header + with open(path, "rb") as f: + yield ELFFile(f) + except (OSError, TypeError, ValueError): + yield None -def _is_linux_armhf() -> bool: +def _is_linux_armhf(executable: str) -> bool: # hard-float ABI can be detected from the ELF header of the running # process # https://static.docs.arm.com/ihi0044/g/aaelf32.pdf - elf_header = _get_elf_header() - if elf_header is None: - return False - result = elf_header.e_ident_class == elf_header.ELFCLASS32 - result &= elf_header.e_ident_data == elf_header.ELFDATA2LSB - result &= elf_header.e_machine == elf_header.EM_ARM - result &= ( - elf_header.e_flags & elf_header.EF_ARM_ABIMASK - ) == elf_header.EF_ARM_ABI_VER5 - result &= ( - elf_header.e_flags & elf_header.EF_ARM_ABI_FLOAT_HARD - ) == elf_header.EF_ARM_ABI_FLOAT_HARD - return result - - -def _is_linux_i686() -> bool: - elf_header = _get_elf_header() - if elf_header is None: - return False - result = elf_header.e_ident_class == elf_header.ELFCLASS32 - result &= elf_header.e_ident_data == elf_header.ELFDATA2LSB - result &= elf_header.e_machine == elf_header.EM_386 - return result + with _parse_elf(executable) as f: + return ( + f is not None + and f.capacity == EIClass.C32 + and f.encoding == EIData.Lsb + and f.machine == EMachine.Arm + and f.flags & EF_ARM_ABIMASK == EF_ARM_ABI_VER5 + and f.flags & EF_ARM_ABI_FLOAT_HARD == EF_ARM_ABI_FLOAT_HARD + ) + + +def _is_linux_i686(executable: str) -> bool: + with _parse_elf(executable) as f: + return ( + f is not None + and f.capacity == EIClass.C32 + and f.encoding == EIData.Lsb + and f.machine == EMachine.I386 + ) -def _have_compatible_abi(arch: str) -> bool: - if arch == "armv7l": - return _is_linux_armhf() - if arch == "i686": - return _is_linux_i686() - return arch in {"x86_64", "aarch64", "ppc64", "ppc64le", "s390x"} +def _have_compatible_abi(executable: str, archs: Sequence[str]) -> bool: + if "armv7l" in archs: + return _is_linux_armhf(executable) + if "i686" in archs: + return _is_linux_i686(executable) + allowed_archs = { + "x86_64", + "aarch64", + "ppc64", + "ppc64le", + "s390x", + "loongarch64", + "riscv64", + } + return any(arch in allowed_archs for arch in archs) # If glibc ever changes its major version, we need to know what the last @@ -124,7 +74,7 @@ def _have_compatible_abi(arch: str) -> bool: # For now, guess what the highest minor version might be, assume it will # be 50 for testing. Once this actually happens, update the dictionary # with the actual value. -_LAST_GLIBC_MINOR: Dict[int, int] = collections.defaultdict(lambda: 50) +_LAST_GLIBC_MINOR: dict[int, int] = collections.defaultdict(lambda: 50) class _GLibCVersion(NamedTuple): @@ -132,7 +82,7 @@ class _GLibCVersion(NamedTuple): minor: int -def _glibc_version_string_confstr() -> Optional[str]: +def _glibc_version_string_confstr() -> str | None: """ Primary implementation of glibc_version_string using os.confstr. """ @@ -141,17 +91,17 @@ def _glibc_version_string_confstr() -> Optional[str]: # platform module. # https://github.com/python/cpython/blob/fcf1d003bf4f0100c/Lib/platform.py#L175-L183 try: - # os.confstr("CS_GNU_LIBC_VERSION") returns a string like "glibc 2.17". - version_string = os.confstr("CS_GNU_LIBC_VERSION") + # Should be a string like "glibc 2.17". + version_string: str | None = os.confstr("CS_GNU_LIBC_VERSION") assert version_string is not None - _, version = version_string.split() + _, version = version_string.rsplit() except (AssertionError, AttributeError, OSError, ValueError): # os.confstr() or CS_GNU_LIBC_VERSION not available (or a bad value)... return None return version -def _glibc_version_string_ctypes() -> Optional[str]: +def _glibc_version_string_ctypes() -> str | None: """ Fallback implementation of glibc_version_string using ctypes. """ @@ -195,12 +145,12 @@ def _glibc_version_string_ctypes() -> Optional[str]: return version_str -def _glibc_version_string() -> Optional[str]: +def _glibc_version_string() -> str | None: """Returns glibc version string, or None if not using glibc.""" return _glibc_version_string_confstr() or _glibc_version_string_ctypes() -def _parse_glibc_version(version_str: str) -> Tuple[int, int]: +def _parse_glibc_version(version_str: str) -> tuple[int, int]: """Parse glibc version. We use a regexp instead of str.split because we want to discard any @@ -211,16 +161,16 @@ def _parse_glibc_version(version_str: str) -> Tuple[int, int]: m = re.match(r"(?P[0-9]+)\.(?P[0-9]+)", version_str) if not m: warnings.warn( - "Expected glibc version with 2 components major.minor," - " got: %s" % version_str, + f"Expected glibc version with 2 components major.minor," + f" got: {version_str}", RuntimeWarning, ) return -1, -1 return int(m.group("major")), int(m.group("minor")) -@functools.lru_cache() -def _get_glibc_version() -> Tuple[int, int]: +@functools.lru_cache +def _get_glibc_version() -> tuple[int, int]: version_str = _glibc_version_string() if version_str is None: return (-1, -1) @@ -228,13 +178,13 @@ def _get_glibc_version() -> Tuple[int, int]: # From PEP 513, PEP 600 -def _is_compatible(name: str, arch: str, version: _GLibCVersion) -> bool: +def _is_compatible(arch: str, version: _GLibCVersion) -> bool: sys_glibc = _get_glibc_version() if sys_glibc < version: return False # Check for presence of _manylinux module. try: - import _manylinux # noqa + import _manylinux except ImportError: return True if hasattr(_manylinux, "manylinux_compatible"): @@ -264,12 +214,22 @@ def _is_compatible(name: str, arch: str, version: _GLibCVersion) -> bool: } -def platform_tags(linux: str, arch: str) -> Iterator[str]: - if not _have_compatible_abi(arch): +def platform_tags(archs: Sequence[str]) -> Iterator[str]: + """Generate manylinux tags compatible to the current platform. + + :param archs: Sequence of compatible architectures. + The first one shall be the closest to the actual architecture and be the part of + platform tag after the ``linux_`` prefix, e.g. ``x86_64``. + The ``linux_`` prefix is assumed as a prerequisite for the current platform to + be manylinux-compatible. + + :returns: An iterator of compatible manylinux tags. + """ + if not _have_compatible_abi(sys.executable, archs): return # Oldest glibc to be supported regardless of architecture is (2, 17). too_old_glibc2 = _GLibCVersion(2, 16) - if arch in {"x86_64", "i686"}: + if set(archs) & {"x86_64", "i686"}: # On x86/i686 also oldest glibc to be supported is (2, 5). too_old_glibc2 = _GLibCVersion(2, 4) current_glibc = _GLibCVersion(*_get_glibc_version()) @@ -283,19 +243,20 @@ def platform_tags(linux: str, arch: str) -> Iterator[str]: for glibc_major in range(current_glibc.major - 1, 1, -1): glibc_minor = _LAST_GLIBC_MINOR[glibc_major] glibc_max_list.append(_GLibCVersion(glibc_major, glibc_minor)) - for glibc_max in glibc_max_list: - if glibc_max.major == too_old_glibc2.major: - min_minor = too_old_glibc2.minor - else: - # For other glibc major versions oldest supported is (x, 0). - min_minor = -1 - for glibc_minor in range(glibc_max.minor, min_minor, -1): - glibc_version = _GLibCVersion(glibc_max.major, glibc_minor) - tag = "manylinux_{}_{}".format(*glibc_version) - if _is_compatible(tag, arch, glibc_version): - yield linux.replace("linux", tag) - # Handle the legacy manylinux1, manylinux2010, manylinux2014 tags. - if glibc_version in _LEGACY_MANYLINUX_MAP: - legacy_tag = _LEGACY_MANYLINUX_MAP[glibc_version] - if _is_compatible(legacy_tag, arch, glibc_version): - yield linux.replace("linux", legacy_tag) + for arch in archs: + for glibc_max in glibc_max_list: + if glibc_max.major == too_old_glibc2.major: + min_minor = too_old_glibc2.minor + else: + # For other glibc major versions oldest supported is (x, 0). + min_minor = -1 + for glibc_minor in range(glibc_max.minor, min_minor, -1): + glibc_version = _GLibCVersion(glibc_max.major, glibc_minor) + tag = "manylinux_{}_{}".format(*glibc_version) + if _is_compatible(arch, glibc_version): + yield f"{tag}_{arch}" + # Handle the legacy manylinux1, manylinux2010, manylinux2014 tags. + if glibc_version in _LEGACY_MANYLINUX_MAP: + legacy_tag = _LEGACY_MANYLINUX_MAP[glibc_version] + if _is_compatible(arch, glibc_version): + yield f"{legacy_tag}_{arch}" diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py b/myenv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py index 8ac3059..d2bf30b 100644 --- a/myenv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py +++ b/myenv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py @@ -4,68 +4,15 @@ linked against musl, and what musl version is used. """ -import contextlib +from __future__ import annotations + import functools -import operator -import os import re -import struct import subprocess import sys -from typing import IO, Iterator, NamedTuple, Optional, Tuple - - -def _read_unpacked(f: IO[bytes], fmt: str) -> Tuple[int, ...]: - return struct.unpack(fmt, f.read(struct.calcsize(fmt))) +from typing import Iterator, NamedTuple, Sequence - -def _parse_ld_musl_from_elf(f: IO[bytes]) -> Optional[str]: - """Detect musl libc location by parsing the Python executable. - - Based on: https://gist.github.com/lyssdod/f51579ae8d93c8657a5564aefc2ffbca - ELF header: https://refspecs.linuxfoundation.org/elf/gabi4+/ch4.eheader.html - """ - f.seek(0) - try: - ident = _read_unpacked(f, "16B") - except struct.error: - return None - if ident[:4] != tuple(b"\x7fELF"): # Invalid magic, not ELF. - return None - f.seek(struct.calcsize("HHI"), 1) # Skip file type, machine, and version. - - try: - # e_fmt: Format for program header. - # p_fmt: Format for section header. - # p_idx: Indexes to find p_type, p_offset, and p_filesz. - e_fmt, p_fmt, p_idx = { - 1: ("IIIIHHH", "IIIIIIII", (0, 1, 4)), # 32-bit. - 2: ("QQQIHHH", "IIQQQQQQ", (0, 2, 5)), # 64-bit. - }[ident[4]] - except KeyError: - return None - else: - p_get = operator.itemgetter(*p_idx) - - # Find the interpreter section and return its content. - try: - _, e_phoff, _, _, _, e_phentsize, e_phnum = _read_unpacked(f, e_fmt) - except struct.error: - return None - for i in range(e_phnum + 1): - f.seek(e_phoff + e_phentsize * i) - try: - p_type, p_offset, p_filesz = p_get(_read_unpacked(f, p_fmt)) - except struct.error: - return None - if p_type != 3: # Not PT_INTERP. - continue - f.seek(p_offset) - interpreter = os.fsdecode(f.read(p_filesz)).strip("\0") - if "musl" not in interpreter: - return None - return interpreter - return None +from ._elffile import ELFFile class _MuslVersion(NamedTuple): @@ -73,7 +20,7 @@ class _MuslVersion(NamedTuple): minor: int -def _parse_musl_version(output: str) -> Optional[_MuslVersion]: +def _parse_musl_version(output: str) -> _MuslVersion | None: lines = [n for n in (n.strip() for n in output.splitlines()) if n] if len(lines) < 2 or lines[0][:4] != "musl": return None @@ -83,8 +30,8 @@ def _parse_musl_version(output: str) -> Optional[_MuslVersion]: return _MuslVersion(major=int(m.group(1)), minor=int(m.group(2))) -@functools.lru_cache() -def _get_musl_version(executable: str) -> Optional[_MuslVersion]: +@functools.lru_cache +def _get_musl_version(executable: str) -> _MuslVersion | None: """Detect currently-running musl runtime version. This is done by checking the specified executable's dynamic linking @@ -95,32 +42,34 @@ def _get_musl_version(executable: str) -> Optional[_MuslVersion]: Version 1.2.2 Dynamic Program Loader """ - with contextlib.ExitStack() as stack: - try: - f = stack.enter_context(open(executable, "rb")) - except OSError: - return None - ld = _parse_ld_musl_from_elf(f) - if not ld: + try: + with open(executable, "rb") as f: + ld = ELFFile(f).interpreter + except (OSError, TypeError, ValueError): + return None + if ld is None or "musl" not in ld: return None - proc = subprocess.run([ld], stderr=subprocess.PIPE, universal_newlines=True) + proc = subprocess.run([ld], stderr=subprocess.PIPE, text=True) return _parse_musl_version(proc.stderr) -def platform_tags(arch: str) -> Iterator[str]: +def platform_tags(archs: Sequence[str]) -> Iterator[str]: """Generate musllinux tags compatible to the current platform. - :param arch: Should be the part of platform tag after the ``linux_`` - prefix, e.g. ``x86_64``. The ``linux_`` prefix is assumed as a - prerequisite for the current platform to be musllinux-compatible. + :param archs: Sequence of compatible architectures. + The first one shall be the closest to the actual architecture and be the part of + platform tag after the ``linux_`` prefix, e.g. ``x86_64``. + The ``linux_`` prefix is assumed as a prerequisite for the current platform to + be musllinux-compatible. :returns: An iterator of compatible musllinux tags. """ sys_musl = _get_musl_version(sys.executable) if sys_musl is None: # Python not dynamically linked against musl. return - for minor in range(sys_musl.minor, -1, -1): - yield f"musllinux_{sys_musl.major}_{minor}_{arch}" + for arch in archs: + for minor in range(sys_musl.minor, -1, -1): + yield f"musllinux_{sys_musl.major}_{minor}_{arch}" if __name__ == "__main__": # pragma: no cover diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/markers.py b/myenv/Lib/site-packages/pip/_vendor/packaging/markers.py index 540e7a4..7ac7bb6 100644 --- a/myenv/Lib/site-packages/pip/_vendor/packaging/markers.py +++ b/myenv/Lib/site-packages/pip/_vendor/packaging/markers.py @@ -2,25 +2,19 @@ # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. +from __future__ import annotations + import operator import os import platform import sys -from typing import Any, Callable, Dict, List, Optional, Tuple, Union - -from pip._vendor.pyparsing import ( # noqa: N817 - Forward, - Group, - Literal as L, - ParseException, - ParseResults, - QuotedString, - ZeroOrMore, - stringEnd, - stringStart, -) +from typing import Any, Callable, TypedDict, cast +from ._parser import MarkerAtom, MarkerList, Op, Value, Variable +from ._parser import parse_marker as _parse_marker +from ._tokenizer import ParserSyntaxError from .specifiers import InvalidSpecifier, Specifier +from .utils import canonicalize_name __all__ = [ "InvalidMarker", @@ -52,103 +46,97 @@ class UndefinedEnvironmentName(ValueError): """ -class Node: - def __init__(self, value: Any) -> None: - self.value = value +class Environment(TypedDict): + implementation_name: str + """The implementation's identifier, e.g. ``'cpython'``.""" - def __str__(self) -> str: - return str(self.value) + implementation_version: str + """ + The implementation's version, e.g. ``'3.13.0a2'`` for CPython 3.13.0a2, or + ``'7.3.13'`` for PyPy3.10 v7.3.13. + """ - def __repr__(self) -> str: - return f"<{self.__class__.__name__}('{self}')>" - - def serialize(self) -> str: - raise NotImplementedError - - -class Variable(Node): - def serialize(self) -> str: - return str(self) - - -class Value(Node): - def serialize(self) -> str: - return f'"{self}"' - - -class Op(Node): - def serialize(self) -> str: - return str(self) - - -VARIABLE = ( - L("implementation_version") - | L("platform_python_implementation") - | L("implementation_name") - | L("python_full_version") - | L("platform_release") - | L("platform_version") - | L("platform_machine") - | L("platform_system") - | L("python_version") - | L("sys_platform") - | L("os_name") - | L("os.name") # PEP-345 - | L("sys.platform") # PEP-345 - | L("platform.version") # PEP-345 - | L("platform.machine") # PEP-345 - | L("platform.python_implementation") # PEP-345 - | L("python_implementation") # undocumented setuptools legacy - | L("extra") # PEP-508 -) -ALIASES = { - "os.name": "os_name", - "sys.platform": "sys_platform", - "platform.version": "platform_version", - "platform.machine": "platform_machine", - "platform.python_implementation": "platform_python_implementation", - "python_implementation": "platform_python_implementation", -} -VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0]))) + os_name: str + """ + The value of :py:data:`os.name`. The name of the operating system dependent module + imported, e.g. ``'posix'``. + """ -VERSION_CMP = ( - L("===") | L("==") | L(">=") | L("<=") | L("!=") | L("~=") | L(">") | L("<") -) + platform_machine: str + """ + Returns the machine type, e.g. ``'i386'``. -MARKER_OP = VERSION_CMP | L("not in") | L("in") -MARKER_OP.setParseAction(lambda s, l, t: Op(t[0])) + An empty string if the value cannot be determined. + """ -MARKER_VALUE = QuotedString("'") | QuotedString('"') -MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0])) + platform_release: str + """ + The system's release, e.g. ``'2.2.0'`` or ``'NT'``. -BOOLOP = L("and") | L("or") + An empty string if the value cannot be determined. + """ -MARKER_VAR = VARIABLE | MARKER_VALUE + platform_system: str + """ + The system/OS name, e.g. ``'Linux'``, ``'Windows'`` or ``'Java'``. -MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR) -MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0])) + An empty string if the value cannot be determined. + """ -LPAREN = L("(").suppress() -RPAREN = L(")").suppress() + platform_version: str + """ + The system's release version, e.g. ``'#3 on degas'``. -MARKER_EXPR = Forward() -MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN) -MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR) + An empty string if the value cannot be determined. + """ -MARKER = stringStart + MARKER_EXPR + stringEnd + python_full_version: str + """ + The Python version as string ``'major.minor.patchlevel'``. + Note that unlike the Python :py:data:`sys.version`, this value will always include + the patchlevel (it defaults to 0). + """ -def _coerce_parse_result(results: Union[ParseResults, List[Any]]) -> List[Any]: - if isinstance(results, ParseResults): - return [_coerce_parse_result(i) for i in results] - else: - return results + platform_python_implementation: str + """ + A string identifying the Python implementation, e.g. ``'CPython'``. + """ + + python_version: str + """The Python version as string ``'major.minor'``.""" + + sys_platform: str + """ + This string contains a platform identifier that can be used to append + platform-specific components to :py:data:`sys.path`, for instance. + + For Unix systems, except on Linux and AIX, this is the lowercased OS name as + returned by ``uname -s`` with the first part of the version as returned by + ``uname -r`` appended, e.g. ``'sunos5'`` or ``'freebsd8'``, at the time when Python + was built. + """ + + +def _normalize_extra_values(results: Any) -> Any: + """ + Normalize extra values. + """ + if isinstance(results[0], tuple): + lhs, op, rhs = results[0] + if isinstance(lhs, Variable) and lhs.value == "extra": + normalized_extra = canonicalize_name(rhs.value) + rhs = Value(normalized_extra) + elif isinstance(rhs, Variable) and rhs.value == "extra": + normalized_extra = canonicalize_name(lhs.value) + lhs = Value(normalized_extra) + results[0] = lhs, op, rhs + return results def _format_marker( - marker: Union[List[str], Tuple[Node, ...], str], first: Optional[bool] = True + marker: list[str] | MarkerAtom | str, first: bool | None = True ) -> str: - assert isinstance(marker, (list, tuple, str)) # Sometimes we have a structure like [[...]] which is a single item list @@ -174,7 +162,7 @@ def _format_marker( return marker -_operators: Dict[str, Operator] = { +_operators: dict[str, Operator] = { "in": lambda lhs, rhs: lhs in rhs, "not in": lambda lhs, rhs: lhs not in rhs, "<": operator.lt, @@ -192,35 +180,29 @@ def _eval_op(lhs: str, op: Op, rhs: str) -> bool: except InvalidSpecifier: pass else: - return spec.contains(lhs) + return spec.contains(lhs, prereleases=True) - oper: Optional[Operator] = _operators.get(op.serialize()) + oper: Operator | None = _operators.get(op.serialize()) if oper is None: raise UndefinedComparison(f"Undefined {op!r} on {lhs!r} and {rhs!r}.") return oper(lhs, rhs) -class Undefined: - pass - - -_undefined = Undefined() - - -def _get_env(environment: Dict[str, str], name: str) -> str: - value: Union[str, Undefined] = environment.get(name, _undefined) +def _normalize(*values: str, key: str) -> tuple[str, ...]: + # PEP 685 – Comparison of extra names for optional distribution dependencies + # https://peps.python.org/pep-0685/ + # > When comparing extra names, tools MUST normalize the names being + # > compared using the semantics outlined in PEP 503 for names + if key == "extra": + return tuple(canonicalize_name(v) for v in values) - if isinstance(value, Undefined): - raise UndefinedEnvironmentName( - f"{name!r} does not exist in evaluation environment." - ) + # other environment markers don't have such standards + return values - return value - -def _evaluate_markers(markers: List[Any], environment: Dict[str, str]) -> bool: - groups: List[List[bool]] = [[]] +def _evaluate_markers(markers: MarkerList, environment: dict[str, str]) -> bool: + groups: list[list[bool]] = [[]] for marker in markers: assert isinstance(marker, (list, tuple, str)) @@ -231,12 +213,15 @@ def _evaluate_markers(markers: List[Any], environment: Dict[str, str]) -> bool: lhs, op, rhs = marker if isinstance(lhs, Variable): - lhs_value = _get_env(environment, lhs.value) + environment_key = lhs.value + lhs_value = environment[environment_key] rhs_value = rhs.value else: lhs_value = lhs.value - rhs_value = _get_env(environment, rhs.value) + environment_key = rhs.value + rhs_value = environment[environment_key] + lhs_value, rhs_value = _normalize(lhs_value, rhs_value, key=environment_key) groups[-1].append(_eval_op(lhs_value, op, rhs_value)) else: assert marker in ["and", "or"] @@ -246,7 +231,7 @@ def _evaluate_markers(markers: List[Any], environment: Dict[str, str]) -> bool: return any(all(item) for item in groups) -def format_full_version(info: "sys._version_info") -> str: +def format_full_version(info: sys._version_info) -> str: version = "{0.major}.{0.minor}.{0.micro}".format(info) kind = info.releaselevel if kind != "final": @@ -254,7 +239,7 @@ def format_full_version(info: "sys._version_info") -> str: return version -def default_environment() -> Dict[str, str]: +def default_environment() -> Environment: iver = format_full_version(sys.implementation.version) implementation_name = sys.implementation.name return { @@ -274,13 +259,29 @@ def default_environment() -> Dict[str, str]: class Marker: def __init__(self, marker: str) -> None: + # Note: We create a Marker object without calling this constructor in + # packaging.requirements.Requirement. If any additional logic is + # added here, make sure to mirror/adapt Requirement. try: - self._markers = _coerce_parse_result(MARKER.parseString(marker)) - except ParseException as e: - raise InvalidMarker( - f"Invalid marker: {marker!r}, parse error at " - f"{marker[e.loc : e.loc + 8]!r}" - ) + self._markers = _normalize_extra_values(_parse_marker(marker)) + # The attribute `_markers` can be described in terms of a recursive type: + # MarkerList = List[Union[Tuple[Node, ...], str, MarkerList]] + # + # For example, the following expression: + # python_version > "3.6" or (python_version == "3.6" and os_name == "unix") + # + # is parsed into: + # [ + # (, ')>, ), + # 'and', + # [ + # (, , ), + # 'or', + # (, , ) + # ] + # ] + except ParserSyntaxError as e: + raise InvalidMarker(str(e)) from e def __str__(self) -> str: return _format_marker(self._markers) @@ -288,7 +289,16 @@ def __str__(self) -> str: def __repr__(self) -> str: return f"" - def evaluate(self, environment: Optional[Dict[str, str]] = None) -> bool: + def __hash__(self) -> int: + return hash((self.__class__.__name__, str(self))) + + def __eq__(self, other: Any) -> bool: + if not isinstance(other, Marker): + return NotImplemented + + return str(self) == str(other) + + def evaluate(self, environment: dict[str, str] | None = None) -> bool: """Evaluate a marker. Return the boolean from evaluating the given marker against the @@ -297,8 +307,19 @@ def evaluate(self, environment: Optional[Dict[str, str]] = None) -> bool: The environment is determined from the current Python process. """ - current_environment = default_environment() + current_environment = cast("dict[str, str]", default_environment()) + current_environment["extra"] = "" + # Work around platform.python_version() returning something that is not PEP 440 + # compliant for non-tagged Python builds. We preserve default_environment()'s + # behavior of returning platform.python_version() verbatim, and leave it to the + # caller to provide a syntactically valid version if they want to override it. + if current_environment["python_full_version"].endswith("+"): + current_environment["python_full_version"] += "local" if environment is not None: current_environment.update(environment) + # The API used to allow setting extra to None. We need to handle this + # case for backwards compatibility. + if current_environment["extra"] is None: + current_environment["extra"] = "" return _evaluate_markers(self._markers, current_environment) diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/requirements.py b/myenv/Lib/site-packages/pip/_vendor/packaging/requirements.py index 1eab7dd..4e068c9 100644 --- a/myenv/Lib/site-packages/pip/_vendor/packaging/requirements.py +++ b/myenv/Lib/site-packages/pip/_vendor/packaging/requirements.py @@ -1,27 +1,15 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. +from __future__ import annotations -import re -import string -import urllib.parse -from typing import List, Optional as TOptional, Set +from typing import Any, Iterator -from pip._vendor.pyparsing import ( # noqa - Combine, - Literal as L, - Optional, - ParseException, - Regex, - Word, - ZeroOrMore, - originalTextFor, - stringEnd, - stringStart, -) - -from .markers import MARKER_EXPR, Marker -from .specifiers import LegacySpecifier, Specifier, SpecifierSet +from ._parser import parse_requirement as _parse_requirement +from ._tokenizer import ParserSyntaxError +from .markers import Marker, _normalize_extra_values +from .specifiers import SpecifierSet +from .utils import canonicalize_name class InvalidRequirement(ValueError): @@ -30,60 +18,6 @@ class InvalidRequirement(ValueError): """ -ALPHANUM = Word(string.ascii_letters + string.digits) - -LBRACKET = L("[").suppress() -RBRACKET = L("]").suppress() -LPAREN = L("(").suppress() -RPAREN = L(")").suppress() -COMMA = L(",").suppress() -SEMICOLON = L(";").suppress() -AT = L("@").suppress() - -PUNCTUATION = Word("-_.") -IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM) -IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END)) - -NAME = IDENTIFIER("name") -EXTRA = IDENTIFIER - -URI = Regex(r"[^ ]+")("url") -URL = AT + URI - -EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA) -EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras") - -VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE) -VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE) - -VERSION_ONE = VERSION_PEP440 ^ VERSION_LEGACY -VERSION_MANY = Combine( - VERSION_ONE + ZeroOrMore(COMMA + VERSION_ONE), joinString=",", adjacent=False -)("_raw_spec") -_VERSION_SPEC = Optional((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY) -_VERSION_SPEC.setParseAction(lambda s, l, t: t._raw_spec or "") - -VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier") -VERSION_SPEC.setParseAction(lambda s, l, t: t[1]) - -MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker") -MARKER_EXPR.setParseAction( - lambda s, l, t: Marker(s[t._original_start : t._original_end]) -) -MARKER_SEPARATOR = SEMICOLON -MARKER = MARKER_SEPARATOR + MARKER_EXPR - -VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER) -URL_AND_MARKER = URL + Optional(MARKER) - -NAMED_REQUIREMENT = NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER) - -REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd -# pyparsing isn't thread safe during initialization, so we do it eagerly, see -# issue #104 -REQUIREMENT.parseString("x[]") - - class Requirement: """Parse a requirement. @@ -99,48 +33,59 @@ class Requirement: def __init__(self, requirement_string: str) -> None: try: - req = REQUIREMENT.parseString(requirement_string) - except ParseException as e: - raise InvalidRequirement( - f'Parse error at "{ requirement_string[e.loc : e.loc + 8]!r}": {e.msg}' - ) - - self.name: str = req.name - if req.url: - parsed_url = urllib.parse.urlparse(req.url) - if parsed_url.scheme == "file": - if urllib.parse.urlunparse(parsed_url) != req.url: - raise InvalidRequirement("Invalid URL given") - elif not (parsed_url.scheme and parsed_url.netloc) or ( - not parsed_url.scheme and not parsed_url.netloc - ): - raise InvalidRequirement(f"Invalid URL: {req.url}") - self.url: TOptional[str] = req.url - else: - self.url = None - self.extras: Set[str] = set(req.extras.asList() if req.extras else []) - self.specifier: SpecifierSet = SpecifierSet(req.specifier) - self.marker: TOptional[Marker] = req.marker if req.marker else None - - def __str__(self) -> str: - parts: List[str] = [self.name] + parsed = _parse_requirement(requirement_string) + except ParserSyntaxError as e: + raise InvalidRequirement(str(e)) from e + + self.name: str = parsed.name + self.url: str | None = parsed.url or None + self.extras: set[str] = set(parsed.extras or []) + self.specifier: SpecifierSet = SpecifierSet(parsed.specifier) + self.marker: Marker | None = None + if parsed.marker is not None: + self.marker = Marker.__new__(Marker) + self.marker._markers = _normalize_extra_values(parsed.marker) + + def _iter_parts(self, name: str) -> Iterator[str]: + yield name if self.extras: formatted_extras = ",".join(sorted(self.extras)) - parts.append(f"[{formatted_extras}]") + yield f"[{formatted_extras}]" if self.specifier: - parts.append(str(self.specifier)) + yield str(self.specifier) if self.url: - parts.append(f"@ {self.url}") + yield f"@ {self.url}" if self.marker: - parts.append(" ") + yield " " if self.marker: - parts.append(f"; {self.marker}") + yield f"; {self.marker}" - return "".join(parts) + def __str__(self) -> str: + return "".join(self._iter_parts(self.name)) def __repr__(self) -> str: return f"" + + def __hash__(self) -> int: + return hash( + ( + self.__class__.__name__, + *self._iter_parts(canonicalize_name(self.name)), + ) + ) + + def __eq__(self, other: Any) -> bool: + if not isinstance(other, Requirement): + return NotImplemented + + return ( + canonicalize_name(self.name) == canonicalize_name(other.name) + and self.extras == other.extras + and self.specifier == other.specifier + and self.url == other.url + and self.marker == other.marker + ) diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/specifiers.py b/myenv/Lib/site-packages/pip/_vendor/packaging/specifiers.py index 0e218a6..f3ac480 100644 --- a/myenv/Lib/site-packages/pip/_vendor/packaging/specifiers.py +++ b/myenv/Lib/site-packages/pip/_vendor/packaging/specifiers.py @@ -1,38 +1,43 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. +""" +.. testsetup:: + + from pip._vendor.packaging.specifiers import Specifier, SpecifierSet, InvalidSpecifier + from pip._vendor.packaging.version import Version +""" + +from __future__ import annotations import abc -import functools import itertools import re -import warnings -from typing import ( - Callable, - Dict, - Iterable, - Iterator, - List, - Optional, - Pattern, - Set, - Tuple, - TypeVar, - Union, -) +from typing import Callable, Iterable, Iterator, TypeVar, Union from .utils import canonicalize_version -from .version import LegacyVersion, Version, parse +from .version import Version + +UnparsedVersion = Union[Version, str] +UnparsedVersionVar = TypeVar("UnparsedVersionVar", bound=UnparsedVersion) +CallableOperator = Callable[[Version, str], bool] + -ParsedVersion = Union[Version, LegacyVersion] -UnparsedVersion = Union[Version, LegacyVersion, str] -VersionTypeVar = TypeVar("VersionTypeVar", bound=UnparsedVersion) -CallableOperator = Callable[[ParsedVersion, str], bool] +def _coerce_version(version: UnparsedVersion) -> Version: + if not isinstance(version, Version): + version = Version(version) + return version class InvalidSpecifier(ValueError): """ - An invalid specifier was found, users should refer to PEP 440. + Raised when attempting to create a :class:`Specifier` with a specifier + string that is invalid. + + >>> Specifier("lolwat") + Traceback (most recent call last): + ... + packaging.specifiers.InvalidSpecifier: Invalid specifier: 'lolwat' """ @@ -40,266 +45,71 @@ class BaseSpecifier(metaclass=abc.ABCMeta): @abc.abstractmethod def __str__(self) -> str: """ - Returns the str representation of this Specifier like object. This + Returns the str representation of this Specifier-like object. This should be representative of the Specifier itself. """ @abc.abstractmethod def __hash__(self) -> int: """ - Returns a hash value for this Specifier like object. + Returns a hash value for this Specifier-like object. """ @abc.abstractmethod def __eq__(self, other: object) -> bool: """ - Returns a boolean representing whether or not the two Specifier like + Returns a boolean representing whether or not the two Specifier-like objects are equal. - """ - @abc.abstractproperty - def prereleases(self) -> Optional[bool]: + :param other: The other object to check against. """ - Returns whether or not pre-releases as a whole are allowed by this - specifier. + + @property + @abc.abstractmethod + def prereleases(self) -> bool | None: + """Whether or not pre-releases as a whole are allowed. + + This can be set to either ``True`` or ``False`` to explicitly enable or disable + prereleases or it can be set to ``None`` (the default) to use default semantics. """ @prereleases.setter def prereleases(self, value: bool) -> None: - """ - Sets whether or not pre-releases as a whole are allowed by this - specifier. + """Setter for :attr:`prereleases`. + + :param value: The value to set. """ @abc.abstractmethod - def contains(self, item: str, prereleases: Optional[bool] = None) -> bool: + def contains(self, item: str, prereleases: bool | None = None) -> bool: """ Determines if the given item is contained within this specifier. """ @abc.abstractmethod def filter( - self, iterable: Iterable[VersionTypeVar], prereleases: Optional[bool] = None - ) -> Iterable[VersionTypeVar]: + self, iterable: Iterable[UnparsedVersionVar], prereleases: bool | None = None + ) -> Iterator[UnparsedVersionVar]: """ Takes an iterable of items and filters them so that only items which are contained within this specifier are allowed in it. """ -class _IndividualSpecifier(BaseSpecifier): - - _operators: Dict[str, str] = {} - _regex: Pattern[str] - - def __init__(self, spec: str = "", prereleases: Optional[bool] = None) -> None: - match = self._regex.search(spec) - if not match: - raise InvalidSpecifier(f"Invalid specifier: '{spec}'") - - self._spec: Tuple[str, str] = ( - match.group("operator").strip(), - match.group("version").strip(), - ) - - # Store whether or not this Specifier should accept prereleases - self._prereleases = prereleases - - def __repr__(self) -> str: - pre = ( - f", prereleases={self.prereleases!r}" - if self._prereleases is not None - else "" - ) - - return f"<{self.__class__.__name__}({str(self)!r}{pre})>" - - def __str__(self) -> str: - return "{}{}".format(*self._spec) - - @property - def _canonical_spec(self) -> Tuple[str, str]: - return self._spec[0], canonicalize_version(self._spec[1]) - - def __hash__(self) -> int: - return hash(self._canonical_spec) - - def __eq__(self, other: object) -> bool: - if isinstance(other, str): - try: - other = self.__class__(str(other)) - except InvalidSpecifier: - return NotImplemented - elif not isinstance(other, self.__class__): - return NotImplemented - - return self._canonical_spec == other._canonical_spec - - def _get_operator(self, op: str) -> CallableOperator: - operator_callable: CallableOperator = getattr( - self, f"_compare_{self._operators[op]}" - ) - return operator_callable - - def _coerce_version(self, version: UnparsedVersion) -> ParsedVersion: - if not isinstance(version, (LegacyVersion, Version)): - version = parse(version) - return version - - @property - def operator(self) -> str: - return self._spec[0] - - @property - def version(self) -> str: - return self._spec[1] - - @property - def prereleases(self) -> Optional[bool]: - return self._prereleases - - @prereleases.setter - def prereleases(self, value: bool) -> None: - self._prereleases = value - - def __contains__(self, item: str) -> bool: - return self.contains(item) - - def contains( - self, item: UnparsedVersion, prereleases: Optional[bool] = None - ) -> bool: - - # Determine if prereleases are to be allowed or not. - if prereleases is None: - prereleases = self.prereleases - - # Normalize item to a Version or LegacyVersion, this allows us to have - # a shortcut for ``"2.0" in Specifier(">=2") - normalized_item = self._coerce_version(item) - - # Determine if we should be supporting prereleases in this specifier - # or not, if we do not support prereleases than we can short circuit - # logic if this version is a prereleases. - if normalized_item.is_prerelease and not prereleases: - return False - - # Actually do the comparison to determine if this item is contained - # within this Specifier or not. - operator_callable: CallableOperator = self._get_operator(self.operator) - return operator_callable(normalized_item, self.version) - - def filter( - self, iterable: Iterable[VersionTypeVar], prereleases: Optional[bool] = None - ) -> Iterable[VersionTypeVar]: - - yielded = False - found_prereleases = [] - - kw = {"prereleases": prereleases if prereleases is not None else True} - - # Attempt to iterate over all the values in the iterable and if any of - # them match, yield them. - for version in iterable: - parsed_version = self._coerce_version(version) - - if self.contains(parsed_version, **kw): - # If our version is a prerelease, and we were not set to allow - # prereleases, then we'll store it for later in case nothing - # else matches this specifier. - if parsed_version.is_prerelease and not ( - prereleases or self.prereleases - ): - found_prereleases.append(version) - # Either this is not a prerelease, or we should have been - # accepting prereleases from the beginning. - else: - yielded = True - yield version - - # Now that we've iterated over everything, determine if we've yielded - # any values, and if we have not and we have any prereleases stored up - # then we will go ahead and yield the prereleases. - if not yielded and found_prereleases: - for version in found_prereleases: - yield version - - -class LegacySpecifier(_IndividualSpecifier): - - _regex_str = r""" - (?P(==|!=|<=|>=|<|>)) - \s* - (?P - [^,;\s)]* # Since this is a "legacy" specifier, and the version - # string can be just about anything, we match everything - # except for whitespace, a semi-colon for marker support, - # a closing paren since versions can be enclosed in - # them, and a comma since it's a version separator. - ) - """ - - _regex = re.compile(r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) - - _operators = { - "==": "equal", - "!=": "not_equal", - "<=": "less_than_equal", - ">=": "greater_than_equal", - "<": "less_than", - ">": "greater_than", - } - - def __init__(self, spec: str = "", prereleases: Optional[bool] = None) -> None: - super().__init__(spec, prereleases) - - warnings.warn( - "Creating a LegacyVersion has been deprecated and will be " - "removed in the next major release", - DeprecationWarning, - ) - - def _coerce_version(self, version: UnparsedVersion) -> LegacyVersion: - if not isinstance(version, LegacyVersion): - version = LegacyVersion(str(version)) - return version - - def _compare_equal(self, prospective: LegacyVersion, spec: str) -> bool: - return prospective == self._coerce_version(spec) - - def _compare_not_equal(self, prospective: LegacyVersion, spec: str) -> bool: - return prospective != self._coerce_version(spec) - - def _compare_less_than_equal(self, prospective: LegacyVersion, spec: str) -> bool: - return prospective <= self._coerce_version(spec) - - def _compare_greater_than_equal( - self, prospective: LegacyVersion, spec: str - ) -> bool: - return prospective >= self._coerce_version(spec) - - def _compare_less_than(self, prospective: LegacyVersion, spec: str) -> bool: - return prospective < self._coerce_version(spec) - - def _compare_greater_than(self, prospective: LegacyVersion, spec: str) -> bool: - return prospective > self._coerce_version(spec) +class Specifier(BaseSpecifier): + """This class abstracts handling of version specifiers. + .. tip:: -def _require_version_compare( - fn: Callable[["Specifier", ParsedVersion, str], bool] -) -> Callable[["Specifier", ParsedVersion, str], bool]: - @functools.wraps(fn) - def wrapped(self: "Specifier", prospective: ParsedVersion, spec: str) -> bool: - if not isinstance(prospective, Version): - return False - return fn(self, prospective, spec) - - return wrapped - - -class Specifier(_IndividualSpecifier): + It is generally not required to instantiate this manually. You should instead + prefer to work with :class:`SpecifierSet` instead, which can parse + comma-separated version specifiers (which is what package metadata contains). + """ - _regex_str = r""" + _operator_regex_str = r""" (?P(~=|==|!=|<=|>=|<|>|===)) + """ + _version_regex_str = r""" (?P (?: # The identity operators allow for an escape hatch that will @@ -309,8 +119,10 @@ class Specifier(_IndividualSpecifier): # but included entirely as an escape hatch. (?<====) # Only match for the identity operator \s* - [^\s]* # We just match everything, except for whitespace - # since we are only testing for strict identity. + [^\s;)]* # The arbitrary version can be just about anything, + # we match everything except for whitespace, a + # semi-colon for marker support, and a closing paren + # since versions can be enclosed in them. ) | (?: @@ -323,23 +135,23 @@ class Specifier(_IndividualSpecifier): v? (?:[0-9]+!)? # epoch [0-9]+(?:\.[0-9]+)* # release - (?: # pre release - [-_\.]? - (a|b|c|rc|alpha|beta|pre|preview) - [-_\.]? - [0-9]* - )? - (?: # post release - (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) - )? - # You cannot use a wild card and a dev or local version - # together so group them with a | and make them optional. + # You cannot use a wild card and a pre-release, post-release, a dev or + # local version together so group them with a | and make them optional. (?: + \.\* # Wild card syntax of .* + | + (?: # pre release + [-_\.]? + (alpha|beta|preview|pre|a|b|c|rc) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local - | - \.\* # Wild card syntax of .* )? ) | @@ -354,7 +166,7 @@ class Specifier(_IndividualSpecifier): [0-9]+(?:\.[0-9]+)+ # release (We have a + instead of a *) (?: # pre release [-_\.]? - (a|b|c|rc|alpha|beta|pre|preview) + (alpha|beta|preview|pre|a|b|c|rc) [-_\.]? [0-9]* )? @@ -379,7 +191,7 @@ class Specifier(_IndividualSpecifier): [0-9]+(?:\.[0-9]+)* # release (?: # pre release [-_\.]? - (a|b|c|rc|alpha|beta|pre|preview) + (alpha|beta|preview|pre|a|b|c|rc) [-_\.]? [0-9]* )? @@ -391,7 +203,10 @@ class Specifier(_IndividualSpecifier): ) """ - _regex = re.compile(r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) + _regex = re.compile( + r"^\s*" + _operator_regex_str + _version_regex_str + r"\s*$", + re.VERBOSE | re.IGNORECASE, + ) _operators = { "~=": "compatible", @@ -404,9 +219,153 @@ class Specifier(_IndividualSpecifier): "===": "arbitrary", } - @_require_version_compare - def _compare_compatible(self, prospective: ParsedVersion, spec: str) -> bool: + def __init__(self, spec: str = "", prereleases: bool | None = None) -> None: + """Initialize a Specifier instance. + + :param spec: + The string representation of a specifier which will be parsed and + normalized before use. + :param prereleases: + This tells the specifier if it should accept prerelease versions if + applicable or not. The default of ``None`` will autodetect it from the + given specifiers. + :raises InvalidSpecifier: + If the given specifier is invalid (i.e. bad syntax). + """ + match = self._regex.search(spec) + if not match: + raise InvalidSpecifier(f"Invalid specifier: '{spec}'") + + self._spec: tuple[str, str] = ( + match.group("operator").strip(), + match.group("version").strip(), + ) + + # Store whether or not this Specifier should accept prereleases + self._prereleases = prereleases + + # https://github.com/python/mypy/pull/13475#pullrequestreview-1079784515 + @property # type: ignore[override] + def prereleases(self) -> bool: + # If there is an explicit prereleases set for this, then we'll just + # blindly use that. + if self._prereleases is not None: + return self._prereleases + + # Look at all of our specifiers and determine if they are inclusive + # operators, and if they are if they are including an explicit + # prerelease. + operator, version = self._spec + if operator in ["==", ">=", "<=", "~=", "==="]: + # The == specifier can include a trailing .*, if it does we + # want to remove before parsing. + if operator == "==" and version.endswith(".*"): + version = version[:-2] + + # Parse the version, and if it is a pre-release than this + # specifier allows pre-releases. + if Version(version).is_prerelease: + return True + + return False + + @prereleases.setter + def prereleases(self, value: bool) -> None: + self._prereleases = value + + @property + def operator(self) -> str: + """The operator of this specifier. + + >>> Specifier("==1.2.3").operator + '==' + """ + return self._spec[0] + + @property + def version(self) -> str: + """The version of this specifier. + + >>> Specifier("==1.2.3").version + '1.2.3' + """ + return self._spec[1] + def __repr__(self) -> str: + """A representation of the Specifier that shows all internal state. + + >>> Specifier('>=1.0.0') + =1.0.0')> + >>> Specifier('>=1.0.0', prereleases=False) + =1.0.0', prereleases=False)> + >>> Specifier('>=1.0.0', prereleases=True) + =1.0.0', prereleases=True)> + """ + pre = ( + f", prereleases={self.prereleases!r}" + if self._prereleases is not None + else "" + ) + + return f"<{self.__class__.__name__}({str(self)!r}{pre})>" + + def __str__(self) -> str: + """A string representation of the Specifier that can be round-tripped. + + >>> str(Specifier('>=1.0.0')) + '>=1.0.0' + >>> str(Specifier('>=1.0.0', prereleases=False)) + '>=1.0.0' + """ + return "{}{}".format(*self._spec) + + @property + def _canonical_spec(self) -> tuple[str, str]: + canonical_version = canonicalize_version( + self._spec[1], + strip_trailing_zero=(self._spec[0] != "~="), + ) + return self._spec[0], canonical_version + + def __hash__(self) -> int: + return hash(self._canonical_spec) + + def __eq__(self, other: object) -> bool: + """Whether or not the two Specifier-like objects are equal. + + :param other: The other object to check against. + + The value of :attr:`prereleases` is ignored. + + >>> Specifier("==1.2.3") == Specifier("== 1.2.3.0") + True + >>> (Specifier("==1.2.3", prereleases=False) == + ... Specifier("==1.2.3", prereleases=True)) + True + >>> Specifier("==1.2.3") == "==1.2.3" + True + >>> Specifier("==1.2.3") == Specifier("==1.2.4") + False + >>> Specifier("==1.2.3") == Specifier("~=1.2.3") + False + """ + if isinstance(other, str): + try: + other = self.__class__(str(other)) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._canonical_spec == other._canonical_spec + + def _get_operator(self, op: str) -> CallableOperator: + operator_callable: CallableOperator = getattr( + self, f"_compare_{self._operators[op]}" + ) + return operator_callable + + def _compare_compatible(self, prospective: Version, spec: str) -> bool: # Compatible releases have an equivalent combination of >= and ==. That # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to # implement this in terms of the other specifiers instead of @@ -415,7 +374,7 @@ def _compare_compatible(self, prospective: ParsedVersion, spec: str) -> bool: # We want everything but the last item in the version, but we want to # ignore suffix segments. - prefix = ".".join( + prefix = _version_join( list(itertools.takewhile(_is_not_suffix, _version_split(spec)))[:-1] ) @@ -426,34 +385,34 @@ def _compare_compatible(self, prospective: ParsedVersion, spec: str) -> bool: prospective, prefix ) - @_require_version_compare - def _compare_equal(self, prospective: ParsedVersion, spec: str) -> bool: - + def _compare_equal(self, prospective: Version, spec: str) -> bool: # We need special logic to handle prefix matching if spec.endswith(".*"): # In the case of prefix matching we want to ignore local segment. - prospective = Version(prospective.public) - # Split the spec out by dots, and pretend that there is an implicit - # dot in between a release segment and a pre-release segment. - split_spec = _version_split(spec[:-2]) # Remove the trailing .* + normalized_prospective = canonicalize_version( + prospective.public, strip_trailing_zero=False + ) + # Get the normalized version string ignoring the trailing .* + normalized_spec = canonicalize_version(spec[:-2], strip_trailing_zero=False) + # Split the spec out by bangs and dots, and pretend that there is + # an implicit dot in between a release segment and a pre-release segment. + split_spec = _version_split(normalized_spec) - # Split the prospective version out by dots, and pretend that there - # is an implicit dot in between a release segment and a pre-release - # segment. - split_prospective = _version_split(str(prospective)) + # Split the prospective version out by bangs and dots, and pretend + # that there is an implicit dot in between a release segment and + # a pre-release segment. + split_prospective = _version_split(normalized_prospective) + + # 0-pad the prospective version before shortening it to get the correct + # shortened version. + padded_prospective, _ = _pad_version(split_prospective, split_spec) # Shorten the prospective version to be the same length as the spec # so that we can determine if the specifier is a prefix of the # prospective version or not. - shortened_prospective = split_prospective[: len(split_spec)] - - # Pad out our two sides with zeros so that they both equal the same - # length. - padded_spec, padded_prospective = _pad_version( - split_spec, shortened_prospective - ) + shortened_prospective = padded_prospective[: len(split_spec)] - return padded_prospective == padded_spec + return shortened_prospective == split_spec else: # Convert our spec string into a Version spec_version = Version(spec) @@ -466,31 +425,22 @@ def _compare_equal(self, prospective: ParsedVersion, spec: str) -> bool: return prospective == spec_version - @_require_version_compare - def _compare_not_equal(self, prospective: ParsedVersion, spec: str) -> bool: + def _compare_not_equal(self, prospective: Version, spec: str) -> bool: return not self._compare_equal(prospective, spec) - @_require_version_compare - def _compare_less_than_equal(self, prospective: ParsedVersion, spec: str) -> bool: - + def _compare_less_than_equal(self, prospective: Version, spec: str) -> bool: # NB: Local version identifiers are NOT permitted in the version # specifier, so local version labels can be universally removed from # the prospective version. return Version(prospective.public) <= Version(spec) - @_require_version_compare - def _compare_greater_than_equal( - self, prospective: ParsedVersion, spec: str - ) -> bool: - + def _compare_greater_than_equal(self, prospective: Version, spec: str) -> bool: # NB: Local version identifiers are NOT permitted in the version # specifier, so local version labels can be universally removed from # the prospective version. return Version(prospective.public) >= Version(spec) - @_require_version_compare - def _compare_less_than(self, prospective: ParsedVersion, spec_str: str) -> bool: - + def _compare_less_than(self, prospective: Version, spec_str: str) -> bool: # Convert our spec to a Version instance, since we'll want to work with # it as a version. spec = Version(spec_str) @@ -514,9 +464,7 @@ def _compare_less_than(self, prospective: ParsedVersion, spec_str: str) -> bool: # version in the spec. return True - @_require_version_compare - def _compare_greater_than(self, prospective: ParsedVersion, spec_str: str) -> bool: - + def _compare_greater_than(self, prospective: Version, spec_str: str) -> bool: # Convert our spec to a Version instance, since we'll want to work with # it as a version. spec = Version(spec_str) @@ -549,42 +497,150 @@ def _compare_greater_than(self, prospective: ParsedVersion, spec_str: str) -> bo def _compare_arbitrary(self, prospective: Version, spec: str) -> bool: return str(prospective).lower() == str(spec).lower() - @property - def prereleases(self) -> bool: + def __contains__(self, item: str | Version) -> bool: + """Return whether or not the item is contained in this specifier. - # If there is an explicit prereleases set for this, then we'll just - # blindly use that. - if self._prereleases is not None: - return self._prereleases + :param item: The item to check for. - # Look at all of our specifiers and determine if they are inclusive - # operators, and if they are if they are including an explicit - # prerelease. - operator, version = self._spec - if operator in ["==", ">=", "<=", "~=", "==="]: - # The == specifier can include a trailing .*, if it does we - # want to remove before parsing. - if operator == "==" and version.endswith(".*"): - version = version[:-2] + This is used for the ``in`` operator and behaves the same as + :meth:`contains` with no ``prereleases`` argument passed. - # Parse the version, and if it is a pre-release than this - # specifier allows pre-releases. - if parse(version).is_prerelease: - return True + >>> "1.2.3" in Specifier(">=1.2.3") + True + >>> Version("1.2.3") in Specifier(">=1.2.3") + True + >>> "1.0.0" in Specifier(">=1.2.3") + False + >>> "1.3.0a1" in Specifier(">=1.2.3") + False + >>> "1.3.0a1" in Specifier(">=1.2.3", prereleases=True) + True + """ + return self.contains(item) - return False + def contains(self, item: UnparsedVersion, prereleases: bool | None = None) -> bool: + """Return whether or not the item is contained in this specifier. + + :param item: + The item to check for, which can be a version string or a + :class:`Version` instance. + :param prereleases: + Whether or not to match prereleases with this Specifier. If set to + ``None`` (the default), it uses :attr:`prereleases` to determine + whether or not prereleases are allowed. + + >>> Specifier(">=1.2.3").contains("1.2.3") + True + >>> Specifier(">=1.2.3").contains(Version("1.2.3")) + True + >>> Specifier(">=1.2.3").contains("1.0.0") + False + >>> Specifier(">=1.2.3").contains("1.3.0a1") + False + >>> Specifier(">=1.2.3", prereleases=True).contains("1.3.0a1") + True + >>> Specifier(">=1.2.3").contains("1.3.0a1", prereleases=True) + True + """ - @prereleases.setter - def prereleases(self, value: bool) -> None: - self._prereleases = value + # Determine if prereleases are to be allowed or not. + if prereleases is None: + prereleases = self.prereleases + + # Normalize item to a Version, this allows us to have a shortcut for + # "2.0" in Specifier(">=2") + normalized_item = _coerce_version(item) + + # Determine if we should be supporting prereleases in this specifier + # or not, if we do not support prereleases than we can short circuit + # logic if this version is a prereleases. + if normalized_item.is_prerelease and not prereleases: + return False + + # Actually do the comparison to determine if this item is contained + # within this Specifier or not. + operator_callable: CallableOperator = self._get_operator(self.operator) + return operator_callable(normalized_item, self.version) + + def filter( + self, iterable: Iterable[UnparsedVersionVar], prereleases: bool | None = None + ) -> Iterator[UnparsedVersionVar]: + """Filter items in the given iterable, that match the specifier. + + :param iterable: + An iterable that can contain version strings and :class:`Version` instances. + The items in the iterable will be filtered according to the specifier. + :param prereleases: + Whether or not to allow prereleases in the returned iterator. If set to + ``None`` (the default), it will be intelligently decide whether to allow + prereleases or not (based on the :attr:`prereleases` attribute, and + whether the only versions matching are prereleases). + + This method is smarter than just ``filter(Specifier().contains, [...])`` + because it implements the rule from :pep:`440` that a prerelease item + SHOULD be accepted if no other versions match the given specifier. + + >>> list(Specifier(">=1.2.3").filter(["1.2", "1.3", "1.5a1"])) + ['1.3'] + >>> list(Specifier(">=1.2.3").filter(["1.2", "1.2.3", "1.3", Version("1.4")])) + ['1.2.3', '1.3', ] + >>> list(Specifier(">=1.2.3").filter(["1.2", "1.5a1"])) + ['1.5a1'] + >>> list(Specifier(">=1.2.3").filter(["1.3", "1.5a1"], prereleases=True)) + ['1.3', '1.5a1'] + >>> list(Specifier(">=1.2.3", prereleases=True).filter(["1.3", "1.5a1"])) + ['1.3', '1.5a1'] + """ + + yielded = False + found_prereleases = [] + + kw = {"prereleases": prereleases if prereleases is not None else True} + + # Attempt to iterate over all the values in the iterable and if any of + # them match, yield them. + for version in iterable: + parsed_version = _coerce_version(version) + + if self.contains(parsed_version, **kw): + # If our version is a prerelease, and we were not set to allow + # prereleases, then we'll store it for later in case nothing + # else matches this specifier. + if parsed_version.is_prerelease and not ( + prereleases or self.prereleases + ): + found_prereleases.append(version) + # Either this is not a prerelease, or we should have been + # accepting prereleases from the beginning. + else: + yielded = True + yield version + + # Now that we've iterated over everything, determine if we've yielded + # any values, and if we have not and we have any prereleases stored up + # then we will go ahead and yield the prereleases. + if not yielded and found_prereleases: + for version in found_prereleases: + yield version _prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$") -def _version_split(version: str) -> List[str]: - result: List[str] = [] - for item in version.split("."): +def _version_split(version: str) -> list[str]: + """Split version into components. + + The split components are intended for version comparison. The logic does + not attempt to retain the original version string, so joining the + components back with :func:`_version_join` may not produce the original + version string. + """ + result: list[str] = [] + + epoch, _, rest = version.rpartition("!") + result.append(epoch or "0") + + for item in rest.split("."): match = _prefix_regex.search(item) if match: result.extend(match.groups()) @@ -593,13 +649,24 @@ def _version_split(version: str) -> List[str]: return result +def _version_join(components: list[str]) -> str: + """Join split version components into a version string. + + This function assumes the input came from :func:`_version_split`, where the + first component must be the epoch (either empty or numeric), and all other + components numeric. + """ + epoch, *rest = components + return f"{epoch}!{'.'.join(rest)}" + + def _is_not_suffix(segment: str) -> bool: return not any( segment.startswith(prefix) for prefix in ("dev", "a", "b", "rc", "post") ) -def _pad_version(left: List[str], right: List[str]) -> Tuple[List[str], List[str]]: +def _pad_version(left: list[str], right: list[str]) -> tuple[list[str], list[str]]: left_split, right_split = [], [] # Get the release segment of our versions @@ -614,35 +681,80 @@ def _pad_version(left: List[str], right: List[str]) -> Tuple[List[str], List[str left_split.insert(1, ["0"] * max(0, len(right_split[0]) - len(left_split[0]))) right_split.insert(1, ["0"] * max(0, len(left_split[0]) - len(right_split[0]))) - return (list(itertools.chain(*left_split)), list(itertools.chain(*right_split))) + return ( + list(itertools.chain.from_iterable(left_split)), + list(itertools.chain.from_iterable(right_split)), + ) class SpecifierSet(BaseSpecifier): - def __init__( - self, specifiers: str = "", prereleases: Optional[bool] = None - ) -> None: + """This class abstracts handling of a set of version specifiers. + + It can be passed a single specifier (``>=3.0``), a comma-separated list of + specifiers (``>=3.0,!=3.1``), or no specifier at all. + """ + + def __init__(self, specifiers: str = "", prereleases: bool | None = None) -> None: + """Initialize a SpecifierSet instance. + + :param specifiers: + The string representation of a specifier or a comma-separated list of + specifiers which will be parsed and normalized before use. + :param prereleases: + This tells the SpecifierSet if it should accept prerelease versions if + applicable or not. The default of ``None`` will autodetect it from the + given specifiers. + + :raises InvalidSpecifier: + If the given ``specifiers`` are not parseable than this exception will be + raised. + """ - # Split on , to break each individual specifier into it's own item, and + # Split on `,` to break each individual specifier into it's own item, and # strip each item to remove leading/trailing whitespace. split_specifiers = [s.strip() for s in specifiers.split(",") if s.strip()] - # Parsed each individual specifier, attempting first to make it a - # Specifier and falling back to a LegacySpecifier. - parsed: Set[_IndividualSpecifier] = set() - for specifier in split_specifiers: - try: - parsed.add(Specifier(specifier)) - except InvalidSpecifier: - parsed.add(LegacySpecifier(specifier)) - - # Turn our parsed specifiers into a frozen set and save them for later. - self._specs = frozenset(parsed) + # Make each individual specifier a Specifier and save in a frozen set for later. + self._specs = frozenset(map(Specifier, split_specifiers)) # Store our prereleases value so we can use it later to determine if # we accept prereleases or not. self._prereleases = prereleases + @property + def prereleases(self) -> bool | None: + # If we have been given an explicit prerelease modifier, then we'll + # pass that through here. + if self._prereleases is not None: + return self._prereleases + + # If we don't have any specifiers, and we don't have a forced value, + # then we'll just return None since we don't know if this should have + # pre-releases or not. + if not self._specs: + return None + + # Otherwise we'll see if any of the given specifiers accept + # prereleases, if any of them do we'll return True, otherwise False. + return any(s.prereleases for s in self._specs) + + @prereleases.setter + def prereleases(self, value: bool) -> None: + self._prereleases = value + def __repr__(self) -> str: + """A representation of the specifier set that shows all internal state. + + Note that the ordering of the individual specifiers within the set may not + match the input string. + + >>> SpecifierSet('>=1.0.0,!=2.0.0') + =1.0.0')> + >>> SpecifierSet('>=1.0.0,!=2.0.0', prereleases=False) + =1.0.0', prereleases=False)> + >>> SpecifierSet('>=1.0.0,!=2.0.0', prereleases=True) + =1.0.0', prereleases=True)> + """ pre = ( f", prereleases={self.prereleases!r}" if self._prereleases is not None @@ -652,12 +764,31 @@ def __repr__(self) -> str: return f"" def __str__(self) -> str: + """A string representation of the specifier set that can be round-tripped. + + Note that the ordering of the individual specifiers within the set may not + match the input string. + + >>> str(SpecifierSet(">=1.0.0,!=1.0.1")) + '!=1.0.1,>=1.0.0' + >>> str(SpecifierSet(">=1.0.0,!=1.0.1", prereleases=False)) + '!=1.0.1,>=1.0.0' + """ return ",".join(sorted(str(s) for s in self._specs)) def __hash__(self) -> int: return hash(self._specs) - def __and__(self, other: Union["SpecifierSet", str]) -> "SpecifierSet": + def __and__(self, other: SpecifierSet | str) -> SpecifierSet: + """Return a SpecifierSet which is a combination of the two sets. + + :param other: The other object to combine with. + + >>> SpecifierSet(">=1.0.0,!=1.0.1") & '<=2.0.0,!=2.0.1' + =1.0.0')> + >>> SpecifierSet(">=1.0.0,!=1.0.1") & SpecifierSet('<=2.0.0,!=2.0.1') + =1.0.0')> + """ if isinstance(other, str): other = SpecifierSet(other) elif not isinstance(other, SpecifierSet): @@ -681,7 +812,25 @@ def __and__(self, other: Union["SpecifierSet", str]) -> "SpecifierSet": return specifier def __eq__(self, other: object) -> bool: - if isinstance(other, (str, _IndividualSpecifier)): + """Whether or not the two SpecifierSet-like objects are equal. + + :param other: The other object to check against. + + The value of :attr:`prereleases` is ignored. + + >>> SpecifierSet(">=1.0.0,!=1.0.1") == SpecifierSet(">=1.0.0,!=1.0.1") + True + >>> (SpecifierSet(">=1.0.0,!=1.0.1", prereleases=False) == + ... SpecifierSet(">=1.0.0,!=1.0.1", prereleases=True)) + True + >>> SpecifierSet(">=1.0.0,!=1.0.1") == ">=1.0.0,!=1.0.1" + True + >>> SpecifierSet(">=1.0.0,!=1.0.1") == SpecifierSet(">=1.0.0") + False + >>> SpecifierSet(">=1.0.0,!=1.0.1") == SpecifierSet(">=1.0.0,!=1.0.2") + False + """ + if isinstance(other, (str, Specifier)): other = SpecifierSet(str(other)) elif not isinstance(other, SpecifierSet): return NotImplemented @@ -689,43 +838,72 @@ def __eq__(self, other: object) -> bool: return self._specs == other._specs def __len__(self) -> int: + """Returns the number of specifiers in this specifier set.""" return len(self._specs) - def __iter__(self) -> Iterator[_IndividualSpecifier]: - return iter(self._specs) - - @property - def prereleases(self) -> Optional[bool]: - - # If we have been given an explicit prerelease modifier, then we'll - # pass that through here. - if self._prereleases is not None: - return self._prereleases - - # If we don't have any specifiers, and we don't have a forced value, - # then we'll just return None since we don't know if this should have - # pre-releases or not. - if not self._specs: - return None - - # Otherwise we'll see if any of the given specifiers accept - # prereleases, if any of them do we'll return True, otherwise False. - return any(s.prereleases for s in self._specs) + def __iter__(self) -> Iterator[Specifier]: + """ + Returns an iterator over all the underlying :class:`Specifier` instances + in this specifier set. - @prereleases.setter - def prereleases(self, value: bool) -> None: - self._prereleases = value + >>> sorted(SpecifierSet(">=1.0.0,!=1.0.1"), key=str) + [, =1.0.0')>] + """ + return iter(self._specs) def __contains__(self, item: UnparsedVersion) -> bool: + """Return whether or not the item is contained in this specifier. + + :param item: The item to check for. + + This is used for the ``in`` operator and behaves the same as + :meth:`contains` with no ``prereleases`` argument passed. + + >>> "1.2.3" in SpecifierSet(">=1.0.0,!=1.0.1") + True + >>> Version("1.2.3") in SpecifierSet(">=1.0.0,!=1.0.1") + True + >>> "1.0.1" in SpecifierSet(">=1.0.0,!=1.0.1") + False + >>> "1.3.0a1" in SpecifierSet(">=1.0.0,!=1.0.1") + False + >>> "1.3.0a1" in SpecifierSet(">=1.0.0,!=1.0.1", prereleases=True) + True + """ return self.contains(item) def contains( - self, item: UnparsedVersion, prereleases: Optional[bool] = None + self, + item: UnparsedVersion, + prereleases: bool | None = None, + installed: bool | None = None, ) -> bool: - - # Ensure that our item is a Version or LegacyVersion instance. - if not isinstance(item, (LegacyVersion, Version)): - item = parse(item) + """Return whether or not the item is contained in this SpecifierSet. + + :param item: + The item to check for, which can be a version string or a + :class:`Version` instance. + :param prereleases: + Whether or not to match prereleases with this SpecifierSet. If set to + ``None`` (the default), it uses :attr:`prereleases` to determine + whether or not prereleases are allowed. + + >>> SpecifierSet(">=1.0.0,!=1.0.1").contains("1.2.3") + True + >>> SpecifierSet(">=1.0.0,!=1.0.1").contains(Version("1.2.3")) + True + >>> SpecifierSet(">=1.0.0,!=1.0.1").contains("1.0.1") + False + >>> SpecifierSet(">=1.0.0,!=1.0.1").contains("1.3.0a1") + False + >>> SpecifierSet(">=1.0.0,!=1.0.1", prereleases=True).contains("1.3.0a1") + True + >>> SpecifierSet(">=1.0.0,!=1.0.1").contains("1.3.0a1", prereleases=True) + True + """ + # Ensure that our item is a Version instance. + if not isinstance(item, Version): + item = Version(item) # Determine if we're forcing a prerelease or not, if we're not forcing # one for this particular filter call, then we'll use whatever the @@ -742,6 +920,9 @@ def contains( if not prereleases and item.is_prerelease: return False + if installed and item.is_prerelease: + item = Version(item.base_version) + # We simply dispatch to the underlying specs here to make sure that the # given version is contained within all of them. # Note: This use of all() here means that an empty set of specifiers @@ -749,9 +930,46 @@ def contains( return all(s.contains(item, prereleases=prereleases) for s in self._specs) def filter( - self, iterable: Iterable[VersionTypeVar], prereleases: Optional[bool] = None - ) -> Iterable[VersionTypeVar]: - + self, iterable: Iterable[UnparsedVersionVar], prereleases: bool | None = None + ) -> Iterator[UnparsedVersionVar]: + """Filter items in the given iterable, that match the specifiers in this set. + + :param iterable: + An iterable that can contain version strings and :class:`Version` instances. + The items in the iterable will be filtered according to the specifier. + :param prereleases: + Whether or not to allow prereleases in the returned iterator. If set to + ``None`` (the default), it will be intelligently decide whether to allow + prereleases or not (based on the :attr:`prereleases` attribute, and + whether the only versions matching are prereleases). + + This method is smarter than just ``filter(SpecifierSet(...).contains, [...])`` + because it implements the rule from :pep:`440` that a prerelease item + SHOULD be accepted if no other versions match the given specifier. + + >>> list(SpecifierSet(">=1.2.3").filter(["1.2", "1.3", "1.5a1"])) + ['1.3'] + >>> list(SpecifierSet(">=1.2.3").filter(["1.2", "1.3", Version("1.4")])) + ['1.3', ] + >>> list(SpecifierSet(">=1.2.3").filter(["1.2", "1.5a1"])) + [] + >>> list(SpecifierSet(">=1.2.3").filter(["1.3", "1.5a1"], prereleases=True)) + ['1.3', '1.5a1'] + >>> list(SpecifierSet(">=1.2.3", prereleases=True).filter(["1.3", "1.5a1"])) + ['1.3', '1.5a1'] + + An "empty" SpecifierSet will filter items based on the presence of prerelease + versions in the set. + + >>> list(SpecifierSet("").filter(["1.3", "1.5a1"])) + ['1.3'] + >>> list(SpecifierSet("").filter(["1.5a1"])) + ['1.5a1'] + >>> list(SpecifierSet("", prereleases=True).filter(["1.3", "1.5a1"])) + ['1.3', '1.5a1'] + >>> list(SpecifierSet("").filter(["1.3", "1.5a1"], prereleases=True)) + ['1.3', '1.5a1'] + """ # Determine if we're forcing a prerelease or not, if we're not forcing # one for this particular filter call, then we'll use whatever the # SpecifierSet thinks for whether or not we should support prereleases. @@ -764,27 +982,16 @@ def filter( if self._specs: for spec in self._specs: iterable = spec.filter(iterable, prereleases=bool(prereleases)) - return iterable + return iter(iterable) # If we do not have any specifiers, then we need to have a rough filter # which will filter out any pre-releases, unless there are no final - # releases, and which will filter out LegacyVersion in general. + # releases. else: - filtered: List[VersionTypeVar] = [] - found_prereleases: List[VersionTypeVar] = [] - - item: UnparsedVersion - parsed_version: Union[Version, LegacyVersion] + filtered: list[UnparsedVersionVar] = [] + found_prereleases: list[UnparsedVersionVar] = [] for item in iterable: - # Ensure that we some kind of Version class for this item. - if not isinstance(item, (LegacyVersion, Version)): - parsed_version = parse(item) - else: - parsed_version = item - - # Filter out any item which is parsed as a LegacyVersion - if isinstance(parsed_version, LegacyVersion): - continue + parsed_version = _coerce_version(item) # Store any item which is a pre-release for later unless we've # already found a final version or we are accepting prereleases @@ -797,6 +1004,6 @@ def filter( # If we've found no items except for pre-releases, then we'll go # ahead and use the pre-releases if not filtered and found_prereleases and prereleases is None: - return found_prereleases + return iter(found_prereleases) - return filtered + return iter(filtered) diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/tags.py b/myenv/Lib/site-packages/pip/_vendor/packaging/tags.py index 9a3d25a..6667d29 100644 --- a/myenv/Lib/site-packages/pip/_vendor/packaging/tags.py +++ b/myenv/Lib/site-packages/pip/_vendor/packaging/tags.py @@ -2,21 +2,21 @@ # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. +from __future__ import annotations + import logging import platform +import re +import struct +import subprocess import sys import sysconfig from importlib.machinery import EXTENSION_SUFFIXES from typing import ( - Dict, - FrozenSet, Iterable, Iterator, - List, - Optional, Sequence, Tuple, - Union, cast, ) @@ -27,7 +27,7 @@ PythonVersion = Sequence[int] MacVersion = Tuple[int, int] -INTERPRETER_SHORT_NAMES: Dict[str, str] = { +INTERPRETER_SHORT_NAMES: dict[str, str] = { "python": "py", # Generic. "cpython": "cp", "pypy": "pp", @@ -36,7 +36,7 @@ } -_32_BIT_INTERPRETER = sys.maxsize <= 2 ** 32 +_32_BIT_INTERPRETER = struct.calcsize("P") == 4 class Tag: @@ -93,7 +93,7 @@ def __repr__(self) -> str: return f"<{self} @ {id(self)}>" -def parse_tag(tag: str) -> FrozenSet[Tag]: +def parse_tag(tag: str) -> frozenset[Tag]: """ Parses the provided tag (e.g. `py3-none-any`) into a frozenset of Tag instances. @@ -109,8 +109,8 @@ def parse_tag(tag: str) -> FrozenSet[Tag]: return frozenset(tags) -def _get_config_var(name: str, warn: bool = False) -> Union[int, str, None]: - value = sysconfig.get_config_var(name) +def _get_config_var(name: str, warn: bool = False) -> int | str | None: + value: int | str | None = sysconfig.get_config_var(name) if value is None and warn: logger.debug( "Config variable '%s' is unset, Python ABI tag may be incorrect", name @@ -119,23 +119,40 @@ def _get_config_var(name: str, warn: bool = False) -> Union[int, str, None]: def _normalize_string(string: str) -> str: - return string.replace(".", "_").replace("-", "_") + return string.replace(".", "_").replace("-", "_").replace(" ", "_") + +def _is_threaded_cpython(abis: list[str]) -> bool: + """ + Determine if the ABI corresponds to a threaded (`--disable-gil`) build. -def _abi3_applies(python_version: PythonVersion) -> bool: + The threaded builds are indicated by a "t" in the abiflags. + """ + if len(abis) == 0: + return False + # expect e.g., cp313 + m = re.match(r"cp\d+(.*)", abis[0]) + if not m: + return False + abiflags = m.group(1) + return "t" in abiflags + + +def _abi3_applies(python_version: PythonVersion, threading: bool) -> bool: """ Determine if the Python version supports abi3. - PEP 384 was first implemented in Python 3.2. + PEP 384 was first implemented in Python 3.2. The threaded (`--disable-gil`) + builds do not support abi3. """ - return len(python_version) > 1 and tuple(python_version) >= (3, 2) + return len(python_version) > 1 and tuple(python_version) >= (3, 2) and not threading -def _cpython_abis(py_version: PythonVersion, warn: bool = False) -> List[str]: +def _cpython_abis(py_version: PythonVersion, warn: bool = False) -> list[str]: py_version = tuple(py_version) # To allow for version comparison. abis = [] version = _version_nodot(py_version[:2]) - debug = pymalloc = ucs4 = "" + threading = debug = pymalloc = ucs4 = "" with_debug = _get_config_var("Py_DEBUG", warn) has_refcount = hasattr(sys, "gettotalrefcount") # Windows doesn't set Py_DEBUG, so checking for support of debug-compiled @@ -144,6 +161,8 @@ def _cpython_abis(py_version: PythonVersion, warn: bool = False) -> List[str]: has_ext = "_d.pyd" in EXTENSION_SUFFIXES if with_debug or (with_debug is None and (has_refcount or has_ext)): debug = "d" + if py_version >= (3, 13) and _get_config_var("Py_GIL_DISABLED", warn): + threading = "t" if py_version < (3, 8): with_pymalloc = _get_config_var("WITH_PYMALLOC", warn) if with_pymalloc or with_pymalloc is None: @@ -157,20 +176,15 @@ def _cpython_abis(py_version: PythonVersion, warn: bool = False) -> List[str]: elif debug: # Debug builds can also load "normal" extension modules. # We can also assume no UCS-4 or pymalloc requirement. - abis.append(f"cp{version}") - abis.insert( - 0, - "cp{version}{debug}{pymalloc}{ucs4}".format( - version=version, debug=debug, pymalloc=pymalloc, ucs4=ucs4 - ), - ) + abis.append(f"cp{version}{threading}") + abis.insert(0, f"cp{version}{threading}{debug}{pymalloc}{ucs4}") return abis def cpython_tags( - python_version: Optional[PythonVersion] = None, - abis: Optional[Iterable[str]] = None, - platforms: Optional[Iterable[str]] = None, + python_version: PythonVersion | None = None, + abis: Iterable[str] | None = None, + platforms: Iterable[str] | None = None, *, warn: bool = False, ) -> Iterator[Tag]: @@ -211,11 +225,14 @@ def cpython_tags( for abi in abis: for platform_ in platforms: yield Tag(interpreter, abi, platform_) - if _abi3_applies(python_version): + + threading = _is_threaded_cpython(abis) + use_abi3 = _abi3_applies(python_version, threading) + if use_abi3: yield from (Tag(interpreter, "abi3", platform_) for platform_ in platforms) yield from (Tag(interpreter, "none", platform_) for platform_ in platforms) - if _abi3_applies(python_version): + if use_abi3: for minor_version in range(python_version[1] - 1, 1, -1): for platform_ in platforms: interpreter = "cp{version}".format( @@ -224,16 +241,51 @@ def cpython_tags( yield Tag(interpreter, "abi3", platform_) -def _generic_abi() -> Iterator[str]: - abi = sysconfig.get_config_var("SOABI") - if abi: - yield _normalize_string(abi) +def _generic_abi() -> list[str]: + """ + Return the ABI tag based on EXT_SUFFIX. + """ + # The following are examples of `EXT_SUFFIX`. + # We want to keep the parts which are related to the ABI and remove the + # parts which are related to the platform: + # - linux: '.cpython-310-x86_64-linux-gnu.so' => cp310 + # - mac: '.cpython-310-darwin.so' => cp310 + # - win: '.cp310-win_amd64.pyd' => cp310 + # - win: '.pyd' => cp37 (uses _cpython_abis()) + # - pypy: '.pypy38-pp73-x86_64-linux-gnu.so' => pypy38_pp73 + # - graalpy: '.graalpy-38-native-x86_64-darwin.dylib' + # => graalpy_38_native + + ext_suffix = _get_config_var("EXT_SUFFIX", warn=True) + if not isinstance(ext_suffix, str) or ext_suffix[0] != ".": + raise SystemError("invalid sysconfig.get_config_var('EXT_SUFFIX')") + parts = ext_suffix.split(".") + if len(parts) < 3: + # CPython3.7 and earlier uses ".pyd" on Windows. + return _cpython_abis(sys.version_info[:2]) + soabi = parts[1] + if soabi.startswith("cpython"): + # non-windows + abi = "cp" + soabi.split("-")[1] + elif soabi.startswith("cp"): + # windows + abi = soabi.split("-")[0] + elif soabi.startswith("pypy"): + abi = "-".join(soabi.split("-")[:2]) + elif soabi.startswith("graalpy"): + abi = "-".join(soabi.split("-")[:3]) + elif soabi: + # pyston, ironpython, others? + abi = soabi + else: + return [] + return [_normalize_string(abi)] def generic_tags( - interpreter: Optional[str] = None, - abis: Optional[Iterable[str]] = None, - platforms: Optional[Iterable[str]] = None, + interpreter: str | None = None, + abis: Iterable[str] | None = None, + platforms: Iterable[str] | None = None, *, warn: bool = False, ) -> Iterator[Tag]: @@ -251,8 +303,9 @@ def generic_tags( interpreter = "".join([interp_name, interp_version]) if abis is None: abis = _generic_abi() + else: + abis = list(abis) platforms = list(platforms or platform_tags()) - abis = list(abis) if "none" not in abis: abis.append("none") for abi in abis: @@ -276,9 +329,9 @@ def _py_interpreter_range(py_version: PythonVersion) -> Iterator[str]: def compatible_tags( - python_version: Optional[PythonVersion] = None, - interpreter: Optional[str] = None, - platforms: Optional[Iterable[str]] = None, + python_version: PythonVersion | None = None, + interpreter: str | None = None, + platforms: Iterable[str] | None = None, ) -> Iterator[Tag]: """ Yields the sequence of tags that are compatible with a specific version of Python. @@ -310,7 +363,7 @@ def _mac_arch(arch: str, is_32bit: bool = _32_BIT_INTERPRETER) -> str: return "i386" -def _mac_binary_formats(version: MacVersion, cpu_arch: str) -> List[str]: +def _mac_binary_formats(version: MacVersion, cpu_arch: str) -> list[str]: formats = [cpu_arch] if cpu_arch == "x86_64": if version < (10, 4): @@ -343,7 +396,7 @@ def _mac_binary_formats(version: MacVersion, cpu_arch: str) -> List[str]: def mac_platforms( - version: Optional[MacVersion] = None, arch: Optional[str] = None + version: MacVersion | None = None, arch: str | None = None ) -> Iterator[str]: """ Yields the platform tags for a macOS system. @@ -356,6 +409,22 @@ def mac_platforms( version_str, _, cpu_arch = platform.mac_ver() if version is None: version = cast("MacVersion", tuple(map(int, version_str.split(".")[:2]))) + if version == (10, 16): + # When built against an older macOS SDK, Python will report macOS 10.16 + # instead of the real version. + version_str = subprocess.run( + [ + sys.executable, + "-sS", + "-c", + "import platform; print(platform.mac_ver()[0])", + ], + check=True, + env={"SYSTEM_VERSION_COMPAT": "0"}, + stdout=subprocess.PIPE, + text=True, + ).stdout + version = cast("MacVersion", tuple(map(int, version_str.split(".")[:2]))) else: version = version if arch is None: @@ -416,15 +485,21 @@ def mac_platforms( def _linux_platforms(is_32bit: bool = _32_BIT_INTERPRETER) -> Iterator[str]: linux = _normalize_string(sysconfig.get_platform()) + if not linux.startswith("linux_"): + # we should never be here, just yield the sysconfig one and return + yield linux + return if is_32bit: if linux == "linux_x86_64": linux = "linux_i686" elif linux == "linux_aarch64": - linux = "linux_armv7l" + linux = "linux_armv8l" _, arch = linux.split("_", 1) - yield from _manylinux.platform_tags(linux, arch) - yield from _musllinux.platform_tags(arch) - yield linux + archs = {"armv8l": ["armv8l", "armv7l"]}.get(arch, [arch]) + yield from _manylinux.platform_tags(archs) + yield from _musllinux.platform_tags(archs) + for arch in archs: + yield f"linux_{arch}" def _generic_platforms() -> Iterator[str]: @@ -446,6 +521,9 @@ def platform_tags() -> Iterator[str]: def interpreter_name() -> str: """ Returns the name of the running interpreter. + + Some implementations have a reserved, two-letter abbreviation which will + be returned when appropriate. """ name = sys.implementation.name return INTERPRETER_SHORT_NAMES.get(name) or name @@ -482,6 +560,9 @@ def sys_tags(*, warn: bool = False) -> Iterator[Tag]: yield from generic_tags() if interp_name == "pp": - yield from compatible_tags(interpreter="pp3") + interp = "pp3" + elif interp_name == "cp": + interp = "cp" + interpreter_version(warn=warn) else: - yield from compatible_tags() + interp = None + yield from compatible_tags(interpreter=interp) diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/utils.py b/myenv/Lib/site-packages/pip/_vendor/packaging/utils.py index bab11b8..d33da5b 100644 --- a/myenv/Lib/site-packages/pip/_vendor/packaging/utils.py +++ b/myenv/Lib/site-packages/pip/_vendor/packaging/utils.py @@ -2,8 +2,10 @@ # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. +from __future__ import annotations + import re -from typing import FrozenSet, NewType, Tuple, Union, cast +from typing import NewType, Tuple, Union, cast from .tags import Tag, parse_tag from .version import InvalidVersion, Version @@ -12,6 +14,12 @@ NormalizedName = NewType("NormalizedName", str) +class InvalidName(ValueError): + """ + An invalid distribution name; users should refer to the packaging user guide. + """ + + class InvalidWheelFilename(ValueError): """ An invalid wheel filename was found, users should refer to PEP 427. @@ -24,18 +32,31 @@ class InvalidSdistFilename(ValueError): """ +# Core metadata spec for `Name` +_validate_regex = re.compile( + r"^([A-Z0-9]|[A-Z0-9][A-Z0-9._-]*[A-Z0-9])$", re.IGNORECASE +) _canonicalize_regex = re.compile(r"[-_.]+") +_normalized_regex = re.compile(r"^([a-z0-9]|[a-z0-9]([a-z0-9-](?!--))*[a-z0-9])$") # PEP 427: The build number must start with a digit. _build_tag_regex = re.compile(r"(\d+)(.*)") -def canonicalize_name(name: str) -> NormalizedName: +def canonicalize_name(name: str, *, validate: bool = False) -> NormalizedName: + if validate and not _validate_regex.match(name): + raise InvalidName(f"name is invalid: {name!r}") # This is taken from PEP 503. value = _canonicalize_regex.sub("-", name).lower() return cast(NormalizedName, value) -def canonicalize_version(version: Union[Version, str]) -> str: +def is_normalized_name(name: str) -> bool: + return _normalized_regex.match(name) is not None + + +def canonicalize_version( + version: Version | str, *, strip_trailing_zero: bool = True +) -> str: """ This is very similar to Version.__str__, but has one subtle difference with the way it handles the release segment. @@ -56,8 +77,11 @@ def canonicalize_version(version: Union[Version, str]) -> str: parts.append(f"{parsed.epoch}!") # Release segment - # NB: This strips trailing '.0's to normalize - parts.append(re.sub(r"(\.0)+$", "", ".".join(str(x) for x in parsed.release))) + release_segment = ".".join(str(x) for x in parsed.release) + if strip_trailing_zero: + # NB: This strips trailing '.0's to normalize + release_segment = re.sub(r"(\.0)+$", "", release_segment) + parts.append(release_segment) # Pre-release if parsed.pre is not None: @@ -80,7 +104,7 @@ def canonicalize_version(version: Union[Version, str]) -> str: def parse_wheel_filename( filename: str, -) -> Tuple[NormalizedName, Version, BuildTag, FrozenSet[Tag]]: +) -> tuple[NormalizedName, Version, BuildTag, frozenset[Tag]]: if not filename.endswith(".whl"): raise InvalidWheelFilename( f"Invalid wheel filename (extension must be '.whl'): {filename}" @@ -95,11 +119,18 @@ def parse_wheel_filename( parts = filename.split("-", dashes - 2) name_part = parts[0] - # See PEP 427 for the rules on escaping the project name + # See PEP 427 for the rules on escaping the project name. if "__" in name_part or re.match(r"^[\w\d._]*$", name_part, re.UNICODE) is None: raise InvalidWheelFilename(f"Invalid project name: {filename}") name = canonicalize_name(name_part) - version = Version(parts[1]) + + try: + version = Version(parts[1]) + except InvalidVersion as e: + raise InvalidWheelFilename( + f"Invalid wheel filename (invalid version): {filename}" + ) from e + if dashes == 5: build_part = parts[2] build_match = _build_tag_regex.match(build_part) @@ -114,7 +145,7 @@ def parse_wheel_filename( return (name, version, build, tags) -def parse_sdist_filename(filename: str) -> Tuple[NormalizedName, Version]: +def parse_sdist_filename(filename: str) -> tuple[NormalizedName, Version]: if filename.endswith(".tar.gz"): file_stem = filename[: -len(".tar.gz")] elif filename.endswith(".zip"): @@ -132,5 +163,12 @@ def parse_sdist_filename(filename: str) -> Tuple[NormalizedName, Version]: raise InvalidSdistFilename(f"Invalid sdist filename: {filename}") name = canonicalize_name(name_part) - version = Version(version_part) + + try: + version = Version(version_part) + except InvalidVersion as e: + raise InvalidSdistFilename( + f"Invalid sdist filename (invalid version): {filename}" + ) from e + return (name, version) diff --git a/myenv/Lib/site-packages/pip/_vendor/packaging/version.py b/myenv/Lib/site-packages/pip/_vendor/packaging/version.py index de9a09a..8b0a040 100644 --- a/myenv/Lib/site-packages/pip/_vendor/packaging/version.py +++ b/myenv/Lib/site-packages/pip/_vendor/packaging/version.py @@ -1,64 +1,73 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. +""" +.. testsetup:: + + from pip._vendor.packaging.version import parse, Version +""" + +from __future__ import annotations -import collections import itertools import re -import warnings -from typing import Callable, Iterator, List, Optional, SupportsInt, Tuple, Union +from typing import Any, Callable, NamedTuple, SupportsInt, Tuple, Union from ._structures import Infinity, InfinityType, NegativeInfinity, NegativeInfinityType -__all__ = ["parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN"] +__all__ = ["VERSION_PATTERN", "parse", "Version", "InvalidVersion"] + +LocalType = Tuple[Union[int, str], ...] -InfiniteTypes = Union[InfinityType, NegativeInfinityType] -PrePostDevType = Union[InfiniteTypes, Tuple[str, int]] -SubLocalType = Union[InfiniteTypes, int, str] -LocalType = Union[ +CmpPrePostDevType = Union[InfinityType, NegativeInfinityType, Tuple[str, int]] +CmpLocalType = Union[ NegativeInfinityType, - Tuple[ - Union[ - SubLocalType, - Tuple[SubLocalType, str], - Tuple[NegativeInfinityType, SubLocalType], - ], - ..., - ], + Tuple[Union[Tuple[int, str], Tuple[NegativeInfinityType, Union[int, str]]], ...], ] CmpKey = Tuple[ - int, Tuple[int, ...], PrePostDevType, PrePostDevType, PrePostDevType, LocalType -] -LegacyCmpKey = Tuple[int, Tuple[str, ...]] -VersionComparisonMethod = Callable[ - [Union[CmpKey, LegacyCmpKey], Union[CmpKey, LegacyCmpKey]], bool + int, + Tuple[int, ...], + CmpPrePostDevType, + CmpPrePostDevType, + CmpPrePostDevType, + CmpLocalType, ] +VersionComparisonMethod = Callable[[CmpKey, CmpKey], bool] -_Version = collections.namedtuple( - "_Version", ["epoch", "release", "dev", "pre", "post", "local"] -) +class _Version(NamedTuple): + epoch: int + release: tuple[int, ...] + dev: tuple[str, int] | None + pre: tuple[str, int] | None + post: tuple[str, int] | None + local: LocalType | None -def parse(version: str) -> Union["LegacyVersion", "Version"]: - """ - Parse the given version string and return either a :class:`Version` object - or a :class:`LegacyVersion` object depending on if the given version is - a valid PEP 440 version or a legacy version. + +def parse(version: str) -> Version: + """Parse the given version string. + + >>> parse('1.0.dev1') + + + :param version: The version string to parse. + :raises InvalidVersion: When the version string is not a valid version. """ - try: - return Version(version) - except InvalidVersion: - return LegacyVersion(version) + return Version(version) class InvalidVersion(ValueError): - """ - An invalid version was found, users should refer to PEP 440. + """Raised when a version string is not a valid version. + + >>> Version("invalid") + Traceback (most recent call last): + ... + packaging.version.InvalidVersion: Invalid version: 'invalid' """ class _BaseVersion: - _key: Union[CmpKey, LegacyCmpKey] + _key: tuple[Any, ...] def __hash__(self) -> int: return hash(self._key) @@ -66,13 +75,13 @@ def __hash__(self) -> int: # Please keep the duplicated `isinstance` check # in the six comparisons hereunder # unless you find a way to avoid adding overhead function calls. - def __lt__(self, other: "_BaseVersion") -> bool: + def __lt__(self, other: _BaseVersion) -> bool: if not isinstance(other, _BaseVersion): return NotImplemented return self._key < other._key - def __le__(self, other: "_BaseVersion") -> bool: + def __le__(self, other: _BaseVersion) -> bool: if not isinstance(other, _BaseVersion): return NotImplemented @@ -84,13 +93,13 @@ def __eq__(self, other: object) -> bool: return self._key == other._key - def __ge__(self, other: "_BaseVersion") -> bool: + def __ge__(self, other: _BaseVersion) -> bool: if not isinstance(other, _BaseVersion): return NotImplemented return self._key >= other._key - def __gt__(self, other: "_BaseVersion") -> bool: + def __gt__(self, other: _BaseVersion) -> bool: if not isinstance(other, _BaseVersion): return NotImplemented @@ -103,133 +112,16 @@ def __ne__(self, other: object) -> bool: return self._key != other._key -class LegacyVersion(_BaseVersion): - def __init__(self, version: str) -> None: - self._version = str(version) - self._key = _legacy_cmpkey(self._version) - - warnings.warn( - "Creating a LegacyVersion has been deprecated and will be " - "removed in the next major release", - DeprecationWarning, - ) - - def __str__(self) -> str: - return self._version - - def __repr__(self) -> str: - return f"" - - @property - def public(self) -> str: - return self._version - - @property - def base_version(self) -> str: - return self._version - - @property - def epoch(self) -> int: - return -1 - - @property - def release(self) -> None: - return None - - @property - def pre(self) -> None: - return None - - @property - def post(self) -> None: - return None - - @property - def dev(self) -> None: - return None - - @property - def local(self) -> None: - return None - - @property - def is_prerelease(self) -> bool: - return False - - @property - def is_postrelease(self) -> bool: - return False - - @property - def is_devrelease(self) -> bool: - return False - - -_legacy_version_component_re = re.compile(r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE) - -_legacy_version_replacement_map = { - "pre": "c", - "preview": "c", - "-": "final-", - "rc": "c", - "dev": "@", -} - - -def _parse_version_parts(s: str) -> Iterator[str]: - for part in _legacy_version_component_re.split(s): - part = _legacy_version_replacement_map.get(part, part) - - if not part or part == ".": - continue - - if part[:1] in "0123456789": - # pad for numeric comparison - yield part.zfill(8) - else: - yield "*" + part - - # ensure that alpha/beta/candidate are before final - yield "*final" - - -def _legacy_cmpkey(version: str) -> LegacyCmpKey: - - # We hardcode an epoch of -1 here. A PEP 440 version can only have a epoch - # greater than or equal to 0. This will effectively put the LegacyVersion, - # which uses the defacto standard originally implemented by setuptools, - # as before all PEP 440 versions. - epoch = -1 - - # This scheme is taken from pkg_resources.parse_version setuptools prior to - # it's adoption of the packaging library. - parts: List[str] = [] - for part in _parse_version_parts(version.lower()): - if part.startswith("*"): - # remove "-" before a prerelease tag - if part < "*final": - while parts and parts[-1] == "*final-": - parts.pop() - - # remove trailing zeros from each series of numeric parts - while parts and parts[-1] == "00000000": - parts.pop() - - parts.append(part) - - return epoch, tuple(parts) - - # Deliberately not anchored to the start and end of the string, to make it # easier for 3rd party code to reuse -VERSION_PATTERN = r""" +_VERSION_PATTERN = r""" v? (?: (?:(?P[0-9]+)!)? # epoch (?P[0-9]+(?:\.[0-9]+)*) # release segment (?P

                                          # pre-release
             [-_\.]?
-            (?P(a|b|c|rc|alpha|beta|pre|preview))
+            (?Palpha|a|beta|b|preview|pre|c|rc)
             [-_\.]?
             (?P[0-9]+)?
         )?
@@ -253,12 +145,56 @@ def _legacy_cmpkey(version: str) -> LegacyCmpKey:
     (?:\+(?P[a-z0-9]+(?:[-_\.][a-z0-9]+)*))?       # local version
 """
 
+VERSION_PATTERN = _VERSION_PATTERN
+"""
+A string containing the regular expression used to match a valid version.
+
+The pattern is not anchored at either end, and is intended for embedding in larger
+expressions (for example, matching a version number as part of a file name). The
+regular expression should be compiled with the ``re.VERBOSE`` and ``re.IGNORECASE``
+flags set.
+
+:meta hide-value:
+"""
+
 
 class Version(_BaseVersion):
+    """This class abstracts handling of a project's versions.
+
+    A :class:`Version` instance is comparison aware and can be compared and
+    sorted using the standard Python interfaces.
+
+    >>> v1 = Version("1.0a5")
+    >>> v2 = Version("1.0")
+    >>> v1
+    
+    >>> v2
+    
+    >>> v1 < v2
+    True
+    >>> v1 == v2
+    False
+    >>> v1 > v2
+    False
+    >>> v1 >= v2
+    False
+    >>> v1 <= v2
+    True
+    """
 
     _regex = re.compile(r"^\s*" + VERSION_PATTERN + r"\s*$", re.VERBOSE | re.IGNORECASE)
+    _key: CmpKey
 
     def __init__(self, version: str) -> None:
+        """Initialize a Version object.
+
+        :param version:
+            The string representation of a version which will be parsed and normalized
+            before use.
+        :raises InvalidVersion:
+            If the ``version`` does not conform to PEP 440 in any way then this
+            exception will be raised.
+        """
 
         # Validate the version and parse it into pieces
         match = self._regex.search(version)
@@ -288,9 +224,19 @@ def __init__(self, version: str) -> None:
         )
 
     def __repr__(self) -> str:
+        """A representation of the Version that shows all internal state.
+
+        >>> Version('1.0.0')
+        
+        """
         return f""
 
     def __str__(self) -> str:
+        """A string representation of the version that can be rounded-tripped.
+
+        >>> str(Version("1.0a5"))
+        '1.0a5'
+        """
         parts = []
 
         # Epoch
@@ -320,29 +266,77 @@ def __str__(self) -> str:
 
     @property
     def epoch(self) -> int:
-        _epoch: int = self._version.epoch
-        return _epoch
+        """The epoch of the version.
+
+        >>> Version("2.0.0").epoch
+        0
+        >>> Version("1!2.0.0").epoch
+        1
+        """
+        return self._version.epoch
 
     @property
-    def release(self) -> Tuple[int, ...]:
-        _release: Tuple[int, ...] = self._version.release
-        return _release
+    def release(self) -> tuple[int, ...]:
+        """The components of the "release" segment of the version.
+
+        >>> Version("1.2.3").release
+        (1, 2, 3)
+        >>> Version("2.0.0").release
+        (2, 0, 0)
+        >>> Version("1!2.0.0.post0").release
+        (2, 0, 0)
+
+        Includes trailing zeroes but not the epoch or any pre-release / development /
+        post-release suffixes.
+        """
+        return self._version.release
 
     @property
-    def pre(self) -> Optional[Tuple[str, int]]:
-        _pre: Optional[Tuple[str, int]] = self._version.pre
-        return _pre
+    def pre(self) -> tuple[str, int] | None:
+        """The pre-release segment of the version.
+
+        >>> print(Version("1.2.3").pre)
+        None
+        >>> Version("1.2.3a1").pre
+        ('a', 1)
+        >>> Version("1.2.3b1").pre
+        ('b', 1)
+        >>> Version("1.2.3rc1").pre
+        ('rc', 1)
+        """
+        return self._version.pre
 
     @property
-    def post(self) -> Optional[int]:
+    def post(self) -> int | None:
+        """The post-release number of the version.
+
+        >>> print(Version("1.2.3").post)
+        None
+        >>> Version("1.2.3.post1").post
+        1
+        """
         return self._version.post[1] if self._version.post else None
 
     @property
-    def dev(self) -> Optional[int]:
+    def dev(self) -> int | None:
+        """The development number of the version.
+
+        >>> print(Version("1.2.3").dev)
+        None
+        >>> Version("1.2.3.dev1").dev
+        1
+        """
         return self._version.dev[1] if self._version.dev else None
 
     @property
-    def local(self) -> Optional[str]:
+    def local(self) -> str | None:
+        """The local version segment of the version.
+
+        >>> print(Version("1.2.3").local)
+        None
+        >>> Version("1.2.3+abc").local
+        'abc'
+        """
         if self._version.local:
             return ".".join(str(x) for x in self._version.local)
         else:
@@ -350,10 +344,31 @@ def local(self) -> Optional[str]:
 
     @property
     def public(self) -> str:
+        """The public portion of the version.
+
+        >>> Version("1.2.3").public
+        '1.2.3'
+        >>> Version("1.2.3+abc").public
+        '1.2.3'
+        >>> Version("1.2.3+abc.dev1").public
+        '1.2.3'
+        """
         return str(self).split("+", 1)[0]
 
     @property
     def base_version(self) -> str:
+        """The "base version" of the version.
+
+        >>> Version("1.2.3").base_version
+        '1.2.3'
+        >>> Version("1.2.3+abc").base_version
+        '1.2.3'
+        >>> Version("1!1.2.3+abc.dev1").base_version
+        '1!1.2.3'
+
+        The "base version" is the public version of the project without any pre or post
+        release markers.
+        """
         parts = []
 
         # Epoch
@@ -367,33 +382,78 @@ def base_version(self) -> str:
 
     @property
     def is_prerelease(self) -> bool:
+        """Whether this version is a pre-release.
+
+        >>> Version("1.2.3").is_prerelease
+        False
+        >>> Version("1.2.3a1").is_prerelease
+        True
+        >>> Version("1.2.3b1").is_prerelease
+        True
+        >>> Version("1.2.3rc1").is_prerelease
+        True
+        >>> Version("1.2.3dev1").is_prerelease
+        True
+        """
         return self.dev is not None or self.pre is not None
 
     @property
     def is_postrelease(self) -> bool:
+        """Whether this version is a post-release.
+
+        >>> Version("1.2.3").is_postrelease
+        False
+        >>> Version("1.2.3.post1").is_postrelease
+        True
+        """
         return self.post is not None
 
     @property
     def is_devrelease(self) -> bool:
+        """Whether this version is a development release.
+
+        >>> Version("1.2.3").is_devrelease
+        False
+        >>> Version("1.2.3.dev1").is_devrelease
+        True
+        """
         return self.dev is not None
 
     @property
     def major(self) -> int:
+        """The first item of :attr:`release` or ``0`` if unavailable.
+
+        >>> Version("1.2.3").major
+        1
+        """
         return self.release[0] if len(self.release) >= 1 else 0
 
     @property
     def minor(self) -> int:
+        """The second item of :attr:`release` or ``0`` if unavailable.
+
+        >>> Version("1.2.3").minor
+        2
+        >>> Version("1").minor
+        0
+        """
         return self.release[1] if len(self.release) >= 2 else 0
 
     @property
     def micro(self) -> int:
+        """The third item of :attr:`release` or ``0`` if unavailable.
+
+        >>> Version("1.2.3").micro
+        3
+        >>> Version("1").micro
+        0
+        """
         return self.release[2] if len(self.release) >= 3 else 0
 
 
 def _parse_letter_version(
-    letter: str, number: Union[str, bytes, SupportsInt]
-) -> Optional[Tuple[str, int]]:
-
+    letter: str | None, number: str | bytes | SupportsInt | None
+) -> tuple[str, int] | None:
     if letter:
         # We consider there to be an implicit 0 in a pre-release if there is
         # not a numeral associated with it.
@@ -429,7 +489,7 @@ def _parse_letter_version(
 _local_version_separators = re.compile(r"[\._-]")
 
 
-def _parse_local_version(local: str) -> Optional[LocalType]:
+def _parse_local_version(local: str | None) -> LocalType | None:
     """
     Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve").
     """
@@ -443,13 +503,12 @@ def _parse_local_version(local: str) -> Optional[LocalType]:
 
 def _cmpkey(
     epoch: int,
-    release: Tuple[int, ...],
-    pre: Optional[Tuple[str, int]],
-    post: Optional[Tuple[str, int]],
-    dev: Optional[Tuple[str, int]],
-    local: Optional[Tuple[SubLocalType]],
+    release: tuple[int, ...],
+    pre: tuple[str, int] | None,
+    post: tuple[str, int] | None,
+    dev: tuple[str, int] | None,
+    local: LocalType | None,
 ) -> CmpKey:
-
     # When we compare a release version, we want to compare it with all of the
     # trailing zeros removed. So we'll use a reverse the list, drop all the now
     # leading zeros until we come to something non zero, then take the rest
@@ -464,7 +523,7 @@ def _cmpkey(
     # if there is not a pre or a post segment. If we have one of those then
     # the normal sorting rules will handle this case correctly.
     if pre is None and post is None and dev is not None:
-        _pre: PrePostDevType = NegativeInfinity
+        _pre: CmpPrePostDevType = NegativeInfinity
     # Versions without a pre-release (except as noted above) should sort after
     # those with one.
     elif pre is None:
@@ -474,21 +533,21 @@ def _cmpkey(
 
     # Versions without a post segment should sort before those with one.
     if post is None:
-        _post: PrePostDevType = NegativeInfinity
+        _post: CmpPrePostDevType = NegativeInfinity
 
     else:
         _post = post
 
     # Versions without a development segment should sort after those with one.
     if dev is None:
-        _dev: PrePostDevType = Infinity
+        _dev: CmpPrePostDevType = Infinity
 
     else:
         _dev = dev
 
     if local is None:
         # Versions without a local segment should sort before those with one.
-        _local: LocalType = NegativeInfinity
+        _local: CmpLocalType = NegativeInfinity
     else:
         # Versions with a local segment need that segment parsed to implement
         # the sorting rules in PEP440.
diff --git a/myenv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py b/myenv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py
index ad27940..417a537 100644
--- a/myenv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py
+++ b/myenv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py
@@ -18,11 +18,16 @@
 """
 
 import sys
+
+if sys.version_info < (3, 8):
+    raise RuntimeError("Python 3.8 or later is required")
+
 import os
 import io
 import time
 import re
 import types
+from typing import List, Protocol
 import zipfile
 import zipimport
 import warnings
@@ -41,18 +46,10 @@
 import ntpath
 import posixpath
 import importlib
+import importlib.machinery
 from pkgutil import get_importer
 
-try:
-    import _imp
-except ImportError:
-    # Python 3.2 compatibility
-    import imp as _imp
-
-try:
-    FileExistsError
-except NameError:
-    FileExistsError = OSError
+import _imp
 
 # capture these to bypass sandboxing
 from os import utime
@@ -68,14 +65,6 @@
 from os import open as os_open
 from os.path import isdir, split
 
-try:
-    import importlib.machinery as importlib_machinery
-
-    # access attribute to force import under delayed import mechanisms.
-    importlib_machinery.__name__
-except ImportError:
-    importlib_machinery = None
-
 from pip._internal.utils._jaraco_text import (
     yield_lines,
     drop_comment,
@@ -91,17 +80,12 @@
 __import__('pip._vendor.packaging.markers')
 __import__('pip._vendor.packaging.utils')
 
-if sys.version_info < (3, 5):
-    raise RuntimeError("Python 3.5 or later is required")
-
 # declare some globals that will be defined later to
 # satisfy the linters.
 require = None
 working_set = None
 add_activation_listener = None
-resources_stream = None
 cleanup_resources = None
-resource_dir = None
 resource_stream = None
 set_extraction_path = None
 resource_isdir = None
@@ -119,7 +103,7 @@
     "pkg_resources is deprecated as an API. "
     "See https://setuptools.pypa.io/en/latest/pkg_resources.html",
     DeprecationWarning,
-    stacklevel=2
+    stacklevel=2,
 )
 
 
@@ -407,20 +391,18 @@ def get_provider(moduleOrReq):
     return _find_adapter(_provider_factories, loader)(module)
 
 
-def _macos_vers(_cache=[]):
-    if not _cache:
-        version = platform.mac_ver()[0]
-        # fallback for MacPorts
-        if version == '':
-            plist = '/System/Library/CoreServices/SystemVersion.plist'
-            if os.path.exists(plist):
-                if hasattr(plistlib, 'readPlist'):
-                    plist_content = plistlib.readPlist(plist)
-                    if 'ProductVersion' in plist_content:
-                        version = plist_content['ProductVersion']
-
-        _cache.append(version.split('.'))
-    return _cache[0]
+@functools.lru_cache(maxsize=None)
+def _macos_vers():
+    version = platform.mac_ver()[0]
+    # fallback for MacPorts
+    if version == '':
+        plist = '/System/Library/CoreServices/SystemVersion.plist'
+        if os.path.exists(plist):
+            with open(plist, 'rb') as fh:
+                plist_content = plistlib.load(fh)
+            if 'ProductVersion' in plist_content:
+                version = plist_content['ProductVersion']
+    return version.split('.')
 
 
 def _macos_arch(machine):
@@ -507,19 +489,6 @@ def compatible_platforms(provided, required):
     return False
 
 
-def run_script(dist_spec, script_name):
-    """Locate distribution `dist_spec` and run its `script_name` script"""
-    ns = sys._getframe(1).f_globals
-    name = ns['__name__']
-    ns.clear()
-    ns['__name__'] = name
-    require(dist_spec)[0].run_script(script_name, ns)
-
-
-# backward compatibility
-run_main = run_script
-
-
 def get_distribution(dist):
     """Return a current distribution object for a Requirement or string"""
     if isinstance(dist, str):
@@ -546,54 +515,54 @@ def get_entry_info(dist, group, name):
     return get_distribution(dist).get_entry_info(group, name)
 
 
-class IMetadataProvider:
-    def has_metadata(name):
+class IMetadataProvider(Protocol):
+    def has_metadata(self, name) -> bool:
         """Does the package's distribution contain the named metadata?"""
 
-    def get_metadata(name):
+    def get_metadata(self, name):
         """The named metadata resource as a string"""
 
-    def get_metadata_lines(name):
+    def get_metadata_lines(self, name):
         """Yield named metadata resource as list of non-blank non-comment lines
 
         Leading and trailing whitespace is stripped from each line, and lines
         with ``#`` as the first non-blank character are omitted."""
 
-    def metadata_isdir(name):
+    def metadata_isdir(self, name) -> bool:
         """Is the named metadata a directory?  (like ``os.path.isdir()``)"""
 
-    def metadata_listdir(name):
+    def metadata_listdir(self, name):
         """List of metadata names in the directory (like ``os.listdir()``)"""
 
-    def run_script(script_name, namespace):
+    def run_script(self, script_name, namespace):
         """Execute the named script in the supplied namespace dictionary"""
 
 
-class IResourceProvider(IMetadataProvider):
+class IResourceProvider(IMetadataProvider, Protocol):
     """An object that provides access to package resources"""
 
-    def get_resource_filename(manager, resource_name):
+    def get_resource_filename(self, manager, resource_name):
         """Return a true filesystem path for `resource_name`
 
         `manager` must be an ``IResourceManager``"""
 
-    def get_resource_stream(manager, resource_name):
+    def get_resource_stream(self, manager, resource_name):
         """Return a readable file-like object for `resource_name`
 
         `manager` must be an ``IResourceManager``"""
 
-    def get_resource_string(manager, resource_name):
-        """Return a string containing the contents of `resource_name`
+    def get_resource_string(self, manager, resource_name) -> bytes:
+        """Return the contents of `resource_name` as :obj:`bytes`
 
         `manager` must be an ``IResourceManager``"""
 
-    def has_resource(resource_name):
+    def has_resource(self, resource_name):
         """Does the package contain the named resource?"""
 
-    def resource_isdir(resource_name):
+    def resource_isdir(self, resource_name):
         """Is the named resource a directory?  (like ``os.path.isdir()``)"""
 
-    def resource_listdir(resource_name):
+    def resource_listdir(self, resource_name):
         """List of resource names in the directory (like ``os.listdir()``)"""
 
 
@@ -1143,8 +1112,7 @@ def obtain(self, requirement, installer=None):
         None is returned instead.  This method is a hook that allows subclasses
         to attempt other ways of obtaining a distribution before falling back
         to the `installer` argument."""
-        if installer is not None:
-            return installer(requirement)
+        return installer(requirement) if installer else None
 
     def __iter__(self):
         """Yield the unique project names of the available distributions"""
@@ -1220,8 +1188,8 @@ def resource_stream(self, package_or_requirement, resource_name):
             self, resource_name
         )
 
-    def resource_string(self, package_or_requirement, resource_name):
-        """Return specified resource as a string"""
+    def resource_string(self, package_or_requirement, resource_name) -> bytes:
+        """Return specified resource as :obj:`bytes`"""
         return get_provider(package_or_requirement).get_resource_string(
             self, resource_name
         )
@@ -1356,7 +1324,7 @@ def set_extraction_path(self, path):
 
         self.extraction_path = path
 
-    def cleanup_resources(self, force=False):
+    def cleanup_resources(self, force=False) -> List[str]:
         """
         Delete all extracted resource files and directories, returning a list
         of the file and directory names that could not be successfully removed.
@@ -1368,6 +1336,7 @@ def cleanup_resources(self, force=False):
         directory used for extractions.
         """
         # XXX
+        return []
 
 
 def get_default_cache():
@@ -1418,7 +1387,7 @@ def _forgiving_version(version):
     match = _PEP440_FALLBACK.search(version)
     if match:
         safe = match["safe"]
-        rest = version[len(safe):]
+        rest = version[len(safe) :]
     else:
         safe = "0"
         rest = version
@@ -1496,7 +1465,7 @@ def get_resource_filename(self, manager, resource_name):
     def get_resource_stream(self, manager, resource_name):
         return io.BytesIO(self.get_resource_string(manager, resource_name))
 
-    def get_resource_string(self, manager, resource_name):
+    def get_resource_string(self, manager, resource_name) -> bytes:
         return self._get(self._fn(self.module_path, resource_name))
 
     def has_resource(self, resource_name):
@@ -1505,9 +1474,9 @@ def has_resource(self, resource_name):
     def _get_metadata_path(self, name):
         return self._fn(self.egg_info, name)
 
-    def has_metadata(self, name):
+    def has_metadata(self, name) -> bool:
         if not self.egg_info:
-            return self.egg_info
+            return False
 
         path = self._get_metadata_path(name)
         return self._has(path)
@@ -1531,8 +1500,8 @@ def get_metadata_lines(self, name):
     def resource_isdir(self, resource_name):
         return self._isdir(self._fn(self.module_path, resource_name))
 
-    def metadata_isdir(self, name):
-        return self.egg_info and self._isdir(self._fn(self.egg_info, name))
+    def metadata_isdir(self, name) -> bool:
+        return bool(self.egg_info and self._isdir(self._fn(self.egg_info, name)))
 
     def resource_listdir(self, resource_name):
         return self._listdir(self._fn(self.module_path, resource_name))
@@ -1571,12 +1540,12 @@ def run_script(self, script_name, namespace):
             script_code = compile(script_text, script_filename, 'exec')
             exec(script_code, namespace, namespace)
 
-    def _has(self, path):
+    def _has(self, path) -> bool:
         raise NotImplementedError(
             "Can't perform this operation for unregistered loader type"
         )
 
-    def _isdir(self, path):
+    def _isdir(self, path) -> bool:
         raise NotImplementedError(
             "Can't perform this operation for unregistered loader type"
         )
@@ -1666,7 +1635,7 @@ def _validate_resource_path(path):
             DeprecationWarning,
         )
 
-    def _get(self, path):
+    def _get(self, path) -> bytes:
         if hasattr(self.loader, 'get_data'):
             return self.loader.get_data(path)
         raise NotImplementedError(
@@ -1711,10 +1680,10 @@ def _set_egg(self, path):
 class DefaultProvider(EggProvider):
     """Provides access to package resources in the filesystem"""
 
-    def _has(self, path):
+    def _has(self, path) -> bool:
         return os.path.exists(path)
 
-    def _isdir(self, path):
+    def _isdir(self, path) -> bool:
         return os.path.isdir(path)
 
     def _listdir(self, path):
@@ -1723,7 +1692,7 @@ def _listdir(self, path):
     def get_resource_stream(self, manager, resource_name):
         return open(self._fn(self.module_path, resource_name), 'rb')
 
-    def _get(self, path):
+    def _get(self, path) -> bytes:
         with open(path, 'rb') as stream:
             return stream.read()
 
@@ -1734,7 +1703,7 @@ def _register(cls):
             'SourcelessFileLoader',
         )
         for name in loader_names:
-            loader_cls = getattr(importlib_machinery, name, type(None))
+            loader_cls = getattr(importlib.machinery, name, type(None))
             register_loader_type(loader_cls, cls)
 
 
@@ -1748,8 +1717,8 @@ class EmptyProvider(NullProvider):
 
     _isdir = _has = lambda self, path: False
 
-    def _get(self, path):
-        return ''
+    def _get(self, path) -> bytes:
+        return b''
 
     def _listdir(self, path):
         return []
@@ -1874,7 +1843,7 @@ def _extract_resource(self, manager, zip_path):  # noqa: C901
         timestamp, size = self._get_date_and_size(self.zipinfo[zip_path])
 
         if not WRITE_SUPPORT:
-            raise IOError(
+            raise OSError(
                 '"os.rename" and "os.unlink" are not supported ' 'on this platform'
             )
         try:
@@ -1895,7 +1864,7 @@ def _extract_resource(self, manager, zip_path):  # noqa: C901
             try:
                 rename(tmpnam, real_path)
 
-            except os.error:
+            except OSError:
                 if os.path.isfile(real_path):
                     if self._is_current(real_path, zip_path):
                         # the file became current since it was checked above,
@@ -1908,7 +1877,7 @@ def _extract_resource(self, manager, zip_path):  # noqa: C901
                         return real_path
                 raise
 
-        except os.error:
+        except OSError:
             # report a user-friendly error
             manager.extraction_error()
 
@@ -1956,11 +1925,11 @@ def _index(self):
             self._dirindex = ind
             return ind
 
-    def _has(self, fspath):
+    def _has(self, fspath) -> bool:
         zip_path = self._zipinfo_name(fspath)
         return zip_path in self.zipinfo or zip_path in self._index()
 
-    def _isdir(self, fspath):
+    def _isdir(self, fspath) -> bool:
         return self._zipinfo_name(fspath) in self._index()
 
     def _listdir(self, fspath):
@@ -1994,14 +1963,14 @@ def __init__(self, path):
     def _get_metadata_path(self, name):
         return self.path
 
-    def has_metadata(self, name):
+    def has_metadata(self, name) -> bool:
         return name == 'PKG-INFO' and os.path.isfile(self.path)
 
     def get_metadata(self, name):
         if name != 'PKG-INFO':
             raise KeyError("No metadata except PKG-INFO is available")
 
-        with io.open(self.path, encoding='utf-8', errors="replace") as f:
+        with open(self.path, encoding='utf-8', errors="replace") as f:
             metadata = f.read()
         self._warn_on_replacement(metadata)
         return metadata
@@ -2095,8 +2064,7 @@ def find_eggs_in_zip(importer, path_item, only=False):
         if _is_egg_path(subitem):
             subpath = os.path.join(path_item, subitem)
             dists = find_eggs_in_zip(zipimport.zipimporter(subpath), subpath)
-            for dist in dists:
-                yield dist
+            yield from dists
         elif subitem.lower().endswith(('.dist-info', '.egg-info')):
             subpath = os.path.join(path_item, subitem)
             submeta = EggMetadata(zipimport.zipimporter(subpath))
@@ -2131,8 +2099,7 @@ def find_on_path(importer, path_item, only=False):
     for entry in sorted(entries):
         fullpath = os.path.join(path_item, entry)
         factory = dist_factory(path_item, entry, only)
-        for dist in factory(fullpath):
-            yield dist
+        yield from factory(fullpath)
 
 
 def dist_factory(path_item, entry, only):
@@ -2231,7 +2198,7 @@ def resolve_egg_link(path):
 if hasattr(pkgutil, 'ImpImporter'):
     register_finder(pkgutil.ImpImporter, find_on_path)
 
-register_finder(importlib_machinery.FileFinder, find_on_path)
+register_finder(importlib.machinery.FileFinder, find_on_path)
 
 _declare_state('dict', _namespace_handlers={})
 _declare_state('dict', _namespace_packages={})
@@ -2398,7 +2365,7 @@ def file_ns_handler(importer, path_item, packageName, module):
     register_namespace_handler(pkgutil.ImpImporter, file_ns_handler)
 
 register_namespace_handler(zipimport.zipimporter, file_ns_handler)
-register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler)
+register_namespace_handler(importlib.machinery.FileFinder, file_ns_handler)
 
 
 def null_ns_handler(importer, path_item, packageName, module):
@@ -2424,12 +2391,9 @@ def _cygwin_patch(filename):  # pragma: nocover
     return os.path.abspath(filename) if sys.platform == 'cygwin' else filename
 
 
-def _normalize_cached(filename, _cache={}):
-    try:
-        return _cache[filename]
-    except KeyError:
-        _cache[filename] = result = normalize_path(filename)
-        return result
+@functools.lru_cache(maxsize=None)
+def _normalize_cached(filename):
+    return normalize_path(filename)
 
 
 def _is_egg_path(path):
@@ -2850,14 +2814,11 @@ def _get_metadata_path_for_display(self, name):
 
     def _get_metadata(self, name):
         if self.has_metadata(name):
-            for line in self.get_metadata_lines(name):
-                yield line
+            yield from self.get_metadata_lines(name)
 
     def _get_version(self):
         lines = self._get_metadata(self.PKG_INFO)
-        version = _version_from_file(lines)
-
-        return version
+        return _version_from_file(lines)
 
     def activate(self, path=None, replace=False):
         """Ensure distribution is importable on `path` (default=sys.path)"""
@@ -2904,7 +2865,7 @@ def __getattr__(self, attr):
 
     def __dir__(self):
         return list(
-            set(super(Distribution, self).__dir__())
+            set(super().__dir__())
             | set(attr for attr in self._provider.__dir__() if not attr.startswith('_'))
         )
 
@@ -3171,7 +3132,7 @@ class RequirementParseError(packaging.requirements.InvalidRequirement):
 class Requirement(packaging.requirements.Requirement):
     def __init__(self, requirement_string):
         """DO NOT CALL THIS UNDOCUMENTED METHOD; use Requirement.parse()!"""
-        super(Requirement, self).__init__(requirement_string)
+        super().__init__(requirement_string)
         self.unsafe_name = self.name
         project_name = safe_name(self.name)
         self.project_name, self.key = project_name, project_name.lower()
@@ -3232,6 +3193,9 @@ def _find_adapter(registry, ob):
     for t in types:
         if t in registry:
             return registry[t]
+    # _find_adapter would previously return None, and immediately be called.
+    # So we're raising a TypeError to keep backward compatibility if anyone depended on that behaviour.
+    raise TypeError(f"Could not find adapter for {registry} and {ob}")
 
 
 def ensure_directory(path):
@@ -3243,7 +3207,7 @@ def ensure_directory(path):
 def _bypass_ensure_directory(path):
     """Sandbox-bypassing version of ensure_directory()"""
     if not WRITE_SUPPORT:
-        raise IOError('"os.mkdir" not supported on this platform.')
+        raise OSError('"os.mkdir" not supported on this platform.')
     dirname, filename = split(path)
     if dirname and filename and not isdir(dirname):
         _bypass_ensure_directory(dirname)
diff --git a/myenv/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-311.pyc
index d9e759b024012c12803f4caf23a9ccb0c4fee85b..625c8d7e792a7375f4c8150ae4998691b9c741ff 100644
GIT binary patch
delta 34321
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
VoESYd+VoO%_|z2hOUVN8{{eBz for details and
-usage.
+Utilities for determining application-specific dirs.
+
+See  for details and usage.
+
 """
+
 from __future__ import annotations
 
 import os
@@ -14,31 +17,27 @@
 
 if TYPE_CHECKING:
     from pathlib import Path
-
-    if sys.version_info >= (3, 8):  # pragma: no cover (py38+)
-        from typing import Literal
-    else:  # pragma: no cover (py38+)
-        from pip._vendor.typing_extensions import Literal
+    from typing import Literal
 
 
 def _set_platform_dir_class() -> type[PlatformDirsABC]:
     if sys.platform == "win32":
-        from pip._vendor.platformdirs.windows import Windows as Result
+        from pip._vendor.platformdirs.windows import Windows as Result  # noqa: PLC0415
     elif sys.platform == "darwin":
-        from pip._vendor.platformdirs.macos import MacOS as Result
+        from pip._vendor.platformdirs.macos import MacOS as Result  # noqa: PLC0415
     else:
-        from pip._vendor.platformdirs.unix import Unix as Result
+        from pip._vendor.platformdirs.unix import Unix as Result  # noqa: PLC0415
 
     if os.getenv("ANDROID_DATA") == "/data" and os.getenv("ANDROID_ROOT") == "/system":
         if os.getenv("SHELL") or os.getenv("PREFIX"):
             return Result
 
-        from pip._vendor.platformdirs.android import _android_folder
+        from pip._vendor.platformdirs.android import _android_folder  # noqa: PLC0415
 
         if _android_folder() is not None:
-            from pip._vendor.platformdirs.android import Android
+            from pip._vendor.platformdirs.android import Android  # noqa: PLC0415
 
-            return Android  # return to avoid redefinition of result
+            return Android  # return to avoid redefinition of a result
 
     return Result
 
@@ -264,6 +263,11 @@ def user_music_dir() -> str:
     return PlatformDirs().user_music_dir
 
 
+def user_desktop_dir() -> str:
+    """:returns: desktop directory tied to the user"""
+    return PlatformDirs().user_desktop_dir
+
+
 def user_runtime_dir(
     appname: str | None = None,
     appauthor: str | None | Literal[False] = None,
@@ -288,6 +292,30 @@ def user_runtime_dir(
     ).user_runtime_dir
 
 
+def site_runtime_dir(
+    appname: str | None = None,
+    appauthor: str | None | Literal[False] = None,
+    version: str | None = None,
+    opinion: bool = True,  # noqa: FBT001, FBT002
+    ensure_exists: bool = False,  # noqa: FBT001, FBT002
+) -> str:
+    """
+    :param appname: See `appname `.
+    :param appauthor: See `appauthor `.
+    :param version: See `version `.
+    :param opinion: See `opinion `.
+    :param ensure_exists: See `ensure_exists `.
+    :returns: runtime directory shared by users
+    """
+    return PlatformDirs(
+        appname=appname,
+        appauthor=appauthor,
+        version=version,
+        opinion=opinion,
+        ensure_exists=ensure_exists,
+    ).site_runtime_dir
+
+
 def user_data_path(
     appname: str | None = None,
     appauthor: str | None | Literal[False] = None,
@@ -481,7 +509,7 @@ def user_log_path(
 
 
 def user_documents_path() -> Path:
-    """:returns: documents path tied to the user"""
+    """:returns: documents a path tied to the user"""
     return PlatformDirs().user_documents_path
 
 
@@ -505,6 +533,11 @@ def user_music_path() -> Path:
     return PlatformDirs().user_music_path
 
 
+def user_desktop_path() -> Path:
+    """:returns: desktop path tied to the user"""
+    return PlatformDirs().user_desktop_path
+
+
 def user_runtime_path(
     appname: str | None = None,
     appauthor: str | None | Literal[False] = None,
@@ -529,38 +562,66 @@ def user_runtime_path(
     ).user_runtime_path
 
 
+def site_runtime_path(
+    appname: str | None = None,
+    appauthor: str | None | Literal[False] = None,
+    version: str | None = None,
+    opinion: bool = True,  # noqa: FBT001, FBT002
+    ensure_exists: bool = False,  # noqa: FBT001, FBT002
+) -> Path:
+    """
+    :param appname: See `appname `.
+    :param appauthor: See `appauthor `.
+    :param version: See `version `.
+    :param opinion: See `opinion `.
+    :param ensure_exists: See `ensure_exists `.
+    :returns: runtime path shared by users
+    """
+    return PlatformDirs(
+        appname=appname,
+        appauthor=appauthor,
+        version=version,
+        opinion=opinion,
+        ensure_exists=ensure_exists,
+    ).site_runtime_path
+
+
 __all__ = [
-    "__version__",
-    "__version_info__",
-    "PlatformDirs",
     "AppDirs",
+    "PlatformDirs",
     "PlatformDirsABC",
-    "user_data_dir",
-    "user_config_dir",
+    "__version__",
+    "__version_info__",
+    "site_cache_dir",
+    "site_cache_path",
+    "site_config_dir",
+    "site_config_path",
+    "site_data_dir",
+    "site_data_path",
+    "site_runtime_dir",
+    "site_runtime_path",
     "user_cache_dir",
-    "user_state_dir",
-    "user_log_dir",
+    "user_cache_path",
+    "user_config_dir",
+    "user_config_path",
+    "user_data_dir",
+    "user_data_path",
+    "user_desktop_dir",
+    "user_desktop_path",
     "user_documents_dir",
+    "user_documents_path",
     "user_downloads_dir",
-    "user_pictures_dir",
-    "user_videos_dir",
+    "user_downloads_path",
+    "user_log_dir",
+    "user_log_path",
     "user_music_dir",
+    "user_music_path",
+    "user_pictures_dir",
+    "user_pictures_path",
     "user_runtime_dir",
-    "site_data_dir",
-    "site_config_dir",
-    "site_cache_dir",
-    "user_data_path",
-    "user_config_path",
-    "user_cache_path",
+    "user_runtime_path",
+    "user_state_dir",
     "user_state_path",
-    "user_log_path",
-    "user_documents_path",
-    "user_downloads_path",
-    "user_pictures_path",
+    "user_videos_dir",
     "user_videos_path",
-    "user_music_path",
-    "user_runtime_path",
-    "site_data_path",
-    "site_config_path",
-    "site_cache_path",
 ]
diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py b/myenv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py
index 6a0d6dd..fa8a677 100644
--- a/myenv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py
+++ b/myenv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py
@@ -1,4 +1,5 @@
 """Main entry point."""
+
 from __future__ import annotations
 
 from pip._vendor.platformdirs import PlatformDirs, __version__
@@ -18,11 +19,12 @@
     "site_data_dir",
     "site_config_dir",
     "site_cache_dir",
+    "site_runtime_dir",
 )
 
 
 def main() -> None:
-    """Run main entry point."""
+    """Run the main entry point."""
     app_name = "MyApp"
     app_author = "MyCompany"
 
diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/__init__.cpython-311.pyc
index f382ac6d2ef8762f00b916c1e8ee86f1bbafd546..5572b6d2d16261eeb4b313efabcfe6ee42396696 100644
GIT binary patch
literal 19205
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

literal 17509
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

diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/__main__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/__main__.cpython-311.pyc
index 77a34da8dc9626d9990dae2a7e0c4e87a6eebef8..a051116f540fee1eaa3f54af2929e6834d47534a 100644
GIT binary patch
delta 169
zcmew;*e=AooR^o20SH`A_N6_X$h(V?f8vR^JOag;C8_a6rFkWpxtrHBo?_yV3@Xi2
zD9K3OT+4EXkyQn#Lu#`h+e$_@Q6RHOZ1P`r7iU=z6C`zuBR)PaF*h|nekDVZDo9ir
zNc`fk$<0qG%}KQ@(gAWAfw;H?NPJ*sWMsU-Abx>C{K4cF4sCV;PNoLd4{DRQahS7!
GbOQjNCoSUu

delta 152
zcmZn{`Y6b|oR^o20SKHA^`#w|$h(V?Z{mr!n~yUdVPX*tD$UzGndJ;4t1?i5#O4&X
zm5gj6KxUEXWMK{$XBiL^Bz21;K0YroH#I(fB}0)4NK^?({Nk|5%}*)KNwq7|267pJ
pxVQvJd|+l|WW2#3et|*!#^hNX+U)$CObx6bR3@L{FlPbj1^{xrChq_M

diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/android.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/android.cpython-311.pyc
index 6adddb4d1d11610afb13c32f36f878cfbc1d11ea..6ec0e7090f5ea142fb79396c412cffe3772bb61f 100644
GIT binary patch
delta 1552
zcmZ{jU1-}@6vuVskJwf$%eL%%G*0ZcNpL>gvcNu4vaYccYM7JMPU_TTI3|)8Q5tVo
z_BOJ03u`v|F#3@5P#9xll(m$V(jwSX=~JP!8>0_<7^ZY#dm4k`!nUVv>|Qx(LbP1t
zzmCrDT>bC4y87+Zr>DhhUayCvW8%T3GIZY-|Az1eaNK21f_jPh+A
zA;qz7ze>x$W^>F@aGG?+q%9WeGU=L0-4^OG=`E8A7TRjkO_O>pR5Yn%W2^F6sASSt
zY;C7Qir+#5j4A<3K4|8Hmb|RUIW8Wqx13l}NJUdh2l2cuANF{nbYx0rRXtkM)o7(0
ztuCwhtL=Gjbnz{f=vrlkmEe$l7+1x5
z`T)-w*#0$mr^D6Ym`M13cn}|iyN%=FW$54?!wqg*p4vF4xIW+DX#zLH@mMcoP1(hE
zWsQezIUaJ@-MK{d!_H&ywsE(!g?DDzYG(1KlSSLiByhQpUmpZ
zc&%qZ_>6_iOf=(hk7P0GqDC@GF=2F%Q((twCY_v}%TDZXG#87*4g4Us0UAE;d4i3D
zNB1_=!_H_jna&(Zmd>f9WNl5{F-+0AeY?7Ns2}d&twY;pvECzl%{o|9$1^ouTeAB2
zc6>5(xpZ=0BcrzuzQcO&#!DLAzxdX9oMC&JW(k>O=%wx{7RxpIg{s9Ou`xKvq`+hW
zzv|1wIR4Yu-u^C4u#Zx|N3~%CfFC(=P29xcer2Q#Ko8dc>&41bll-xpXKlv4{(krm
DJ#ll_

delta 1189
zcmZ{iZAep57{~9k&CPA@Zf?^}({|PAoSOEAA!0N(B~9IYnbs`k%e~eTHSV-55)2~3
z4^cir&?iAEq!h=c`V#a)(1)P<5F&o4@LNT(D1t(;bFPsu%X8t+!}*=_|DWfcbF=Mp
z6MM&C&@p6qpIzxK&Wf?iklqapbAu6>5b#V$!9z$XsCWx<3R{MSPr9hOO_txKd*l&P
z%QPTUO#)4p>6lEl2~;Q3IhpDcXo^ff$kdQPS(%!Y^i;+KYLe*zrLDlirzTJ{Z*F1S
z)=<%XjIH`vP!oe*>!$6=_Sb-
z3n-Ufr^Em%r3-8kK#g?Ir~~yO@>|8d=+~#=OSTkOOfwLenn?u+;;i{6gz%Q72)E^G
zrN`D0$PUxhJE^1-X`EJw^g2a75w`^kY@;xZFU)?jn>
zmJ#$wDW@VmL&L=WX}(ogL6fLV;%wdo2$ILi!iK<5zN>swAiEam^VT+O+0Vm#7tG=N
zeBvwj5^$AmupW2ics5xZ*Q^_YEw$dQylEra{^4k(2e0K>aK)vCC#Wr)s1OKo|9w04
zv^gK0u!;xi4qZ6hJ4|~IheaiY#Z=m;9LBeW?NEm$ZoB;qnII30i9RP9R|3ES!;Y~F
dc+}1B=>Q;4>i>Fq@S9A2tmo$y(s#ED{s25*73=^2

diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/api.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/api.cpython-311.pyc
index 584e8d5c5adcaa639b2e8d8c1d6205b7bedabebc..14b4aae9a2c79cecf44922597764a72e3949f4e2 100644
GIT binary patch
literal 14123
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

delta 2500
zcmai$Z)_7~9LMka_jcFz+O8X2|6SK@bk~h;rF3H(6aVo?5=I8NU=hmTIvi|W^K>I%
zVz%fKctHruV~j>vh{kDLgv9wqLwuocNQ_BG8eAHT_(Bt2h$UcROhljG)6=m#jMw&i
z&wakX-}5}b>pf3yF?VCH<3qchXUOr~R~JTZ`{x{9c786p^I$+>72}wY7P7(#8~AW2
z){|y9BP(&av6^vv+RidL3%znwuMEr%MyZ))6h3QSFfz;{`Bjg!s2KM#vM~4FUfW%u
zcR3<5JNHO3d||{AD@mJ_l;WB-r%g(i;+Zw2%}TdYPtKOCHOncR@gX*9+^l$UhLxo-DfGqCCUtX1hz*3X(2
z$m|!Zr4dc9qdcnPUdmf_yn%9A$9AyKEWG=d(ElxiBwmYV;9=LX_u+(eQWywUCQ~
zi3k*o{5T`*VRztb!bM9EVq5Sw+dDC+5m|_o&EqGPQ6w7>?TIEEXfpCcOcZnW1Ura(
z?c3NOUanh@7wjE2h%K-XMh5uNo^ZWL+7F<=8Tvuh&=(xNtRK%h5<;3-Xd_6~`PtD=
zoMtg4WHioIH;>;GyNLS@aTSf5aBd+^&Y2WOHO@_EA8{P6q>$4%$OSpqh*QuwwQiW-
zfV)FDt#PippC-<)?mpo)onyntYc~=1Qf;5`y2j-^TZyyN(<7YKIG=i;;)*9FoYy!*
zbud3%mlWpKIGy;TdKl;X`flf2s}8g*crLOF_Xl_!@@^y{gWhELU1B_dM{$Pv&B8c6
z7oRVA)-Q|Ek{B&=QF7lQ<(?PrQmi2Zz3x9~Bf>|f10;)lBC{i*OZ0<{x}E{m-tv9-vxs>AdLpx9RfDd98d0~WvP
z9P#tm5lj;I*4e+d6G
zEZncXjc~utHg*d)A$-kU;c+km#SBJL!gt{QTk3v%qp1b+O-|xIYU+vKCT>CV$H~iL
ztR%*YTnxdgm8}B<1KYRn-!41xo_O6f-L@RiE8V+lp+z?^+Je3iZP8^;TkC*%iO43p
zT_6bnrO+Z2mi}Xu#u^@rP}{J`4RQK$V4Q6K?BlYv?rFD$El^S(@lPZCL6{US~Hj
z26I~lq}myDAv;l?oXUJAGcq+fg|e9pf_Dbgj7?n|rpv~{nL^oiDvJuE6S>T2Ze#+%
zYfL$qAI--zr^t>wf#Q>A@}s%qne6GwY!2cIbat9)|G{k;pHQa8vQMEiqzBk03qKL5
z7+IEGVZ<46g^3i`e(@V!yQVE{?~2JWvkN|VtbED3?(MFd*2bc>afOQ%b>BN&PjT(H
YV%cqEN#Re{i^uL$=iz_&W_q*!26*u?K>z>%

diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/macos.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/macos.cpython-311.pyc
index 2715d1f0fa38560301cc51dd1d2448111cdace7c..1d654bcfa12a7da6119cd3bc651b203db023fde0 100644
GIT binary patch
literal 8532
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

diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/unix.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/unix.cpython-311.pyc
index 5e198659dfcc8364366f418d687a54e424bc9067..03d8bc053a37a40fd40b857afc0913cbf1ef47cd 100644
GIT binary patch
delta 5907
zcmcIoeQXrR72mlp--qqJ^V#Qbv;Ov(^VtRm6bdFdb_gUfA;y%LhV$ZG+h?EeoY^%2
z2XanA18GqTOd^t0RghYdkW>v4twgJSNsS^!YN9he333e;Y8y5Ehh9V@MUkrZy;=M0
zfVE+Qxeiak;|Q#4XU1l2NCj2d_;j%gDRi-BaVnfFbUfQ
zrTDm@h-%RVvmm?!|Hd`qRw@)PXn2%L#Rtz4MVufbUd22l_^Zw&dwhOV%DzKasjSCn
z%03u-Ox5RTl-WtEl@>rFtcTpPy5U7+t)^z;W{;RE;|*ZWIYAXhh$4)b6f$B~ElRy&
zIc~WCHQzD%203B{yg{+$;5J^rAO|ntxIG8A^L89dczmS;2Ul?BC^$Lp%E4V62Or*H
zXd%aoa_}OK7iZ(p|41<}5VH#a7dh_E!QCA9rhUe58#9K3?#RfzXw&2gpDq|^Yls+4A>4xZKUTm#P#C*)C-s>~?`SCKyt}W8rerBE)rmyY#Y4Ns2bJgs2Wlahc#Wx)VN^t
z6!4y@>+&ybW>Zlua8bk6DM?ghAKF_;6Wiq}V-Cl5(F5>TjtDfcU(@Lm>|Kw~`bWS{
zus_(Q*fmGJ{iHBX6zg$26T2$d-$WmKt);l7U&x*+@S<%nRkW{vd#Hcgo^7H29ghvs
za>iWs{xJg0Enil6@d^UDy$N1kA?Jh%;i&LL`7!dM={%DQN}1^N#Lt*cRSXFig^Pr)
zfod1cDO0d3MP_L|{L(ORNYVlo;rW$wGnzgYo0;vMZ^KCphP1G*h7?(sLrR!x!OfA_
zm>ki1;bplda6`D=3gXKJAt4SM_Z81+%QbiRRd;v%QvIU4C+Y6Vlu`7O-$pCpL90+y
zqo@IqD!|#%)Y+6(n~j8ZDgnryJqpgo3gR6W&6no0vlG=0g7|X5B77=(n7?pC-;!xy
z#}(yQQ$L&fu;jN@i@kf2y?X#!6o->wynUEkm*r)25&V`3lu;yIOiTKqYNGhy@|-7Tl#tvGJtky68RiOj;n0>g(R}SINs8PY&J?
zJ*Vcs6aQBHRee!xN{UShdlU7r-HuB3d)vos#Qj!7IkYnGc&0Nr7K@IDCujxyUhy|4
zcax``+z;gb2H~pK_n``>vd5&Dj}gvg%W-hXc?;65ScmfEYs$*bwD=C>p|*7}B_g%&
z-!=Ha4q!MZH>l0qJ5_zG^RP0J<^F$z

R0+fevHWRaT&u#5IpY%#`tS6&ZcGaV@I z&R2>=qe0;jkP^IRQPpEmbyYX>zWm(}qUv4{u!NAU2RsdIbE*CR&R7R$>^cZ3Y`?pn zy;u@+t(ugx-W~203S&S98b9vs4KCAo3s_9oq2Nmy2~3fj6hp!aZ*O|rdxsIhvJ7vV z{}bNsEW1$8d22`B%43siKH7SGZR8-(ww%3DS;eM(Yk|J!d=Had?9aXp7F1*Rxyqz@ zXXhcAb{fqfX&^%Kn1~@3WBcy%w#FGW9G3t{AN2fwEK6VcW}RW2mytMzQTZY^yK8ep(qY))+Z;wn`%RKup<21m@}TF}Krg zf>*g}Zl{et2r8+9*lai&jztZ(<9@{5o~jAOW_7?}Gd&U-qbhWb>{iDh(>t=lPrkHG z)lIvOVgLOgmd2J88(>mg;;GGP!Q|+<;VpZ4qfy1)-|^)CytIc?d2YiqigQdh!eYKmZVa`hnlpk|-vQ8YNK z-n!Z@>D#DS#*O&`9Nm~`yyw!fMR6c04kYXYy!AfzUag!*eM4PPI-N)T=%U!46#EnQ z{w4MI>mJXe-nFKkyu$XcspB^Gv7fIQ&Qq&FY9p_+hooAgmS^iG$`j{JkfvzUdTf>@ zYFgvQ>*%Nv;ra)L9@?|(Q4DbyY5R>*n&SYlJ>{O$R2o`p3#V+SWA~KaCv55&)=?F)c>WoWay;YN< zpah*lHXG;rJcu3R(vjF4SfEW}+eT7p3{PIw%u0V~5gKpM2`o~B6G3Tov=fHei57Ks zjgAJe-#o+54AQw|HkiV`->{YSxk}BeU6ZkN*-ko!lZ+Ih3JBPIF&ILh^A?nTd%paP zPGbEqiYXMBP-fEtfRvjjjhR_$$#6Lv57R49TSGe*gfD7Xtf{fh;;6eJmYh0zO>DU; zwj^4&FNzN)#Rt=Zxv1`XdHre2Y0J&>+S3;Htgj4sSJJ$nOtNTmml@`eeXn`Mg9%c0 zaIv?vk&jq+OB2*DZ{Ev(*y1k=EO}eQxd*+C<#ZMmx8`VfwFb!VK)bSV$D+71Deg?z zcfuNjhDexw+}gd=@p1zLISqWht({!Q2H1DoTwubRZSSn(dnQjERyIytZhj;2qle%< zvwvcXv+TIPo!nsW`tObNGe*(!37(%bvhpR&F&i;mMOQo|5IDCV6>zqUYp-yQ5JWIY z^J_p*$kS%PO)psBlLWz}V7_P5k+2$3HsQ(4;Jh4FB$&XsDj6Bg9DG55%|=?@VZy2w z9E1_v3yo5q8mx}-0H)kpjSvci*9i#RV8@c9TtX-S3heCL|W?yUXimwce zueX&c=L@J0`{OGC(-jKIu|OX~fmtBkhhjg911Mw^5fo7rPomIJ%%R|`avtA~qTu&CROEHcFi zw6jkG@dpac)^-SwS;A?ywjq{Ra9VJur3%#Op%8?9T6+1p4htdW>_o8k;XKI#R#{SlgX(x%>wHhB;$hsRUt(gQ&;7>+zcx{!J_NdcA#MzvK2aC?*5zD zJ&G@}P=Y`Q`%AGL6Fd-4p6519K3jZGDV zLJ(}BwI!BAUHs(nm3{L}Oqq+Qz4UeXiD6r-2bne#Laqz01=mfXA(3^nzw~UZxGpp& z^4+ZNp26rIGXZksmnXM=&P)Ejx;$ztAZ2MGTa@~UJ1u039>MBLn@uj$LIM79w*3nm Ce3jw= delta 3728 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 E8x!NcasU7T delta 190 zcmZ3)dW@-lIWI340}wbL>PuSyq#uJgFu(+5d=>*TrZc24R4_&{L@}l?0%@iw<`kx2 z22JKFR%1O2Jwr|Am&`y_FF8O2BaraZWVyv1A77SQRGgWg7axC%9m>2Vh!CClTx@bZ wW4#d%Pyz3zz|6?V_<@ZW1XJ_Y|nVp;2o4Zu_mb!oGaw!PL=x49Z{IvTGcNpJ!qkGpyF)tP5l#CI0T3 z!$hAnQFw?)JiAP^V50tQsK-R#G11^Q)Mui96+$N?B(x3nbCiU)$pfamX`4Jqq)8NO zu3As#ilnrlXKR=_Eb&?OiCM##)AuElc`Zwei9&9gmh{q$k(e$Ol3Fo7uO}DkCVU;} zPwKN;KA${SEG-mgN_nEu92w4}6N;k37|)*5bah_W)Y6P<%xY>TJ2zL%7Bn^|wl{6? z!1`=n#5QqF~Ml0&`R7-0Ya=M{EuyRSh za*OnVfTQI#>n8&4D!---2=XA5S07?8g&UctA;P|Kev0?Ak6nMmPnCb-{tV;M@|5=~ zmXC6^{TpgkJXQXxVG-j~WfEA%_%us~qUCRceHfo9CqrWx=S|7a!tEHpQ2uSx<5)fq z4(MU_y1SMAA)NIc-bXcKo)-71MAOe1r8%~zDSEM2)e>hCY9`ZpVsiBOvEvg5$BvA4 zJ~vWV$z-aH2PVfxj-*FMCl60e92*%sK6+qk;`k~06!)IwG4i{w(lF4f7t%}98~)QI zM_&wY6gBZE@?&n=&h~~Hy@zh8Pp_*_-|~#Dd&bsmW95HG)-YaSe{P;)k}K{z_#kpR zUo>)1F`qlgRHyZ#4&_s`x|%V)Z=n3#ObpX0IAME)dd|?&n=~Ir_$cxUkI)5V1=VEa z4Xk@Q)@&U#0+N_O9k8&jmM+}L##=5~>!mA%I zNYCIJdPwhCknCRlVNC!LtL|uvd123Yom{Ik_=i~z64ZQl9$CL zM11V`iNW|LUDB{MkV!c3p(ki$ex@dyWXdBw${tVdvi`#hY|PH4le zg^_s!%jem9$uhpjPVV_$xX6{=Re9Q2oYQn#F9gWgulE=OR`uBdI59Xl(L zXr;Ne(iG+YXiKH7qvluqat#6bCV;HUrRmGNUoNedYC$AvN^+ znsH0%T~~Tn4%~JHuCQ9)GuDbH_=TtEb2i-ns`@UR{wA{Xdx79yAmhPD7t)W2z`p8l z9WHv?ks*WT#^^xQg3&2d6c^A1%PF*gHynt|*mzJqgeDQUV;uvDBRuV94r11Nnyj-~ zJ!=@0@*GqhV}-dAHAX2dQM$-=`E92B-GO(S=hc+z+>OfK8feM958QuX>Q{h3>I7Me zS8Tz{F8=%4hMfK@LvKBH%h9p!=%^uVkKgw9t~q;a7GUpxZAH!yNF~=pQn5KNivUZm z`}gnH6n1A|cq9tGFNv+_=Sq*|SGdRW8*v}{*!O+68}zgB!PEUq7(-L~|MYU{o{9Wx lGyW3$axnH}6h~@kD|w;=2Wx06If`Alw}!S7l^q(||36=ucsT$7 delta 2182 zcma)7Z){Ul6uA0oto;Ec(@VF`9+_l*_$XWaKH zgREI4ixMNo<;F}6L5<0bnZ`(?eozwdlO`sPxR}~7gCFpVkkmhkiAv(RuiIe558n6g z@1A>p=bn4dz3<$2kDia&-m_X|1ZD4+uZ$^MW^GRV^Xyj7v>|E?8VM$1)D)9~5=I~! zqvn_;XaU(oq^KM#3Kn6cSf~j&bF?^S4O%f0&^|;gGl9*~wL`xY+EQrCpe-X#;()eXKrR6(5;1&GF^|Co)ItGm`RuJa$wA~3I9S0%oa&tb zb`B{hhzSY`1P2X@2#&-VaUKROtPVvGj**xyVNy-x8B@^2t=LsuRqZ6j580Y^_O8yt zk~esgb+%66VMVq{fwk#uN@pS14Xj;fKNPBVJ4xk3Y#C=s)kFGnVjMzV zS56v^#7W|e8mb;HT4UF>;h zCA(F86Zf&J)^G8i%thPR81Ksr+uy>br?^SaiiwLgmtDh8XYQ7r#rSCEgd>G9VfD2& zS1SD&N4S(3tny(T*Tp$!6E>;f;P*yw;K(dhyRl^w`t%?`=0NQt#wk{_=@5Igz6Cp2 zqW(PlyS~O%B_Nbud-8&8H0KcqXQs{lBW8g{mj#)Oo;-(4ve6;nBkZNk2aO82eKC{U zTqKGI_bD3t#q&u+7<67tk3ggHBym$GAboZfE@iHJsenIc9nGJyJIxFD7<;|tkSWCZ z5%yb4coQF*D^un8?I7Wnj~7 zb;gnz1kyWg_1n9(|2Lx%{M>D8*lIYbUvS*}lo8go?oy({lrd$PLd4EG{hb33*pkxq z>l%Xj?|XuLD?3*O=in~vn)^&d8+VUtXD1ZZ$3FFY1h1Lh_IsR9(qk}j1VO|((;3Lm zXq56;+2%k7-)7msZf69#UK=f(3dlKA!4GR~*IG>a>E?;gf*#vLRP(*4>z`Z^*i8vbCGC)iwOBsmqsI%1wC$ z@Mjs4y+F9*{w-yG8TH@H%?wF5=)?^wT;RC@3O7(y0A1cIW56w=JA;}IG{O-Pg3 zPo2I29;Uu)UMVMyht;sAQF@Upd9YODz(3Pm(c>|G$vsACf>NF_kR6=Wvx6P&s`Flk zUY={70Z5}|$#(I%S0`^s?j^~cN7(3HF7YgyJ$Zp;yZSqe!RWH+MempP8NR@M1~1M@ zvGAlCIj49<{bVRNp+y|H#I-Eg?ee_IJC*b>G&wmG8cS;Y$_i1QA%&%va_Kai>mHcq zD=lO#kD?G1Unq3|rWP0()yD{a+(e87!GI{!=>}zcp>qt&iwHpA7?jrc>7$~l}GDgR|Brd TqxG;Kn{jg`_. Makes use of the - `appname `, - `version `, - `ensure_exists `. + Follows the guidance `from here `_. + + Makes use of the `appname `, `version + `, `ensure_exists `. + """ @property @@ -43,7 +45,7 @@ def site_config_dir(self) -> str: @property def user_cache_dir(self) -> str: - """:return: cache directory tied to the user, e.g. e.g. ``/data/user///cache/``""" + """:return: cache directory tied to the user, e.g.,``/data/user///cache/``""" return self._append_app_name_and_version(cast(str, _android_folder()), "cache") @property @@ -92,6 +94,11 @@ def user_music_dir(self) -> str: """:return: music directory tied to the user e.g. ``/storage/emulated/0/Music``""" return _android_music_folder() + @property + def user_desktop_dir(self) -> str: + """:return: desktop directory tied to the user e.g. ``/storage/emulated/0/Desktop``""" + return "/storage/emulated/0/Desktop" + @property def user_runtime_dir(self) -> str: """ @@ -103,18 +110,23 @@ def user_runtime_dir(self) -> str: path = os.path.join(path, "tmp") # noqa: PTH118 return path + @property + def site_runtime_dir(self) -> str: + """:return: runtime directory shared by users, same as `user_runtime_dir`""" + return self.user_runtime_dir + @lru_cache(maxsize=1) def _android_folder() -> str | None: """:return: base folder for the Android OS or None if it cannot be found""" try: - # First try to get path to android app via pyjnius - from jnius import autoclass + # First try to get a path to android app via pyjnius + from jnius import autoclass # noqa: PLC0415 context = autoclass("android.content.Context") result: str | None = context.getFilesDir().getParentFile().getAbsolutePath() except Exception: # noqa: BLE001 - # if fails find an android folder looking path on the sys.path + # if fails find an android folder looking a path on the sys.path pattern = re.compile(r"/data/(data|user/\d+)/(.+)/files") for path in sys.path: if pattern.match(path): @@ -130,7 +142,7 @@ def _android_documents_folder() -> str: """:return: documents folder for the Android OS""" # Get directories with pyjnius try: - from jnius import autoclass + from jnius import autoclass # noqa: PLC0415 context = autoclass("android.content.Context") environment = autoclass("android.os.Environment") @@ -146,7 +158,7 @@ def _android_downloads_folder() -> str: """:return: downloads folder for the Android OS""" # Get directories with pyjnius try: - from jnius import autoclass + from jnius import autoclass # noqa: PLC0415 context = autoclass("android.content.Context") environment = autoclass("android.os.Environment") @@ -162,7 +174,7 @@ def _android_pictures_folder() -> str: """:return: pictures folder for the Android OS""" # Get directories with pyjnius try: - from jnius import autoclass + from jnius import autoclass # noqa: PLC0415 context = autoclass("android.content.Context") environment = autoclass("android.os.Environment") @@ -178,7 +190,7 @@ def _android_videos_folder() -> str: """:return: videos folder for the Android OS""" # Get directories with pyjnius try: - from jnius import autoclass + from jnius import autoclass # noqa: PLC0415 context = autoclass("android.content.Context") environment = autoclass("android.os.Environment") @@ -194,7 +206,7 @@ def _android_music_folder() -> str: """:return: music folder for the Android OS""" # Get directories with pyjnius try: - from jnius import autoclass + from jnius import autoclass # noqa: PLC0415 context = autoclass("android.content.Context") environment = autoclass("android.os.Environment") diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/api.py b/myenv/Lib/site-packages/pip/_vendor/platformdirs/api.py index d64ebb9..c50caa6 100644 --- a/myenv/Lib/site-packages/pip/_vendor/platformdirs/api.py +++ b/myenv/Lib/site-packages/pip/_vendor/platformdirs/api.py @@ -1,4 +1,5 @@ """Base API.""" + from __future__ import annotations import os @@ -7,18 +8,13 @@ from typing import TYPE_CHECKING if TYPE_CHECKING: - import sys - - if sys.version_info >= (3, 8): # pragma: no cover (py38+) - from typing import Literal - else: # pragma: no cover (py38+) - from pip._vendor.typing_extensions import Literal + from typing import Iterator, Literal -class PlatformDirsABC(ABC): +class PlatformDirsABC(ABC): # noqa: PLR0904 """Abstract base class for platform directories.""" - def __init__( # noqa: PLR0913 + def __init__( # noqa: PLR0913, PLR0917 self, appname: str | None = None, appauthor: str | None | Literal[False] = None, @@ -38,34 +34,47 @@ def __init__( # noqa: PLR0913 :param multipath: See `multipath`. :param opinion: See `opinion`. :param ensure_exists: See `ensure_exists`. + """ self.appname = appname #: The name of application. self.appauthor = appauthor """ - The name of the app author or distributing body for this application. Typically, it is the owning company name. - Defaults to `appname`. You may pass ``False`` to disable it. + The name of the app author or distributing body for this application. + + Typically, it is the owning company name. Defaults to `appname`. You may pass ``False`` to disable it. + """ self.version = version """ - An optional version path element to append to the path. You might want to use this if you want multiple versions - of your app to be able to run independently. If used, this would typically be ``.``. + An optional version path element to append to the path. + + You might want to use this if you want multiple versions of your app to be able to run independently. If used, + this would typically be ``.``. + """ self.roaming = roaming """ - Whether to use the roaming appdata directory on Windows. That means that for users on a Windows network setup - for roaming profiles, this user data will be synced on login (see - `here `_). + Whether to use the roaming appdata directory on Windows. + + That means that for users on a Windows network setup for roaming profiles, this user data will be synced on + login (see + `here `_). + """ self.multipath = multipath """ - An optional parameter only applicable to Unix/Linux which indicates that the entire list of data dirs should be - returned. By default, the first item would only be returned. + An optional parameter which indicates that the entire list of data dirs should be returned. + + By default, the first item would only be returned. + """ self.opinion = opinion #: A flag to indicating to use opinionated values. self.ensure_exists = ensure_exists """ Optionally create the directory (and any missing parents) upon access if it does not exist. + By default, no directories are created. + """ def _append_app_name_and_version(self, *base: str) -> str: @@ -147,11 +156,21 @@ def user_videos_dir(self) -> str: def user_music_dir(self) -> str: """:return: music directory tied to the user""" + @property + @abstractmethod + def user_desktop_dir(self) -> str: + """:return: desktop directory tied to the user""" + @property @abstractmethod def user_runtime_dir(self) -> str: """:return: runtime directory tied to the user""" + @property + @abstractmethod + def site_runtime_dir(self) -> str: + """:return: runtime directory shared by users""" + @property def user_data_path(self) -> Path: """:return: data path tied to the user""" @@ -194,7 +213,7 @@ def user_log_path(self) -> Path: @property def user_documents_path(self) -> Path: - """:return: documents path tied to the user""" + """:return: documents a path tied to the user""" return Path(self.user_documents_dir) @property @@ -217,7 +236,57 @@ def user_music_path(self) -> Path: """:return: music path tied to the user""" return Path(self.user_music_dir) + @property + def user_desktop_path(self) -> Path: + """:return: desktop path tied to the user""" + return Path(self.user_desktop_dir) + @property def user_runtime_path(self) -> Path: """:return: runtime path tied to the user""" return Path(self.user_runtime_dir) + + @property + def site_runtime_path(self) -> Path: + """:return: runtime path shared by users""" + return Path(self.site_runtime_dir) + + def iter_config_dirs(self) -> Iterator[str]: + """:yield: all user and site configuration directories.""" + yield self.user_config_dir + yield self.site_config_dir + + def iter_data_dirs(self) -> Iterator[str]: + """:yield: all user and site data directories.""" + yield self.user_data_dir + yield self.site_data_dir + + def iter_cache_dirs(self) -> Iterator[str]: + """:yield: all user and site cache directories.""" + yield self.user_cache_dir + yield self.site_cache_dir + + def iter_runtime_dirs(self) -> Iterator[str]: + """:yield: all user and site runtime directories.""" + yield self.user_runtime_dir + yield self.site_runtime_dir + + def iter_config_paths(self) -> Iterator[Path]: + """:yield: all user and site configuration paths.""" + for path in self.iter_config_dirs(): + yield Path(path) + + def iter_data_paths(self) -> Iterator[Path]: + """:yield: all user and site data paths.""" + for path in self.iter_data_dirs(): + yield Path(path) + + def iter_cache_paths(self) -> Iterator[Path]: + """:yield: all user and site cache paths.""" + for path in self.iter_cache_dirs(): + yield Path(path) + + def iter_runtime_paths(self) -> Iterator[Path]: + """:yield: all user and site runtime paths.""" + for path in self.iter_runtime_dirs(): + yield Path(path) diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/macos.py b/myenv/Lib/site-packages/pip/_vendor/platformdirs/macos.py index a753e2a..eb1ba5d 100644 --- a/myenv/Lib/site-packages/pip/_vendor/platformdirs/macos.py +++ b/myenv/Lib/site-packages/pip/_vendor/platformdirs/macos.py @@ -1,18 +1,23 @@ """macOS.""" + from __future__ import annotations import os.path +import sys from .api import PlatformDirsABC class MacOS(PlatformDirsABC): """ - Platform directories for the macOS operating system. Follows the guidance from `Apple documentation - `_. + Platform directories for the macOS operating system. + + Follows the guidance from + `Apple documentation `_. Makes use of the `appname `, `version `, `ensure_exists `. + """ @property @@ -22,8 +27,20 @@ def user_data_dir(self) -> str: @property def site_data_dir(self) -> str: - """:return: data directory shared by users, e.g. ``/Library/Application Support/$appname/$version``""" - return self._append_app_name_and_version("/Library/Application Support") + """ + :return: data directory shared by users, e.g. ``/Library/Application Support/$appname/$version``. + If we're using a Python binary managed by `Homebrew `_, the directory + will be under the Homebrew prefix, e.g. ``/opt/homebrew/share/$appname/$version``. + If `multipath ` is enabled, and we're in Homebrew, + the response is a multi-path string separated by ":", e.g. + ``/opt/homebrew/share/$appname/$version:/Library/Application Support/$appname/$version`` + """ + is_homebrew = sys.prefix.startswith("/opt/homebrew") + path_list = [self._append_app_name_and_version("/opt/homebrew/share")] if is_homebrew else [] + path_list.append(self._append_app_name_and_version("/Library/Application Support")) + if self.multipath: + return os.pathsep.join(path_list) + return path_list[0] @property def user_config_dir(self) -> str: @@ -42,8 +59,20 @@ def user_cache_dir(self) -> str: @property def site_cache_dir(self) -> str: - """:return: cache directory shared by users, e.g. ``/Library/Caches/$appname/$version``""" - return self._append_app_name_and_version("/Library/Caches") + """ + :return: cache directory shared by users, e.g. ``/Library/Caches/$appname/$version``. + If we're using a Python binary managed by `Homebrew `_, the directory + will be under the Homebrew prefix, e.g. ``/opt/homebrew/var/cache/$appname/$version``. + If `multipath ` is enabled, and we're in Homebrew, + the response is a multi-path string separated by ":", e.g. + ``/opt/homebrew/var/cache/$appname/$version:/Library/Caches/$appname/$version`` + """ + is_homebrew = sys.prefix.startswith("/opt/homebrew") + path_list = [self._append_app_name_and_version("/opt/homebrew/var/cache")] if is_homebrew else [] + path_list.append(self._append_app_name_and_version("/Library/Caches")) + if self.multipath: + return os.pathsep.join(path_list) + return path_list[0] @property def user_state_dir(self) -> str: @@ -80,11 +109,21 @@ def user_music_dir(self) -> str: """:return: music directory tied to the user, e.g. ``~/Music``""" return os.path.expanduser("~/Music") # noqa: PTH111 + @property + def user_desktop_dir(self) -> str: + """:return: desktop directory tied to the user, e.g. ``~/Desktop``""" + return os.path.expanduser("~/Desktop") # noqa: PTH111 + @property def user_runtime_dir(self) -> str: """:return: runtime directory tied to the user, e.g. ``~/Library/Caches/TemporaryItems/$appname/$version``""" return self._append_app_name_and_version(os.path.expanduser("~/Library/Caches/TemporaryItems")) # noqa: PTH111 + @property + def site_runtime_dir(self) -> str: + """:return: runtime directory shared by users, same as `user_runtime_dir`""" + return self.user_runtime_dir + __all__ = [ "MacOS", diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/unix.py b/myenv/Lib/site-packages/pip/_vendor/platformdirs/unix.py index 468b0ab..9500ade 100644 --- a/myenv/Lib/site-packages/pip/_vendor/platformdirs/unix.py +++ b/myenv/Lib/site-packages/pip/_vendor/platformdirs/unix.py @@ -1,16 +1,18 @@ """Unix.""" + from __future__ import annotations import os import sys from configparser import ConfigParser from pathlib import Path +from typing import Iterator, NoReturn from .api import PlatformDirsABC if sys.platform == "win32": - def getuid() -> int: + def getuid() -> NoReturn: msg = "should only be used on Unix" raise RuntimeError(msg) @@ -18,17 +20,17 @@ def getuid() -> int: from os import getuid -class Unix(PlatformDirsABC): +class Unix(PlatformDirsABC): # noqa: PLR0904 """ - On Unix/Linux, we follow the - `XDG Basedir Spec `_. The spec allows - overriding directories with environment variables. The examples show are the default values, alongside the name of - the environment variable that overrides them. Makes use of the - `appname `, - `version `, - `multipath `, - `opinion `, - `ensure_exists `. + On Unix/Linux, we follow the `XDG Basedir Spec `_. + + The spec allows overriding directories with environment variables. The examples shown are the default values, + alongside the name of the environment variable that overrides them. Makes use of the `appname + `, `version `, `multipath + `, `opinion `, `ensure_exists + `. + """ @property @@ -42,25 +44,25 @@ def user_data_dir(self) -> str: path = os.path.expanduser("~/.local/share") # noqa: PTH111 return self._append_app_name_and_version(path) + @property + def _site_data_dirs(self) -> list[str]: + path = os.environ.get("XDG_DATA_DIRS", "") + if not path.strip(): + path = f"/usr/local/share{os.pathsep}/usr/share" + return [self._append_app_name_and_version(p) for p in path.split(os.pathsep)] + @property def site_data_dir(self) -> str: """ :return: data directories shared by users (if `multipath ` is - enabled and ``XDG_DATA_DIR`` is set and a multi path the response is also a multi path separated by the OS - path separator), e.g. ``/usr/local/share/$appname/$version`` or ``/usr/share/$appname/$version`` + enabled and ``XDG_DATA_DIRS`` is set and a multi path the response is also a multi path separated by the + OS path separator), e.g. ``/usr/local/share/$appname/$version`` or ``/usr/share/$appname/$version`` """ # XDG default for $XDG_DATA_DIRS; only first, if multipath is False - path = os.environ.get("XDG_DATA_DIRS", "") - if not path.strip(): - path = f"/usr/local/share{os.pathsep}/usr/share" - return self._with_multi_path(path) - - def _with_multi_path(self, path: str) -> str: - path_list = path.split(os.pathsep) + dirs = self._site_data_dirs if not self.multipath: - path_list = path_list[0:1] - path_list = [self._append_app_name_and_version(os.path.expanduser(p)) for p in path_list] # noqa: PTH111 - return os.pathsep.join(path_list) + return dirs[0] + return os.pathsep.join(dirs) @property def user_config_dir(self) -> str: @@ -73,18 +75,25 @@ def user_config_dir(self) -> str: path = os.path.expanduser("~/.config") # noqa: PTH111 return self._append_app_name_and_version(path) + @property + def _site_config_dirs(self) -> list[str]: + path = os.environ.get("XDG_CONFIG_DIRS", "") + if not path.strip(): + path = "/etc/xdg" + return [self._append_app_name_and_version(p) for p in path.split(os.pathsep)] + @property def site_config_dir(self) -> str: """ :return: config directories shared by users (if `multipath ` - is enabled and ``XDG_DATA_DIR`` is set and a multi path the response is also a multi path separated by the OS - path separator), e.g. ``/etc/xdg/$appname/$version`` + is enabled and ``XDG_CONFIG_DIRS`` is set and a multi path the response is also a multi path separated by + the OS path separator), e.g. ``/etc/xdg/$appname/$version`` """ # XDG default for $XDG_CONFIG_DIRS only first, if multipath is False - path = os.environ.get("XDG_CONFIG_DIRS", "") - if not path.strip(): - path = "/etc/xdg" - return self._with_multi_path(path) + dirs = self._site_config_dirs + if not self.multipath: + return dirs[0] + return os.pathsep.join(dirs) @property def user_cache_dir(self) -> str: @@ -99,8 +108,8 @@ def user_cache_dir(self) -> str: @property def site_cache_dir(self) -> str: - """:return: cache directory shared by users, e.g. ``/var/tmp/$appname/$version``""" - return self._append_app_name_and_version("/var/tmp") # noqa: S108 + """:return: cache directory shared by users, e.g. ``/var/cache/$appname/$version``""" + return self._append_app_name_and_version("/var/cache") @property def user_state_dir(self) -> str: @@ -119,6 +128,7 @@ def user_log_dir(self) -> str: path = self.user_state_dir if self.opinion: path = os.path.join(path, "log") # noqa: PTH118 + self._optionally_create_directory(path) return path @property @@ -146,6 +156,11 @@ def user_music_dir(self) -> str: """:return: music directory tied to the user, e.g. ``~/Music``""" return _get_user_media_dir("XDG_MUSIC_DIR", "~/Music") + @property + def user_desktop_dir(self) -> str: + """:return: desktop directory tied to the user, e.g. ``~/Desktop``""" + return _get_user_media_dir("XDG_DESKTOP_DIR", "~/Desktop") + @property def user_runtime_dir(self) -> str: """ @@ -166,19 +181,41 @@ def user_runtime_dir(self) -> str: path = f"/run/user/{getuid()}" return self._append_app_name_and_version(path) + @property + def site_runtime_dir(self) -> str: + """ + :return: runtime directory shared by users, e.g. ``/run/$appname/$version`` or \ + ``$XDG_RUNTIME_DIR/$appname/$version``. + + Note that this behaves almost exactly like `user_runtime_dir` if ``$XDG_RUNTIME_DIR`` is set, but will + fall back to paths associated to the root user instead of a regular logged-in user if it's not set. + + If you wish to ensure that a logged-in root user path is returned e.g. ``/run/user/0``, use `user_runtime_dir` + instead. + + For FreeBSD/OpenBSD/NetBSD, it would return ``/var/run/$appname/$version`` if ``$XDG_RUNTIME_DIR`` is not set. + """ + path = os.environ.get("XDG_RUNTIME_DIR", "") + if not path.strip(): + if sys.platform.startswith(("freebsd", "openbsd", "netbsd")): + path = "/var/run" + else: + path = "/run" + return self._append_app_name_and_version(path) + @property def site_data_path(self) -> Path: - """:return: data path shared by users. Only return first item, even if ``multipath`` is set to ``True``""" + """:return: data path shared by users. Only return the first item, even if ``multipath`` is set to ``True``""" return self._first_item_as_path_if_multipath(self.site_data_dir) @property def site_config_path(self) -> Path: - """:return: config path shared by the users. Only return first item, even if ``multipath`` is set to ``True``""" + """:return: config path shared by the users, returns the first item, even if ``multipath`` is set to ``True``""" return self._first_item_as_path_if_multipath(self.site_config_dir) @property def site_cache_path(self) -> Path: - """:return: cache path shared by users. Only return first item, even if ``multipath`` is set to ``True``""" + """:return: cache path shared by users. Only return the first item, even if ``multipath`` is set to ``True``""" return self._first_item_as_path_if_multipath(self.site_cache_dir) def _first_item_as_path_if_multipath(self, directory: str) -> Path: @@ -187,6 +224,16 @@ def _first_item_as_path_if_multipath(self, directory: str) -> Path: directory = directory.split(os.pathsep)[0] return Path(directory) + def iter_config_dirs(self) -> Iterator[str]: + """:yield: all user and site configuration directories.""" + yield self.user_config_dir + yield from self._site_config_dirs + + def iter_data_dirs(self) -> Iterator[str]: + """:yield: all user and site data directories.""" + yield self.user_data_dir + yield from self._site_data_dirs + def _get_user_media_dir(env_var: str, fallback_tilde_path: str) -> str: media_dir = _get_user_dirs_folder(env_var) @@ -199,7 +246,12 @@ def _get_user_media_dir(env_var: str, fallback_tilde_path: str) -> str: def _get_user_dirs_folder(key: str) -> str | None: - """Return directory from user-dirs.dirs config file. See https://freedesktop.org/wiki/Software/xdg-user-dirs/.""" + """ + Return directory from user-dirs.dirs config file. + + See https://freedesktop.org/wiki/Software/xdg-user-dirs/. + + """ user_dirs_config_path = Path(Unix().user_config_dir) / "user-dirs.dirs" if user_dirs_config_path.exists(): parser = ConfigParser() diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/version.py b/myenv/Lib/site-packages/pip/_vendor/platformdirs/version.py index dc8c44c..c418cd0 100644 --- a/myenv/Lib/site-packages/pip/_vendor/platformdirs/version.py +++ b/myenv/Lib/site-packages/pip/_vendor/platformdirs/version.py @@ -1,4 +1,16 @@ # file generated by setuptools_scm # don't change, don't track in version control -__version__ = version = '3.8.1' -__version_tuple__ = version_tuple = (3, 8, 1) +TYPE_CHECKING = False +if TYPE_CHECKING: + from typing import Tuple, Union + VERSION_TUPLE = Tuple[Union[int, str], ...] +else: + VERSION_TUPLE = object + +version: str +__version__: str +__version_tuple__: VERSION_TUPLE +version_tuple: VERSION_TUPLE + +__version__ = version = '4.2.1' +__version_tuple__ = version_tuple = (4, 2, 1) diff --git a/myenv/Lib/site-packages/pip/_vendor/platformdirs/windows.py b/myenv/Lib/site-packages/pip/_vendor/platformdirs/windows.py index b52c9c6..d7bc960 100644 --- a/myenv/Lib/site-packages/pip/_vendor/platformdirs/windows.py +++ b/myenv/Lib/site-packages/pip/_vendor/platformdirs/windows.py @@ -1,7 +1,7 @@ """Windows.""" + from __future__ import annotations -import ctypes import os import sys from functools import lru_cache @@ -15,15 +15,13 @@ class Windows(PlatformDirsABC): """ - `MSDN on where to store app data files - `_. - Makes use of the - `appname `, - `appauthor `, - `version `, - `roaming `, - `opinion `, - `ensure_exists `. + `MSDN on where to store app data files `_. + + Makes use of the `appname `, `appauthor + `, `version `, `roaming + `, `opinion `, `ensure_exists + `. + """ @property @@ -122,6 +120,11 @@ def user_music_dir(self) -> str: """:return: music directory tied to the user e.g. ``%USERPROFILE%\\Music``""" return os.path.normpath(get_win_folder("CSIDL_MYMUSIC")) + @property + def user_desktop_dir(self) -> str: + """:return: desktop directory tied to the user, e.g. ``%USERPROFILE%\\Desktop``""" + return os.path.normpath(get_win_folder("CSIDL_DESKTOPDIRECTORY")) + @property def user_runtime_dir(self) -> str: """ @@ -131,6 +134,11 @@ def user_runtime_dir(self) -> str: path = os.path.normpath(os.path.join(get_win_folder("CSIDL_LOCAL_APPDATA"), "Temp")) # noqa: PTH118 return self._append_parts(path) + @property + def site_runtime_dir(self) -> str: + """:return: runtime directory shared by users, same as `user_runtime_dir`""" + return self.user_runtime_dir + def get_win_folder_from_env_vars(csidl_name: str) -> str: """Get folder from environment variables.""" @@ -154,7 +162,7 @@ def get_win_folder_from_env_vars(csidl_name: str) -> str: def get_win_folder_if_csidl_name_not_env_var(csidl_name: str) -> str | None: - """Get folder for a CSIDL name that does not exist as an environment variable.""" + """Get a folder for a CSIDL name that does not exist as an environment variable.""" if csidl_name == "CSIDL_PERSONAL": return os.path.join(os.path.normpath(os.environ["USERPROFILE"]), "Documents") # noqa: PTH118 @@ -178,6 +186,7 @@ def get_win_folder_from_registry(csidl_name: str) -> str: This is a fallback technique at best. I'm not sure if using the registry for these guarantees us the correct answer for all CSIDL_* names. + """ shell_folder_name = { "CSIDL_APPDATA": "AppData", @@ -194,7 +203,7 @@ def get_win_folder_from_registry(csidl_name: str) -> str: raise ValueError(msg) if sys.platform != "win32": # only needed for mypy type checker to know that this code runs only on Windows raise NotImplementedError - import winreg + import winreg # noqa: PLC0415 key = winreg.OpenKey(winreg.HKEY_CURRENT_USER, r"Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders") directory, _ = winreg.QueryValueEx(key, shell_folder_name) @@ -207,6 +216,8 @@ def get_win_folder_via_ctypes(csidl_name: str) -> str: # Use 'CSIDL_PROFILE' (40) and append the default folder 'Downloads' instead. # https://learn.microsoft.com/en-us/windows/win32/shell/knownfolderid + import ctypes # noqa: PLC0415 + csidl_const = { "CSIDL_APPDATA": 26, "CSIDL_COMMON_APPDATA": 35, @@ -216,6 +227,7 @@ def get_win_folder_via_ctypes(csidl_name: str) -> str: "CSIDL_MYVIDEO": 14, "CSIDL_MYMUSIC": 13, "CSIDL_DOWNLOADS": 40, + "CSIDL_DESKTOPDIRECTORY": 16, }.get(csidl_name) if csidl_const is None: msg = f"Unknown CSIDL name: {csidl_name}" @@ -225,7 +237,7 @@ def get_win_folder_via_ctypes(csidl_name: str) -> str: windll = getattr(ctypes, "windll") # noqa: B009 # using getattr to avoid false positive with mypy type checker windll.shell32.SHGetFolderPathW(None, csidl_const, None, 0, buf) - # Downgrade to short path name if it has highbit chars. + # Downgrade to short path name if it has high-bit chars. if any(ord(c) > 255 for c in buf): # noqa: PLR2004 buf2 = ctypes.create_unicode_buffer(1024) if windll.kernel32.GetShortPathNameW(buf.value, buf2, 1024): @@ -238,10 +250,15 @@ def get_win_folder_via_ctypes(csidl_name: str) -> str: def _pick_get_win_folder() -> Callable[[str], str]: - if hasattr(ctypes, "windll"): - return get_win_folder_via_ctypes try: - import winreg # noqa: F401 + import ctypes # noqa: PLC0415 + except ImportError: + pass + else: + if hasattr(ctypes, "windll"): + return get_win_folder_via_ctypes + try: + import winreg # noqa: PLC0415, F401 except ImportError: return get_win_folder_from_env_vars else: diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__init__.py b/myenv/Lib/site-packages/pip/_vendor/pygments/__init__.py index 39c84aa..5b8a3f9 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/__init__.py @@ -26,7 +26,7 @@ """ from io import StringIO, BytesIO -__version__ = '2.15.1' +__version__ = '2.17.2' __docformat__ = 'restructuredtext' __all__ = ['lex', 'format', 'highlight'] diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/__init__.cpython-311.pyc index 852c7bd0ef83883361d2256472f910c9e0527996..ef83c0520bda3c7ff0bd8c47dddccce9be44c6c5 100644 GIT binary patch delta 28 icmZpbYn9_#&dbZi00gclH*(EpVK&z@+Ps1#mJ0x1sRrZ# delta 28 icmZpbYn9_#&dbZi00hp5Hge5oVK&t>+`NJ%mJ0x169(7- diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/__main__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/__main__.cpython-311.pyc index 9160ff32ca5a48dd11b208e62398fa585d00c69c..04f9ee16b7208937fd108163ea340cbb210500aa 100644 GIT binary patch delta 19 ZcmbQmHj9mGIWI340}!~L+{h)s3;-&E1M&a> delta 19 ZcmbQmHj9mGIWI340}wbL+Q=oq3;-%q1L*(& diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/cmdline.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/cmdline.cpython-311.pyc index 1aa4db71b8944f035085f34129a7d454d68f4e33..dbeb5d0c0939ac2e7d1212e3bdaa72dfb7316240 100644 GIT binary patch delta 633 zcmaF(hH=gtM&9MTyj%=G;CiwzEomd~G+9Q!%}Znxg!MB^#6aQ@kmUwrrKprK6h+sF zWVypdRDmKvlZ_3X1Zov)6tlcw5(~U1ZhMtVGCvzLA^3R3IGceSM zl+2rKZ)DB5aB{VgA>-o7YmGD+gC=h@Rhsb%Cij1LPQF9ZR>U0xc=`{!&R2Yh67#SiNYUGQ=Y7`bg%-(1s4KaK3dlL~h#_-K7 z){_`Tgp>1g@{1C46ZJClGD|WOb25ulH=nf0W#r_5$xQaLi{`okG<_Qo7n^ThZzs$v zq;`P^iau~Kh|6CQ)7<>hdj_)uO9ltS3l6RfQRWvSj6m|Gy-=10!z&HRY)0nS>`n~1 zN(^t6xbird-|8^taWlMQX9Tj}aWI3}+>&`Jn-BW?Gcw+qEEpKh_;7M&;C9B_lNE!s zr5*z9F3JWG)*!+FMBD-slhcA6SU}9l0vuwS4+J@Iv%LpNeB8_yw~USP5Ob& zK|=30OQmgPsG+D-w%}Znxg!OYu#6aQ@kmUwrrKprK6vfqu zWVypdRDmL)lZ_3X#B#lonHU*zy}_hUts)~sjp72|$s6TFC(kleV4O2~x1lHF{K>3F zs)7q)+8G#XL`oJhFib8~5}O=oq|CTTkwUgf(D>8-yMOAou>Ny!|z z#b~Uz`Kt*B8)M|=e^!$idF2Z-3-sd4Qu9*si}WT>v=I?vhw^T5B*(}VjxtthsRT~n5-D& zzye}U7T^%uTpi@V&Gr!_@p<#X*kx>tpEqZuq%*R82MK-Ld^L3|Bll+z8!9k0ou5hU z5m4Y3pJP#aX>Mv>NkC#zacWV~oyog00~l{j=FWrZm}d5r5E2~Nl7hE sE;=~5F3XdVYx9XLKQ^}eAVrTh%M|i6v4O%6Xo6v}2BYHUsNzFR07uu)$p8QV diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/console.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/console.cpython-311.pyc index 4d7c244ca8b8c9d5f9a21cba4be2e8dc61febf21..a6dfd489876bfcc53a4eb0d496cc425c6eadea00 100644 GIT binary patch delta 19 Zcmew;{!yH3IWI340}!~L+{pEu8vr`C1)%@{ delta 19 Zcmew;{!yH3IWI340}wbL+Q{{s8vr_o1(*N; diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/filter.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/filter.cpython-311.pyc index 6f1df78aa3faaa02664c2dd7d5b2c3cd9c30742d..c8301ebdfb76f056a96f4f6d681a0b30d66bb149 100644 GIT binary patch delta 19 Zcmdldy-%8JIWI340}!~L+{m?s7XUM^1rh)N delta 19 Zcmdldy-%8JIWI340}wbL+Q_wq7XUMV1qlEE diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/formatter.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/formatter.cpython-311.pyc index a822e75d50da2e5b0fbd9e4f3c804a281a97afa6..5d493cd996a578a984d414392607f218664865fe 100644 GIT binary patch delta 19 ZcmaE;`cRc?IWI340}!~L+{krZ2mm@c1(W~) delta 19 ZcmaE;`cRc?IWI340}wbL+Q@ZX2mm??1&aUx diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/lexer.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/lexer.cpython-311.pyc index 3ab051f796ab6a1bc3b857974c77db5713d6f515..bef4719358b6d467a50bf57d25df0a285f0d9c3e 100644 GIT binary patch delta 4512 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 Rod5NWQq7W9|BFlFe*h`hefj_Z diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/modeline.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/modeline.cpython-311.pyc index d28f911b609611e2be328b381bc4952d18a48f74..b688889d020abb4cc800d513bd6310a539b7a365 100644 GIT binary patch delta 19 ZcmX@fdyDB4*)PU1jYaW diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/regexopt.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/regexopt.cpython-311.pyc index a85d6a805be238ffc9d127a291529596d699a30d..acbc8a21b7b9e9fa34e92801bb8c92910d50d362 100644 GIT binary patch delta 19 Zcmdm@zD1pDIWI340}!~L+{m>`7yvWS1rh)N delta 19 Zcmdm@zD1pDIWI340}wbL+Q_v^7yvV&1qlEE diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/scanner.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/scanner.cpython-311.pyc index 3defccdb03239bbf77e5bf968bd6d4c3a8c19034..01cc8717c9d0dec1f4954fcd15d45322ab8eb382 100644 GIT binary patch delta 19 ZcmZ3iwpfj8IWI340}!~L+{h&<3;-}F1YH0C delta 19 ZcmZ3iwpfj8IWI340}wbL+Q=m-3;-|r1XKV3 diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/sphinxext.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/sphinxext.cpython-311.pyc index 76f68d274ffb794ee38f43130da5634ac5406199..3c76c4a025e8dddf4debeac39b015404383cda59 100644 GIT binary patch delta 2387 zcmZuxTTmNS7(SaDo6Utw5+DheO=yL1Nh#Epa%t-bj>TB*#TT^`1G~`BkffWXmbhEm z>Vq?)O*zhpB6d5r$c&6br(^5*=7YBVS3`lLR1{tY37>B%|YIsbqD z+xh>0v&7wvSiiDZ7(~XvuOE%PUU%Di%cc9>fDoQHx>`AkLlK>Ct8%44{jAR2@ zC87niazmn&68y;3!0X;aOZo*3LSK`W8~rGyIo+N;hMP!RuUl5TjB8z{hb!#n3Iri8b_^Q6Nm56NjY367SEoe!+WaWlzm8`;& zq*E%?NVSR$cKlyOZR?mlFH|^j#-xda!vIQFK)F;ZRUF{)HPe!Lfg;Aq+B9A!l_eZv zTb?GG7Rfq?IIBd@p?O`g^c9LEytELn&>G#B}sN<3ptfb<-|zEympgQ zrc{xNdh7bpX_H(*1Z+|T5wPb4rp=N;sfLHym{C-mcEt&NJg+7pNMMbu4 z7TH!PGAr98n^Yn(y(G;k&2(>3vm0{FK3w~>WCRwprY)V!uR zTvDwf9km1vmYRYUr3Q+kQEDM&j{0JC*&*pk>NiYwR)oMe2T6g0W5vUHnsk{1zftcq z*-35d$tSs~WEGEW6ETu+!>RS;3fR0OuP2eudrW{&TxcQSqcU`Sa&(-JiisIkrsnZQ zc5o^~2l)%3@py#K=tVvuCNkztdL$g-6G{DqIMUVyx_opv#)YG!N&CQfT%2S##aNJI z8#F(ZN6RVtn-8IDCou*|5b z2}VQXd`1TbGluaP$Hj&P@@GN3^m3ubJ;uUXqUz+@9T|#O4@M`f)(@m?z zGfh{%Z-w91;UV@mw9wBOJ2nsj{Bm;u-)I<|`pfNAIv1Jc{x$c(b@##d1L;zC7FjJl zX}kNAz)V1?df@52@9A8Aam~}W?&({zA6kbwux<|!kqs^7s7cqg!rqqN(*t{NihAgB zUvK%WW%2FVmNnObb=QGZNxG^oi?roUf4Um78p_$YC}k1loN5GYOuKhwwPaU`4XwuA z^aK&eB8{UdOCx*rEcNk$EYg?vq&>Tp(9NpF@|&*IVA@{0>givz_ot4k$G~@ktDZn^ zuGs^G%Qik>JMOa`YwW&tb{{eC=uu%-m#+4#?(ViN?;@C+Yt`Me##!UTJAXG^)2ZE6 zhd*!Xpnk(EO|^~~RJI2II$AgaAY#h5ziSSTLjc17?*P~USO5t?2Dk`t3E(oo6&&;V zeX4Q;&?5k&09OH00M`I!06xV(`TD4pJG$n7HB@Y-%{O%e*s8}ZXBll`G9i3OE;39o zNP21_!Uu!75O#V8?GqqreBo%|)WC`USDqKX0OlzIK0~gtRUc|}d*Ny;oP+`4#kO|p z5&om?7pJOr6Kt7-!E+O#2y`~_dl7%{e_VP{Uz0^!a30^=^Rs@L2tUT}w)+igSYP6M z?L%E3fQxB>>j1X^XaJBF+5vn3jRgLodvnh_Bz%jH@15>Er=f_Or(?>uq24^%et$-f I%Q|ZQ2bG*W+W-In delta 1402 zcmZvaU1$?o6vywKWM-0?e6&rbZDKU3XO?_P!3%kDfp!ZBnlc*Q&k2~j_|M|Fg z9%t|CzPnzpLipPJ$JODt;fKCE;U#?{AvcLmbs5hWE)uRK@vH z-^`~nl{uN*$FF3HUbamB_T|MKFc4^jx}=}hK`f~y9@|eYTOL$Yp8Rx!*;dx@7pZ45 zL}Qx2CZ-s``@vjZe??gg+SV?oPbg~86411U+6gT$6ZkF9#GRTeM& zA4{m7E#zR7|B+ub-ma<$3HnZyY@Fbp6L&neefek^VH4P72!}SIZHK!DgWk<~HNPegQ&s&o& zpRv@A1W#LkSjvs+`siUp#Yp+c(4an&&lG%^AqEso>&Fd~CEi#UfkkGO!i2roO=(cfl#sgDB9gVLRtoI<-@a-rIsqcBl0 z&Tz+^l1}sK$Ff7|bg750%cFV^M!L7{*tKu#o-IFZHm;y?A4fte-J@N@Zm%0%3;h%% z0*|`8=yQ12{VZh50CRcL>EmOA+5BJ*>yE?Io`3yuG4h@)U?pIM?JQSY95~mSY5jPMn#4T92YB9YH`&V6Fv0tD(-S;__n72LuRr{F}!o88t&I=>| diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/style.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/style.cpython-311.pyc index fdc8e731769870cff7fd13c54a75cf819daa2247..7c046b66b7fa531884c2a0122bed987435a9797d 100644 GIT binary patch delta 175 zcmeCR+F`}FoR^o20SH`A_N9qPZsco~U^JUNMM9S^ogs=lg(He5g)^8zlWX#E2}j;r z?4@~miMgpMZho4)lX)ap@)h|5wccV+%*jkFPA#6iRnn3%YVvzY7j6y)9?=Gu2Ydnz n?vstArZBc_J}$+@WTVKa_JIMDn2-q;{Roo!fwOg7StY9AOdi3yot(T^ahFIeP@EP%EG05ftT2><{9 diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/token.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/token.cpython-311.pyc index 36f21327671c0434078ad61a8f2743d78a0e94c0..bb0cc5e1434c4038e3d05a8b6c1010eda3f968ed 100644 GIT binary patch delta 1318 zcmYk6OHUJF6o#jzqxOm-v`|qKQ4uew6h!e3RH4OkY0IrzZ$JS>3>5D=E?B$a4|HQ( z8xsG5F)lR9f|!_?xN|j$d*eCp>r|%cWS-}oZ_YR8`)1yCeD7#{6AbzcIpQB)O%2r= z#!m(3sQY*E`^VeHk7jgo+ib!KO{8Z6uU+HGiA>sP%C7z~KZX1ig~`Ql?m{uu)VKPz zI`8)S;&b<>)5V4PmF7sh?~9Ce$$#O1S&Ct%MC5xgLNkgKeVQ?f@$#4) h1^bnEuY9ggHiS!U>mFHnEwZ#B{xYP$g^+x${sJ7UYTp0= delta 1261 zcmYk6$xjn;6vuxvcB*uPKw+?;CT^wf(&AEg3JJ7YT3faOaYGQ-gyO!82hLpj5A0~~i_kO?k+h%@bKV*~dqS26|EB9$_p|4x1 zpA6n*Z#?|{_CER9iY$fS8cu$`QcMGEf#?&QIy^)A3}0yNzN z+{?(RNnjta8Q|I}7{zy2@8dw8?0(n-jF$)x0uM3rcn$-PFct`p0{gva8kq6g4gik< zrQ~s#6JEkeU{+bPQu`G6wAbAk;8{i<**V~OgL#Dbf&noI!DG#d7!n~BhYhD*PIO>{ z^@tZqQ1+-~=RLB4qPk ziF@t0+URD`R92J*kuz}uh8S^LheeE#XruV3VBS=&)z%DjQJI3MB4uD#1xt*w17$In z#qcXx5mRNe%Ii5UVnR}E`T$IdnL-NBW?F>fwF&7NG0Lg`?k)FlzctU$-n@zNZ#hO^ Fq<=g|S|R`d diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/unistring.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/unistring.cpython-311.pyc index a5549d2ef2fc7bf3ba374e501851f9e45c3c7b84..a89c10f3b255b9157855872efd8822e9b8ad6fa4 100644 GIT binary patch delta 21 bcmdnp!L+-BiEBA8FBbz4xSrg|W!M4$MLq@I delta 21 bcmdnp!L+-BiEBA8FBbz4I3L=`W!M4$MGpnl diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/util.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/__pycache__/util.cpython-311.pyc index 1a9cb53984a0dd90a7b495de41488bccea38ca26..de94daa8d8c52f8e5592f0ad7471c8ddbdcb55b0 100644 GIT binary patch delta 19 Zcmca!b-jvfIWI340}!~L+{oo?3jjkh1c delta 19 Zcmca!b-jvfIWI340}wbL+Q{W=3jjj{1;PLT diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/cmdline.py b/myenv/Lib/site-packages/pip/_vendor/pygments/cmdline.py index eec1775..29b5608 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/cmdline.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/cmdline.py @@ -469,11 +469,11 @@ def is_only_option(opt): outfile = UnclosingTextIOWrapper(outfile, encoding=fmter.encoding) fmter.encoding = None try: - import pip._vendor.colorama.initialise as colorama_initialise + import colorama.initialise except ImportError: pass else: - outfile = colorama_initialise.wrap_stream( + outfile = colorama.initialise.wrap_stream( outfile, convert=None, strip=None, autoreset=False, wrap=True) # When using the LaTeX formatter and the option `escapeinside` is diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/filters/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/filters/__pycache__/__init__.cpython-311.pyc index 29baaa42d15603e7879808c13df5918845d5d674..a10fa49d8c644026823a4b856b5feff686861a14 100644 GIT binary patch delta 21 bcmdnClWE&dCa&eYyj%=G;CgZ+*P1y1Or8eG delta 21 bcmdnClWE&dCa&eYyj%=G;CyH!*P1y1Om7Cj diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py index 39db842..6abb45a 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py @@ -131,7 +131,7 @@ def get_formatter_for_filename(fn, **options): if name not in _formatter_cache: _load_formatters(modname) return _formatter_cache[name](**options) - for cls in find_plugin_formatters(): + for _name, cls in find_plugin_formatters(): for filename in cls.filenames: if _fn_matches(fn, filename): return cls(**options) diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/__init__.cpython-311.pyc index 7b9c8b137fac07decbb8de78105e4bfb5bcb03f3..059856779a87ebd5020906b6b25f228e0439d775 100644 GIT binary patch delta 205 zcmaE0^T~#HIWI340}!~L>`OD>$QvWVRK_^@0Jq}g9+5lT+A&NF47KdF95o!1b486A zIVLX@6=&4hyi;@{BO~WzZ*g^@TdeVUiMgpoia;}pIe~=2s}Po zyCSCdfq|J-4NP=$b+C36Z}yis$t2|kR9&P8BE&(2D2Q+Y6O)akt@%MrO~xWa5T#J$ iH@QaoE?Ddqdv1P8X-;Z!k@w^b8GFW<%`0SfFaiLDpEQO5 delta 205 zcmexl^T398IWI340}wbL>Ps`&$QvWVRKPg-0Jq}g9+5k&8nx^-?30T{jV0Mrm@^q_ z7?&{iF(xxHGJtR}Lyvrq=H~sP6B!vfCI^bEa}_B94JzgU5|g{cWf(;!FBe}VBA|AW zU;PTd`UeJPRy8ou!Mr(9;v|!lCs1LL9*7VJ5uzZ%8B9!ek+$XsF*O;B3_+Aak?-U_ f>APUDTkN^{DWy57#YJ9|t7PmMqc`u8*}(_^nHe&| diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/_mapping.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/_mapping.cpython-311.pyc index bd54b99e13182b3d45ee27dbe8adc58edfe40db8..668331953b125b3f9ad95c78441c8c50d2ecf225 100644 GIT binary patch delta 19 ZcmeBC>`~-e&dbZi00gclH*z%z001o!1d9Lw delta 19 ZcmeBC>`~-e&dbZi00hp5HgYuy001oF1cCqn diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/bbcode.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/bbcode.cpython-311.pyc index c5f9b8a88fce4d88e7e62d730cf4f287e3029214..11cc7fa83c20a3cd508936747ce795dc8a76d825 100644 GIT binary patch delta 19 ZcmeBC?osAi&dbZi00gclH*z%z0st*m1dsp# delta 19 ZcmeBC?osAi&dbZi00hp5HgYuy0st*11cv|s diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/groff.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/groff.cpython-311.pyc index bed68d84e0279df7764444426718ad366ebfbfe7..f632cfacd321b2f1408bc97fc665d2cc8650ace1 100644 GIT binary patch delta 19 ZcmdmKyVI6yIWI340}!~L+{m?F4gfcW1y}$8 delta 19 ZcmdmKyVI6yIWI340}wbL+Q_wD4gfb+1y29~ diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/html.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/html.cpython-311.pyc index c71d99414999177c0d2d5b97d1381dc5a76640a8..9875cabef45b227dc93d24bf277235a94fdfe988 100644 GIT binary patch delta 521 zcmZ{gUr1A77{<@@ednw(cPcwW3pKumF_v~=B$ePw#KHuP+A2(J|Bh|eG&@QZ5#>Hn)N-nrGlf&<;0wS_zB8i?B{Y4Oaa2*}sahWTMbx`V=`n7Y0?~UPmZTRzs|6c8*@_bcb)(FhH10Riwbe;S)P(~*+#~Cs- zf8BofJ_T<+(J)D?ZY7yJrfSXwrNG^Eadb-ElhUznLHRe+&EE^=$A7%F!tOVrZc`?g KHE{ln!RBvi&Ziy# delta 420 zcmZ{gODIHP9L4YX?!%b5H>UB(W5I}p$3o14P#T5EGlXP}SB#Qor6kH@Bc{HQP?(kH zhCg8;Q9^@=k}PGZC`w7(X3bgrHm6SKoQW&8aLKe~O*0C*?8lQG(VLpzgm!u`eaG>P zrfm@m_J_H`AzGOqh6Dj3k622&=I*~!8{F*+%!m0Mj z7|aC0J*=mH@|%Wm+NraMh^F%f7ehMPno=1GxU=~lIXv6(j53OAu>w_OcSZvB)Yw`E zIB2b{MnUJ6%Wr^(F5J5^?r5anEV3U)GXrOUi5!DIhHzrTOhf|7Bhx@8&5w2iS)`1s z2IP@t>RZGLH}f$ibbz(7D1O9qA@d(@uE(^LEwaNhs%-68r<+ftUW MACxbOM+`cD0eVn}D*ylh diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/img.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/img.cpython-311.pyc index 331e8c40c54f01ac844a6248a5979988ccb6a1f9..98158fb5d340d542b3bd102352805067012cd403 100644 GIT binary patch delta 4542 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 delta 3265 zcmZ`*3v3kE6`eP;Gy7k_HXj?aHQ2_xwu*u92_FZD12)(g{0-QY)z~xku37IcZ^kiD z6c9q8Y8&G45FZtSm9)6DAwZ`Tszzzr1eFw#T8U}VkhE^pCT*jp8#QSpRFU5M1{2cK zvG>e<_w(l7cRw>ve@IUMfrN&GL7xCu^)C;0|ETpss8}Wo*_fQi*2u@n5}+R0)CA(A zf-bZZO=uT2(k^KeG-*F+cWJKuLc6TVfQqI7x-~bTN1Ld5LGIOju<~hsK))6M3}`{X zpcZNtqLbKeCFYl4bNv1DAYtz-%cq$hSlqpO<#B3AVb9JkVXt`HB*a#F@`;Bv24;nc zpb5>w|24VrxMPyTO?+q)a7=a+BVbNJHk-eBGD~^#a-vd$Ee#}6wxX#N?$IFY^+wp6 z-UCx4+hyp9N%=j}}Dwkt!^U34Y#Nz9g$iIi^GF1&$AHRG%{R6|;T)tYpwp`?xRnJxH;R)pyY1pv_y)sg1T^{@>EGh%JH-ip8v8Uv({BjAzW z7n|FO?Q6*Wa)5Lb@_GRbHvo^XXr&Y35{R&n?6Uq+a7iTXY-mOsS^?xcf#R6Lz5=BEzDcG@Z{85O~yf6soHT(=gM%_miuOxqn-4b?O${U%@a z=%$g_rAMW^^;HWd&)R86V9p8wr$+akIM% zS_*qNLvI>EB$1-C4i z?rBG0Z(CZszQ&d^sh(YO`5d^dp~tM-ON$k9jD=S%oA@nsh1WL5Mk}qvst}pN1DTKJ zE-lez^2Vk8?CD46?fDL>VdK&vgy#{;5jqgCUU-bQj0G{^+~V{F| zW~?inOjCLujlCLG2h`4_Zr~(hPga*s-U$5vo;p?Ra&;k5tsB*sB`E%bHPz%ed#mP% z|0n1MkM968YFCky>|*UtgIAC{1aL-#O~1Z&C3%6py!IL8BJvNg#&s*m8TRbDQ$f_B zmjI%uSXK8JImh=?A7{r{6pg!^jB;(Nr}+B%Ocdl?^f8MPE=hDe}ApF!>*!k-b|2QU->XM#Ed z^aJ+mwy^jQV*Rb{h&1=xAZ@u#eDqIfa2B8;noIlPZYvp;>M7Iq={quNN;B0?gVwV1 z?Nj%BfVv|Hzeo5T!Yu?I3bv*#^{G2-30_iEL%|sGyuj;uX64LGgEThNP} zxE_PXfX@jS;!YD|mGUOEy;Scq;SovQ=~mv4=pJvOKDCELtQ+b}@*X^FzCBe4NX0L* z2Q*J2I?xa;pm$JH0wwAJ%9c|40DTX6V+eSb)ItcM3i?OgNS#A!2;rW0l=q$orF*bY zsTaxfNMS|6hX}lhcvM(Q5TN>mPH|q@a(@OsPwwW7eugY}y5HVZ1uV0za3+e43^=&=-d|SiC9)?gaBR2EZfg?B z$wR4GU#-Kfrej2f2;8+2-pQ^H z#TQWEU)z^SQyd5 diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/irc.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/irc.cpython-311.pyc index 9121bb5716c5dc6369e1e8648f55cc157ee4a4b4..2d7add6689f4e2d2b2668cdf04f4bba075fae6bd 100644 GIT binary patch delta 19 ZcmbPaG|7l-IWI340}!~L+{nct2>>rZ1V{h? delta 19 ZcmbPaG|7l-IWI340}wbL+Q`Kr2>>q<1U~=( diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/latex.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/latex.cpython-311.pyc index 459fcad078a2c72c2e4fbb223da548c3232798ae..c86a776ad910810e2ec2fb197428693d25092ec9 100644 GIT binary patch delta 21 bcmdnBigDK}My}<&yj%=G;CgZ+mq921Nv#F$ delta 21 bcmdnBigDK}My}<&yj%=G;CyH!mq921Nqz<8 diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/other.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/other.cpython-311.pyc index 0c59b729a227feef3a9384ffdcfd887d3f53118f..8407c1c0476e51305efb55301c835e5bfbf03c6b 100644 GIT binary patch delta 19 Zcmca-eb1U}IWI340}!~L+{krB763fH1;PLT delta 19 Zcmca-eb1U}IWI340}wbL+Q@Z9763et1-SqK diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/pangomarkup.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/pangomarkup.cpython-311.pyc index ef319d1aad0fa6f238a970a081864e30d7045f24..7a7938d69cde2e15ccbc61843909f2298f60d5aa 100644 GIT binary patch delta 19 Zcmew+@lAqjIWI340}!~L+{l%~0{}Xg1v3Bu delta 19 Zcmew+@lAqjIWI340}wbL+Q^l|0{}W`1u6gl diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/rtf.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/rtf.cpython-311.pyc index 4798467b2694cc8f3fea7f57aaa94a74ad993182..9c625613b7e94ab0487ace093f4f93411517d96f 100644 GIT binary patch delta 19 ZcmX?UdeW3@IWI340}!~L+{m?G3II6K1#|!a delta 19 ZcmX?UdeW3@IWI340}wbL+Q_wE3II5w1#18R diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/svg.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/svg.cpython-311.pyc index 85c719165e36614b6e7e7d196adc6f546a3f7091..782cebe2b3bd3665683075efb9794ab4bad57783 100644 GIT binary patch delta 19 ZcmX@>eb$?6IWI340}!~L+{krU6#zV71-AeI delta 19 ZcmX@>eb$?6IWI340}wbL+Q@ZS6#zUj1+D-9 diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/terminal.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/terminal.cpython-311.pyc index 52e9df0719e67812b90d0e792df501d47d7d7039..056d312c53735c1082183ff796d8d7ca1e32bde0 100644 GIT binary patch delta 19 ZcmZ3Xze1mDIWI340}!~L+{iUg8~`&M1p)v7 delta 19 ZcmZ3Xze1mDIWI340}wbL+Q>Ce8~`%y1o;2} diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/terminal256.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/terminal256.cpython-311.pyc index d5d8e406ab05d2cbc02566edfad59457b3885846..6dded913281973f643c9afe314d4f205ad5d42a7 100644 GIT binary patch delta 21 bcmZ41z__e|k!v|GFBbz4xSrg|CF1}9KvD%s delta 21 bcmZ41z__e|k!v|GFBbz4I3L=`CF1}9KqCb} diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/html.py b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/html.py index 931d7c3..0cadcb2 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/html.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/html.py @@ -323,6 +323,7 @@ class ``"special"`` (default: ``0``). If set to the path of a ctags file, wrap names in anchor tags that link to their definitions. `lineanchors` should be used, and the tags file should specify line numbers (see the `-n` option to ctags). + The tags file is assumed to be encoded in UTF-8. .. versionadded:: 1.6 @@ -908,7 +909,7 @@ def _format_lines(self, tokensource): def _lookup_ctag(self, token): entry = ctags.TagEntry() if self._ctags.find(entry, token.encode(), 0): - return entry['file'], entry['lineNumber'] + return entry['file'].decode(), entry['lineNumber'] else: return None, None diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/img.py b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/img.py index a338c15..9e66b66 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/img.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/formatters/img.py @@ -7,7 +7,6 @@ :copyright: Copyright 2006-2023 by the Pygments team, see AUTHORS. :license: BSD, see LICENSE for details. """ - import os import sys @@ -68,6 +67,15 @@ def __init__(self, font_name, font_size=14): self.font_size = font_size self.fonts = {} self.encoding = None + self.variable = False + if hasattr(font_name, 'read') or os.path.isfile(font_name): + font = ImageFont.truetype(font_name, self.font_size) + self.variable = True + for style in STYLES: + self.fonts[style] = font + + return + if sys.platform.startswith('win'): if not font_name: self.font_name = DEFAULT_FONT_NAME_WIN @@ -223,14 +231,43 @@ def get_font(self, bold, oblique): Get the font based on bold and italic flags. """ if bold and oblique: + if self.variable: + return self.get_style('BOLDITALIC') + return self.fonts['BOLDITALIC'] elif bold: + if self.variable: + return self.get_style('BOLD') + return self.fonts['BOLD'] elif oblique: + if self.variable: + return self.get_style('ITALIC') + return self.fonts['ITALIC'] else: + if self.variable: + return self.get_style('NORMAL') + return self.fonts['NORMAL'] + def get_style(self, style): + """ + Get the specified style of the font if it is a variable font. + If not found, return the normal font. + """ + font = self.fonts[style] + for style_name in STYLES[style]: + try: + font.set_variation_by_name(style_name) + return font + except ValueError: + pass + except OSError: + return font + + return font + class ImageFormatter(Formatter): """ @@ -258,6 +295,8 @@ class ImageFormatter(Formatter): The font name to be used as the base font from which others, such as bold and italic fonts will be generated. This really should be a monospace font to look sane. + If a filename or a file-like object is specified, the user must + provide different styles of the font. Default: "Courier New" on Windows, "Menlo" on Mac OS, and "DejaVu Sans Mono" on \\*nix diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/lexer.py b/myenv/Lib/site-packages/pip/_vendor/pygments/lexer.py index eb2c1b4..26c5fb3 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/lexer.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/lexer.py @@ -72,6 +72,11 @@ class Lexer(metaclass=LexerMeta): .. autoattribute:: url :no-value: + Lexers included in Pygments may have additional attributes: + + .. autoattribute:: _example + :no-value: + You can pass options to the constructor. The basic options recognized by all lexers and processed by the base `Lexer` class are: @@ -128,6 +133,10 @@ class Lexer(metaclass=LexerMeta): #: documentation. url = None + #: Example file name. Relative to the ``tests/examplefiles`` directory. + #: This is used by the documentation generator to show an example. + _example = None + def __init__(self, **options): """ This constructor takes arbitrary options as keyword arguments. @@ -190,26 +199,17 @@ def analyse_text(text): it's the same as if the return values was ``0.0``. """ - def get_tokens(self, text, unfiltered=False): - """ - This method is the basic interface of a lexer. It is called by - the `highlight()` function. It must process the text and return an - iterable of ``(tokentype, value)`` pairs from `text`. + def _preprocess_lexer_input(self, text): + """Apply preprocessing such as decoding the input, removing BOM and normalizing newlines.""" - Normally, you don't need to override this method. The default - implementation processes the options recognized by all lexers - (`stripnl`, `stripall` and so on), and then yields all tokens - from `get_tokens_unprocessed()`, with the ``index`` dropped. - - If `unfiltered` is set to `True`, the filtering mechanism is - bypassed even if filters are defined. - """ if not isinstance(text, str): if self.encoding == 'guess': text, _ = guess_decode(text) elif self.encoding == 'chardet': try: - from pip._vendor import chardet + # pip vendoring note: this code is not reachable by pip, + # removed import of chardet to make it clear. + raise ImportError('chardet is not vendored by pip') except ImportError as e: raise ImportError('To enable chardet encoding guessing, ' 'please install the chardet library ' @@ -246,6 +246,24 @@ def get_tokens(self, text, unfiltered=False): if self.ensurenl and not text.endswith('\n'): text += '\n' + return text + + def get_tokens(self, text, unfiltered=False): + """ + This method is the basic interface of a lexer. It is called by + the `highlight()` function. It must process the text and return an + iterable of ``(tokentype, value)`` pairs from `text`. + + Normally, you don't need to override this method. The default + implementation processes the options recognized by all lexers + (`stripnl`, `stripall` and so on), and then yields all tokens + from `get_tokens_unprocessed()`, with the ``index`` dropped. + + If `unfiltered` is set to `True`, the filtering mechanism is + bypassed even if filters are defined. + """ + text = self._preprocess_lexer_input(text) + def streamer(): for _, t, v in self.get_tokens_unprocessed(text): yield t, v diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py b/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py index d97c3e3..0c176df 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py @@ -22,6 +22,7 @@ COMPAT = { 'Python3Lexer': 'PythonLexer', 'Python3TracebackLexer': 'PythonTracebackLexer', + 'LeanLexer': 'Lean3Lexer', } __all__ = ['get_lexer_by_name', 'get_lexer_for_filename', 'find_lexer_class', diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/__pycache__/__init__.cpython-311.pyc index 2da5dd890c7a5eac5a9c0762157f67061e267fe7..27177659ddc9f2228534c1f522ee499d57449d5c 100644 GIT binary patch delta 1852 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/__pycache__/python.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/__pycache__/python.cpython-311.pyc index 2a96fec8d619d98ef40a4be9333b99007d5129fd..e1eb7e96065279d8acbe05f19b0e81fd15f68ec6 100644 GIT binary patch delta 4894 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 IH^9yR073-HApigX delta 4871 zcmb7|c~n%_9mjby!wicU7eH1)BF;QP(O9D*W>7&zVX!6|6m*#74NQEqKyebOxcc6p=pAupVwWbCFIN0S)Z(;&A_nK5F* zEen4;a`rpoH-2Wy^bu0k6P2H(j>mJImrB3;XlOc@r`0&-i7eG9&j%I&3xRb&4NwcT z0*ipffP)at=i?)J>1){%c@l*nui8Kv3H z6pxOyG4+F=5M+llh4bVUz zMfow{IPe7TUR-E=7UpyO$l@Z?uV9`?;>V(MCTqqHzt`2yG!y;?+zNY>qMEUbIs9!3 zJB6xm0jGJzl7)G1!#o3=1>OPP2R`7w4NddeU&z+3YV1^)M-4=7bTB{O+()SKG4KiS zDJo@LA9ncN4(6_9EWp@j2z;Kjy~kGYADG_|WIG!}%Ycmq#sLLD3izhwny# zB?#03%Yb^I0k8p$z;doFEy-E|^LpS0U=?s9AH6JRRujzCz#5<#XaUv%b^^x1#5h{v zasn>CYT2Y}JZ)(3Y1bp70zSY`(9-Spfr)}7{Rs2}qfs0K96<3P zkb~k_;0TIFSeb+vJB0FKARW#$APaaHzGJ|LC_Vz~QQ$FP9DI+%Iu1Mm#DOOXnxUTN zgqE_v;aVT|y4JH_B9e+GPr-T`cm^1Svw}Sf;7!nRQQbI0nh*~+9x~F=mb>aE9lhn- zo2HakBm7TP{1?F{j~)KX#I`J6)L#DkrX@w9C(+4}^hk0JNzTP2{v1+Yp~2v3B?>pE)lZ9f?{0ow4rr z-G;H|2P~%K(U5<^)bN=Q^Idl_%92hDFn^JGs)NO5cWHm^EFEr~r#MLd@54 zi+bu7_0-l2Twg1LR! zPw4&60OS>WA2~mQb*ZFcA0Y4<0uWL)rVB8?N#ZMerWb#N*vEvZzQtX}{tC-b-4ZEd zpCIDlM|$p&KIPLkW~JW&$LGMEeEG(4#xG!g$$cB`V_t+g6KP)}OVjyPoYeDea`}}v zqCIFM&Xi%hky!rX-0kP{dULYHsfq(tGu%KkK5;xg$=CNzP==kOgJ-5VF26z#e*?rB ziBncfS)qg!)=6(qoMGaG7Tbt8H)r7yhHohRtKJz>VZ1bEG|{$Fe&qin3(>9Gat8x#2o?G zgJ`nb>k6BPOzH;_KPEz|H$?a z#@>J*%08NAu})}iF}Fn4%Iq{bFp)btMM!@uVvr~J?*50U*S>~a-h5zHI>)na1Ge)M2TF@~pqY;CqCZ-) z8dkc(LNyi_3)M(h3h7{=v5GR;+&^c)zUv;=tI>&ns&&j(~X`fH2@&()-s&XAW9Y1@xQ*S_;{{p+P!o>gp diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py b/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py index de6a015..1ff2b28 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py @@ -31,7 +31,8 @@ 'ArduinoLexer': ('pip._vendor.pygments.lexers.c_like', 'Arduino', ('arduino',), ('*.ino',), ('text/x-arduino',)), 'ArrowLexer': ('pip._vendor.pygments.lexers.arrow', 'Arrow', ('arrow',), ('*.arw',), ()), 'ArturoLexer': ('pip._vendor.pygments.lexers.arturo', 'Arturo', ('arturo', 'art'), ('*.art',), ()), - 'AscLexer': ('pip._vendor.pygments.lexers.asc', 'ASCII armored', ('asc', 'pem'), ('*.asc', '*.pem', 'id_dsa', 'id_ecdsa', 'id_ecdsa_sk', 'id_ed25519', 'id_ed25519_sk', 'id_rsa'), ('application/pgp-keys', 'application/pgp-encrypted', 'application/pgp-signature')), + 'AscLexer': ('pip._vendor.pygments.lexers.asc', 'ASCII armored', ('asc', 'pem'), ('*.asc', '*.pem', 'id_dsa', 'id_ecdsa', 'id_ecdsa_sk', 'id_ed25519', 'id_ed25519_sk', 'id_rsa'), ('application/pgp-keys', 'application/pgp-encrypted', 'application/pgp-signature', 'application/pem-certificate-chain')), + 'Asn1Lexer': ('pip._vendor.pygments.lexers.asn1', 'ASN.1', ('asn1',), ('*.asn1',), ()), 'AspectJLexer': ('pip._vendor.pygments.lexers.jvm', 'AspectJ', ('aspectj',), ('*.aj',), ('text/x-aspectj',)), 'AsymptoteLexer': ('pip._vendor.pygments.lexers.graphics', 'Asymptote', ('asymptote', 'asy'), ('*.asy',), ('text/x-asymptote',)), 'AugeasLexer': ('pip._vendor.pygments.lexers.configs', 'Augeas', ('augeas',), ('*.aug',), ()), @@ -41,6 +42,7 @@ 'BBCBasicLexer': ('pip._vendor.pygments.lexers.basic', 'BBC Basic', ('bbcbasic',), ('*.bbc',), ()), 'BBCodeLexer': ('pip._vendor.pygments.lexers.markup', 'BBCode', ('bbcode',), (), ('text/x-bbcode',)), 'BCLexer': ('pip._vendor.pygments.lexers.algebra', 'BC', ('bc',), ('*.bc',), ()), + 'BQNLexer': ('pip._vendor.pygments.lexers.bqn', 'BQN', ('bqn',), ('*.bqn',), ()), 'BSTLexer': ('pip._vendor.pygments.lexers.bibtex', 'BST', ('bst', 'bst-pybtex'), ('*.bst',), ()), 'BareLexer': ('pip._vendor.pygments.lexers.bare', 'BARE', ('bare',), ('*.bare',), ()), 'BaseMakefileLexer': ('pip._vendor.pygments.lexers.make', 'Base Makefile', ('basemake',), (), ()), @@ -53,6 +55,7 @@ 'BibTeXLexer': ('pip._vendor.pygments.lexers.bibtex', 'BibTeX', ('bibtex', 'bib'), ('*.bib',), ('text/x-bibtex',)), 'BlitzBasicLexer': ('pip._vendor.pygments.lexers.basic', 'BlitzBasic', ('blitzbasic', 'b3d', 'bplus'), ('*.bb', '*.decls'), ('text/x-bb',)), 'BlitzMaxLexer': ('pip._vendor.pygments.lexers.basic', 'BlitzMax', ('blitzmax', 'bmax'), ('*.bmx',), ('text/x-bmx',)), + 'BlueprintLexer': ('pip._vendor.pygments.lexers.blueprint', 'Blueprint', ('blueprint',), ('*.blp',), ('text/x-blueprint',)), 'BnfLexer': ('pip._vendor.pygments.lexers.grammar_notation', 'BNF', ('bnf',), ('*.bnf',), ('text/x-bnf',)), 'BoaLexer': ('pip._vendor.pygments.lexers.boa', 'Boa', ('boa',), ('*.boa',), ()), 'BooLexer': ('pip._vendor.pygments.lexers.dotnet', 'Boo', ('boo',), ('*.boo',), ('text/x-boo',)), @@ -125,10 +128,12 @@ 'DaxLexer': ('pip._vendor.pygments.lexers.dax', 'Dax', ('dax',), ('*.dax',), ()), 'DebianControlLexer': ('pip._vendor.pygments.lexers.installers', 'Debian Control file', ('debcontrol', 'control'), ('control',), ()), 'DelphiLexer': ('pip._vendor.pygments.lexers.pascal', 'Delphi', ('delphi', 'pas', 'pascal', 'objectpascal'), ('*.pas', '*.dpr'), ('text/x-pascal',)), + 'DesktopLexer': ('pip._vendor.pygments.lexers.configs', 'Desktop file', ('desktop',), ('*.desktop',), ()), 'DevicetreeLexer': ('pip._vendor.pygments.lexers.devicetree', 'Devicetree', ('devicetree', 'dts'), ('*.dts', '*.dtsi'), ('text/x-c',)), 'DgLexer': ('pip._vendor.pygments.lexers.python', 'dg', ('dg',), ('*.dg',), ('text/x-dg',)), 'DiffLexer': ('pip._vendor.pygments.lexers.diff', 'Diff', ('diff', 'udiff'), ('*.diff', '*.patch'), ('text/x-diff', 'text/x-patch')), 'DjangoLexer': ('pip._vendor.pygments.lexers.templates', 'Django/Jinja', ('django', 'jinja'), (), ('application/x-django-templating', 'application/x-jinja')), + 'DnsZoneLexer': ('pip._vendor.pygments.lexers.dns', 'Zone', ('zone',), ('*.zone',), ('text/dns',)), 'DockerLexer': ('pip._vendor.pygments.lexers.configs', 'Docker', ('docker', 'dockerfile'), ('Dockerfile', '*.docker'), ('text/x-dockerfile-config',)), 'DtdLexer': ('pip._vendor.pygments.lexers.html', 'DTD', ('dtd',), ('*.dtd',), ('application/xml-dtd',)), 'DuelLexer': ('pip._vendor.pygments.lexers.webmisc', 'Duel', ('duel', 'jbst', 'jsonml+bst'), ('*.duel', '*.jbst'), ('text/x-duel', 'text/x-jbst')), @@ -190,6 +195,7 @@ 'GoodDataCLLexer': ('pip._vendor.pygments.lexers.business', 'GoodData-CL', ('gooddata-cl',), ('*.gdc',), ('text/x-gooddata-cl',)), 'GosuLexer': ('pip._vendor.pygments.lexers.jvm', 'Gosu', ('gosu',), ('*.gs', '*.gsx', '*.gsp', '*.vark'), ('text/x-gosu',)), 'GosuTemplateLexer': ('pip._vendor.pygments.lexers.jvm', 'Gosu Template', ('gst',), ('*.gst',), ('text/x-gosu-template',)), + 'GraphQLLexer': ('pip._vendor.pygments.lexers.graphql', 'GraphQL', ('graphql',), ('*.graphql',), ()), 'GraphvizLexer': ('pip._vendor.pygments.lexers.graphviz', 'Graphviz', ('graphviz', 'dot'), ('*.gv', '*.dot'), ('text/x-graphviz', 'text/vnd.graphviz')), 'GroffLexer': ('pip._vendor.pygments.lexers.markup', 'Groff', ('groff', 'nroff', 'man'), ('*.[1-9]', '*.man', '*.1p', '*.3pm'), ('application/x-troff', 'text/troff')), 'GroovyLexer': ('pip._vendor.pygments.lexers.jvm', 'Groovy', ('groovy',), ('*.groovy', '*.gradle'), ('text/x-groovy',)), @@ -219,7 +225,7 @@ 'Inform6Lexer': ('pip._vendor.pygments.lexers.int_fiction', 'Inform 6', ('inform6', 'i6'), ('*.inf',), ()), 'Inform6TemplateLexer': ('pip._vendor.pygments.lexers.int_fiction', 'Inform 6 template', ('i6t',), ('*.i6t',), ()), 'Inform7Lexer': ('pip._vendor.pygments.lexers.int_fiction', 'Inform 7', ('inform7', 'i7'), ('*.ni', '*.i7x'), ()), - 'IniLexer': ('pip._vendor.pygments.lexers.configs', 'INI', ('ini', 'cfg', 'dosini'), ('*.ini', '*.cfg', '*.inf', '.editorconfig', '*.service', '*.socket', '*.device', '*.mount', '*.automount', '*.swap', '*.target', '*.path', '*.timer', '*.slice', '*.scope'), ('text/x-ini', 'text/inf')), + 'IniLexer': ('pip._vendor.pygments.lexers.configs', 'INI', ('ini', 'cfg', 'dosini'), ('*.ini', '*.cfg', '*.inf', '.editorconfig'), ('text/x-ini', 'text/inf')), 'IoLexer': ('pip._vendor.pygments.lexers.iolang', 'Io', ('io',), ('*.io',), ('text/x-iosrc',)), 'IokeLexer': ('pip._vendor.pygments.lexers.jvm', 'Ioke', ('ioke', 'ik'), ('*.ik',), ('text/x-iokesrc',)), 'IrcLogsLexer': ('pip._vendor.pygments.lexers.textfmts', 'IRC logs', ('irc',), ('*.weechatlog',), ('text/x-irclog',)), @@ -241,9 +247,10 @@ 'JsgfLexer': ('pip._vendor.pygments.lexers.grammar_notation', 'JSGF', ('jsgf',), ('*.jsgf',), ('application/jsgf', 'application/x-jsgf', 'text/jsgf')), 'JsonBareObjectLexer': ('pip._vendor.pygments.lexers.data', 'JSONBareObject', (), (), ()), 'JsonLdLexer': ('pip._vendor.pygments.lexers.data', 'JSON-LD', ('jsonld', 'json-ld'), ('*.jsonld',), ('application/ld+json',)), - 'JsonLexer': ('pip._vendor.pygments.lexers.data', 'JSON', ('json', 'json-object'), ('*.json', 'Pipfile.lock'), ('application/json', 'application/json-object')), + 'JsonLexer': ('pip._vendor.pygments.lexers.data', 'JSON', ('json', 'json-object'), ('*.json', '*.jsonl', '*.ndjson', 'Pipfile.lock'), ('application/json', 'application/json-object', 'application/x-ndjson', 'application/jsonl', 'application/json-seq')), 'JsonnetLexer': ('pip._vendor.pygments.lexers.jsonnet', 'Jsonnet', ('jsonnet',), ('*.jsonnet', '*.libsonnet'), ()), 'JspLexer': ('pip._vendor.pygments.lexers.templates', 'Java Server Page', ('jsp',), ('*.jsp',), ('application/x-jsp',)), + 'JsxLexer': ('pip._vendor.pygments.lexers.jsx', 'JSX', ('jsx', 'react'), ('*.jsx', '*.react'), ('text/jsx', 'text/typescript-jsx')), 'JuliaConsoleLexer': ('pip._vendor.pygments.lexers.julia', 'Julia console', ('jlcon', 'julia-repl'), (), ()), 'JuliaLexer': ('pip._vendor.pygments.lexers.julia', 'Julia', ('julia', 'jl'), ('*.jl',), ('text/x-julia', 'application/x-julia')), 'JuttleLexer': ('pip._vendor.pygments.lexers.javascript', 'Juttle', ('juttle',), ('*.juttle',), ('application/juttle', 'application/x-juttle', 'text/x-juttle', 'text/juttle')), @@ -254,13 +261,16 @@ 'KokaLexer': ('pip._vendor.pygments.lexers.haskell', 'Koka', ('koka',), ('*.kk', '*.kki'), ('text/x-koka',)), 'KotlinLexer': ('pip._vendor.pygments.lexers.jvm', 'Kotlin', ('kotlin',), ('*.kt', '*.kts'), ('text/x-kotlin',)), 'KuinLexer': ('pip._vendor.pygments.lexers.kuin', 'Kuin', ('kuin',), ('*.kn',), ()), + 'KustoLexer': ('pip._vendor.pygments.lexers.kusto', 'Kusto', ('kql', 'kusto'), ('*.kql', '*.kusto', '.csl'), ()), 'LSLLexer': ('pip._vendor.pygments.lexers.scripting', 'LSL', ('lsl',), ('*.lsl',), ('text/x-lsl',)), 'LassoCssLexer': ('pip._vendor.pygments.lexers.templates', 'CSS+Lasso', ('css+lasso',), (), ('text/css+lasso',)), 'LassoHtmlLexer': ('pip._vendor.pygments.lexers.templates', 'HTML+Lasso', ('html+lasso',), (), ('text/html+lasso', 'application/x-httpd-lasso', 'application/x-httpd-lasso[89]')), 'LassoJavascriptLexer': ('pip._vendor.pygments.lexers.templates', 'JavaScript+Lasso', ('javascript+lasso', 'js+lasso'), (), ('application/x-javascript+lasso', 'text/x-javascript+lasso', 'text/javascript+lasso')), 'LassoLexer': ('pip._vendor.pygments.lexers.javascript', 'Lasso', ('lasso', 'lassoscript'), ('*.lasso', '*.lasso[89]'), ('text/x-lasso',)), 'LassoXmlLexer': ('pip._vendor.pygments.lexers.templates', 'XML+Lasso', ('xml+lasso',), (), ('application/xml+lasso',)), - 'LeanLexer': ('pip._vendor.pygments.lexers.theorem', 'Lean', ('lean',), ('*.lean',), ('text/x-lean',)), + 'LdaprcLexer': ('pip._vendor.pygments.lexers.ldap', 'LDAP configuration file', ('ldapconf', 'ldaprc'), ('.ldaprc', 'ldaprc', 'ldap.conf'), ('text/x-ldapconf',)), + 'LdifLexer': ('pip._vendor.pygments.lexers.ldap', 'LDIF', ('ldif',), ('*.ldif',), ('text/x-ldif',)), + 'Lean3Lexer': ('pip._vendor.pygments.lexers.lean', 'Lean', ('lean', 'lean3'), ('*.lean',), ('text/x-lean', 'text/x-lean3')), 'LessCssLexer': ('pip._vendor.pygments.lexers.css', 'LessCss', ('less',), ('*.less',), ('text/x-less-css',)), 'LighttpdConfLexer': ('pip._vendor.pygments.lexers.configs', 'Lighttpd configuration file', ('lighttpd', 'lighty'), ('lighttpd.conf',), ('text/x-lighttpd-conf',)), 'LilyPondLexer': ('pip._vendor.pygments.lexers.lilypond', 'LilyPond', ('lilypond',), ('*.ly',), ()), @@ -351,6 +361,7 @@ 'OocLexer': ('pip._vendor.pygments.lexers.ooc', 'Ooc', ('ooc',), ('*.ooc',), ('text/x-ooc',)), 'OpaLexer': ('pip._vendor.pygments.lexers.ml', 'Opa', ('opa',), ('*.opa',), ('text/x-opa',)), 'OpenEdgeLexer': ('pip._vendor.pygments.lexers.business', 'OpenEdge ABL', ('openedge', 'abl', 'progress'), ('*.p', '*.cls'), ('text/x-openedge', 'application/x-openedge')), + 'OpenScadLexer': ('pip._vendor.pygments.lexers.openscad', 'OpenSCAD', ('openscad',), ('*.scad',), ('application/x-openscad',)), 'OutputLexer': ('pip._vendor.pygments.lexers.special', 'Text output', ('output',), (), ()), 'PacmanConfLexer': ('pip._vendor.pygments.lexers.configs', 'PacmanConf', ('pacmanconf',), ('pacman.conf',), ()), 'PanLexer': ('pip._vendor.pygments.lexers.dsls', 'Pan', ('pan',), ('*.pan',), ()), @@ -381,14 +392,16 @@ 'PromQLLexer': ('pip._vendor.pygments.lexers.promql', 'PromQL', ('promql',), ('*.promql',), ()), 'PropertiesLexer': ('pip._vendor.pygments.lexers.configs', 'Properties', ('properties', 'jproperties'), ('*.properties',), ('text/x-java-properties',)), 'ProtoBufLexer': ('pip._vendor.pygments.lexers.dsls', 'Protocol Buffer', ('protobuf', 'proto'), ('*.proto',), ()), + 'PrqlLexer': ('pip._vendor.pygments.lexers.prql', 'PRQL', ('prql',), ('*.prql',), ('application/prql', 'application/x-prql')), 'PsyshConsoleLexer': ('pip._vendor.pygments.lexers.php', 'PsySH console session for PHP', ('psysh',), (), ()), + 'PtxLexer': ('pip._vendor.pygments.lexers.ptx', 'PTX', ('ptx',), ('*.ptx',), ('text/x-ptx',)), 'PugLexer': ('pip._vendor.pygments.lexers.html', 'Pug', ('pug', 'jade'), ('*.pug', '*.jade'), ('text/x-pug', 'text/x-jade')), 'PuppetLexer': ('pip._vendor.pygments.lexers.dsls', 'Puppet', ('puppet',), ('*.pp',), ()), 'PyPyLogLexer': ('pip._vendor.pygments.lexers.console', 'PyPy Log', ('pypylog', 'pypy'), ('*.pypylog',), ('application/x-pypylog',)), 'Python2Lexer': ('pip._vendor.pygments.lexers.python', 'Python 2.x', ('python2', 'py2'), (), ('text/x-python2', 'application/x-python2')), 'Python2TracebackLexer': ('pip._vendor.pygments.lexers.python', 'Python 2.x Traceback', ('py2tb',), ('*.py2tb',), ('text/x-python2-traceback',)), 'PythonConsoleLexer': ('pip._vendor.pygments.lexers.python', 'Python console session', ('pycon',), (), ('text/x-python-doctest',)), - 'PythonLexer': ('pip._vendor.pygments.lexers.python', 'Python', ('python', 'py', 'sage', 'python3', 'py3'), ('*.py', '*.pyw', '*.pyi', '*.jy', '*.sage', '*.sc', 'SConstruct', 'SConscript', '*.bzl', 'BUCK', 'BUILD', 'BUILD.bazel', 'WORKSPACE', '*.tac'), ('text/x-python', 'application/x-python', 'text/x-python3', 'application/x-python3')), + 'PythonLexer': ('pip._vendor.pygments.lexers.python', 'Python', ('python', 'py', 'sage', 'python3', 'py3', 'bazel', 'starlark'), ('*.py', '*.pyw', '*.pyi', '*.jy', '*.sage', '*.sc', 'SConstruct', 'SConscript', '*.bzl', 'BUCK', 'BUILD', 'BUILD.bazel', 'WORKSPACE', '*.tac'), ('text/x-python', 'application/x-python', 'text/x-python3', 'application/x-python3')), 'PythonTracebackLexer': ('pip._vendor.pygments.lexers.python', 'Python Traceback', ('pytb', 'py3tb'), ('*.pytb', '*.py3tb'), ('text/x-python-traceback', 'text/x-python3-traceback')), 'PythonUL4Lexer': ('pip._vendor.pygments.lexers.ul4', 'Python+UL4', ('py+ul4',), ('*.pyul4',), ()), 'QBasicLexer': ('pip._vendor.pygments.lexers.basic', 'QBasic', ('qbasic', 'basic'), ('*.BAS', '*.bas'), ('text/basic',)), @@ -477,9 +490,10 @@ 'SwiftLexer': ('pip._vendor.pygments.lexers.objective', 'Swift', ('swift',), ('*.swift',), ('text/x-swift',)), 'SwigLexer': ('pip._vendor.pygments.lexers.c_like', 'SWIG', ('swig',), ('*.swg', '*.i'), ('text/swig',)), 'SystemVerilogLexer': ('pip._vendor.pygments.lexers.hdl', 'systemverilog', ('systemverilog', 'sv'), ('*.sv', '*.svh'), ('text/x-systemverilog',)), + 'SystemdLexer': ('pip._vendor.pygments.lexers.configs', 'Systemd', ('systemd',), ('*.service', '*.socket', '*.device', '*.mount', '*.automount', '*.swap', '*.target', '*.path', '*.timer', '*.slice', '*.scope'), ()), 'TAPLexer': ('pip._vendor.pygments.lexers.testing', 'TAP', ('tap',), ('*.tap',), ()), 'TNTLexer': ('pip._vendor.pygments.lexers.tnt', 'Typographic Number Theory', ('tnt',), ('*.tnt',), ()), - 'TOMLLexer': ('pip._vendor.pygments.lexers.configs', 'TOML', ('toml',), ('*.toml', 'Pipfile', 'poetry.lock'), ()), + 'TOMLLexer': ('pip._vendor.pygments.lexers.configs', 'TOML', ('toml',), ('*.toml', 'Pipfile', 'poetry.lock'), ('application/toml',)), 'Tads3Lexer': ('pip._vendor.pygments.lexers.int_fiction', 'TADS 3', ('tads3',), ('*.t',), ()), 'TalLexer': ('pip._vendor.pygments.lexers.tal', 'Tal', ('tal', 'uxntal'), ('*.tal',), ('text/x-uxntal',)), 'TasmLexer': ('pip._vendor.pygments.lexers.asm', 'TASM', ('tasm',), ('*.asm', '*.ASM', '*.tasm'), ('text/x-tasm',)), @@ -498,6 +512,7 @@ 'ThriftLexer': ('pip._vendor.pygments.lexers.dsls', 'Thrift', ('thrift',), ('*.thrift',), ('application/x-thrift',)), 'TiddlyWiki5Lexer': ('pip._vendor.pygments.lexers.markup', 'tiddler', ('tid',), ('*.tid',), ('text/vnd.tiddlywiki',)), 'TlbLexer': ('pip._vendor.pygments.lexers.tlb', 'Tl-b', ('tlb',), ('*.tlb',), ()), + 'TlsLexer': ('pip._vendor.pygments.lexers.tls', 'TLS Presentation Language', ('tls',), (), ()), 'TodotxtLexer': ('pip._vendor.pygments.lexers.textfmts', 'Todotxt', ('todotxt',), ('todo.txt', '*.todotxt'), ('text/x-todo',)), 'TransactSqlLexer': ('pip._vendor.pygments.lexers.sql', 'Transact-SQL', ('tsql', 't-sql'), ('*.sql',), ('text/x-tsql',)), 'TreetopLexer': ('pip._vendor.pygments.lexers.parsers', 'Treetop', ('treetop',), ('*.treetop', '*.tt'), ()), @@ -513,6 +528,7 @@ 'UniconLexer': ('pip._vendor.pygments.lexers.unicon', 'Unicon', ('unicon',), ('*.icn',), ('text/unicon',)), 'UnixConfigLexer': ('pip._vendor.pygments.lexers.configs', 'Unix/Linux config files', ('unixconfig', 'linuxconfig'), (), ()), 'UrbiscriptLexer': ('pip._vendor.pygments.lexers.urbi', 'UrbiScript', ('urbiscript',), ('*.u',), ('application/x-urbiscript',)), + 'UrlEncodedLexer': ('pip._vendor.pygments.lexers.html', 'urlencoded', ('urlencoded',), (), ('application/x-www-form-urlencoded',)), 'UsdLexer': ('pip._vendor.pygments.lexers.usd', 'USD', ('usd', 'usda'), ('*.usd', '*.usda'), ()), 'VBScriptLexer': ('pip._vendor.pygments.lexers.basic', 'VBScript', ('vbscript',), ('*.vbs', '*.VBS'), ()), 'VCLLexer': ('pip._vendor.pygments.lexers.varnish', 'VCL', ('vcl',), ('*.vcl',), ('text/x-vclsrc',)), @@ -525,9 +541,13 @@ 'VelocityHtmlLexer': ('pip._vendor.pygments.lexers.templates', 'HTML+Velocity', ('html+velocity',), (), ('text/html+velocity',)), 'VelocityLexer': ('pip._vendor.pygments.lexers.templates', 'Velocity', ('velocity',), ('*.vm', '*.fhtml'), ()), 'VelocityXmlLexer': ('pip._vendor.pygments.lexers.templates', 'XML+Velocity', ('xml+velocity',), (), ('application/xml+velocity',)), + 'VerifpalLexer': ('pip._vendor.pygments.lexers.verifpal', 'Verifpal', ('verifpal',), ('*.vp',), ('text/x-verifpal',)), 'VerilogLexer': ('pip._vendor.pygments.lexers.hdl', 'verilog', ('verilog', 'v'), ('*.v',), ('text/x-verilog',)), 'VhdlLexer': ('pip._vendor.pygments.lexers.hdl', 'vhdl', ('vhdl',), ('*.vhdl', '*.vhd'), ('text/x-vhdl',)), 'VimLexer': ('pip._vendor.pygments.lexers.textedit', 'VimL', ('vim',), ('*.vim', '.vimrc', '.exrc', '.gvimrc', '_vimrc', '_exrc', '_gvimrc', 'vimrc', 'gvimrc'), ('text/x-vim',)), + 'VisualPrologGrammarLexer': ('pip._vendor.pygments.lexers.vip', 'Visual Prolog Grammar', ('visualprologgrammar',), ('*.vipgrm',), ()), + 'VisualPrologLexer': ('pip._vendor.pygments.lexers.vip', 'Visual Prolog', ('visualprolog',), ('*.pro', '*.cl', '*.i', '*.pack', '*.ph'), ()), + 'VyperLexer': ('pip._vendor.pygments.lexers.vyper', 'Vyper', ('vyper',), ('*.vy',), ()), 'WDiffLexer': ('pip._vendor.pygments.lexers.diff', 'WDiff', ('wdiff',), ('*.wdiff',), ()), 'WatLexer': ('pip._vendor.pygments.lexers.webassembly', 'WebAssembly', ('wast', 'wat'), ('*.wat', '*.wast'), ()), 'WebIDLLexer': ('pip._vendor.pygments.lexers.webidl', 'Web IDL', ('webidl',), ('*.webidl',), ()), @@ -552,6 +572,7 @@ 'YamlJinjaLexer': ('pip._vendor.pygments.lexers.templates', 'YAML+Jinja', ('yaml+jinja', 'salt', 'sls'), ('*.sls', '*.yaml.j2', '*.yml.j2', '*.yaml.jinja2', '*.yml.jinja2'), ('text/x-yaml+jinja', 'text/x-sls')), 'YamlLexer': ('pip._vendor.pygments.lexers.data', 'YAML', ('yaml',), ('*.yaml', '*.yml'), ('text/x-yaml',)), 'YangLexer': ('pip._vendor.pygments.lexers.yang', 'YANG', ('yang',), ('*.yang',), ('application/yang',)), + 'YaraLexer': ('pip._vendor.pygments.lexers.yara', 'YARA', ('yara', 'yar'), ('*.yar',), ('text/x-yara',)), 'ZeekLexer': ('pip._vendor.pygments.lexers.dsls', 'Zeek', ('zeek', 'bro'), ('*.zeek', '*.bro'), ()), 'ZephirLexer': ('pip._vendor.pygments.lexers.php', 'Zephir', ('zephir',), ('*.zep',), ()), 'ZigLexer': ('pip._vendor.pygments.lexers.zig', 'Zig', ('zig',), ('*.zig',), ('text/zig',)), diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py b/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py index e9bf2d3..e2ce58f 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py @@ -35,8 +35,8 @@ class PythonLexer(RegexLexer): """ name = 'Python' - url = 'http://www.python.org' - aliases = ['python', 'py', 'sage', 'python3', 'py3'] + url = 'https://www.python.org' + aliases = ['python', 'py', 'sage', 'python3', 'py3', 'bazel', 'starlark'] filenames = [ '*.py', '*.pyw', @@ -425,7 +425,7 @@ class Python2Lexer(RegexLexer): """ name = 'Python 2.x' - url = 'http://www.python.org' + url = 'https://www.python.org' aliases = ['python2', 'py2'] filenames = [] # now taken over by PythonLexer (3.x) mimetypes = ['text/x-python2', 'application/x-python2'] @@ -830,7 +830,7 @@ class CythonLexer(RegexLexer): """ name = 'Cython' - url = 'http://cython.org' + url = 'https://cython.org' aliases = ['cython', 'pyx', 'pyrex'] filenames = ['*.pyx', '*.pxd', '*.pxi'] mimetypes = ['text/x-cython', 'application/x-cython'] diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py b/myenv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py index 2c7facd..fc0b027 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py @@ -147,6 +147,10 @@ def write_seperator(): def document_lexers(self): from pip._vendor.pygments.lexers._mapping import LEXERS + from pip._vendor import pygments + import inspect + import pathlib + out = [] modules = {} moduledocstrings = {} @@ -160,6 +164,24 @@ def document_lexers(self): docstring = cls.__doc__ if isinstance(docstring, bytes): docstring = docstring.decode('utf8') + + example_file = getattr(cls, '_example', None) + if example_file: + p = pathlib.Path(inspect.getabsfile(pygments)).parent.parent /\ + 'tests' / 'examplefiles' / example_file + content = p.read_text(encoding='utf-8') + if not content: + raise Exception( + f"Empty example file '{example_file}' for lexer " + f"{classname}") + + if data[2]: + lexer_name = data[2][0] + docstring += '\n\n .. admonition:: Example\n' + docstring += f'\n .. code-block:: {lexer_name}\n\n' + for line in content.splitlines(): + docstring += f' {line}\n' + modules.setdefault(module, []).append(( classname, ', '.join(data[2]) or 'None', diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/style.py b/myenv/Lib/site-packages/pip/_vendor/pygments/style.py index edc1962..f2f72d3 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/style.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/style.py @@ -190,6 +190,12 @@ class Style(metaclass=StyleMeta): #: Style definitions for individual token types. styles = {} + #: user-friendly style name (used when selecting the style, so this + # should be all-lowercase, no spaces, hyphens) + name = 'unnamed' + + aliases = [] + # Attribute for lexers defined within Pygments. If set # to True, the style is not shown in the style gallery # on the website. This is intended for language-specific diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py b/myenv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py index 7401cf5..23b5546 100644 --- a/myenv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py @@ -10,59 +10,15 @@ from pip._vendor.pygments.plugin import find_plugin_styles from pip._vendor.pygments.util import ClassNotFound +from pip._vendor.pygments.styles._mapping import STYLES #: A dictionary of built-in styles, mapping style names to #: ``'submodule::classname'`` strings. -STYLE_MAP = { - 'default': 'default::DefaultStyle', - 'emacs': 'emacs::EmacsStyle', - 'friendly': 'friendly::FriendlyStyle', - 'friendly_grayscale': 'friendly_grayscale::FriendlyGrayscaleStyle', - 'colorful': 'colorful::ColorfulStyle', - 'autumn': 'autumn::AutumnStyle', - 'murphy': 'murphy::MurphyStyle', - 'manni': 'manni::ManniStyle', - 'material': 'material::MaterialStyle', - 'monokai': 'monokai::MonokaiStyle', - 'perldoc': 'perldoc::PerldocStyle', - 'pastie': 'pastie::PastieStyle', - 'borland': 'borland::BorlandStyle', - 'trac': 'trac::TracStyle', - 'native': 'native::NativeStyle', - 'fruity': 'fruity::FruityStyle', - 'bw': 'bw::BlackWhiteStyle', - 'vim': 'vim::VimStyle', - 'vs': 'vs::VisualStudioStyle', - 'tango': 'tango::TangoStyle', - 'rrt': 'rrt::RrtStyle', - 'xcode': 'xcode::XcodeStyle', - 'igor': 'igor::IgorStyle', - 'paraiso-light': 'paraiso_light::ParaisoLightStyle', - 'paraiso-dark': 'paraiso_dark::ParaisoDarkStyle', - 'lovelace': 'lovelace::LovelaceStyle', - 'algol': 'algol::AlgolStyle', - 'algol_nu': 'algol_nu::Algol_NuStyle', - 'arduino': 'arduino::ArduinoStyle', - 'rainbow_dash': 'rainbow_dash::RainbowDashStyle', - 'abap': 'abap::AbapStyle', - 'solarized-dark': 'solarized::SolarizedDarkStyle', - 'solarized-light': 'solarized::SolarizedLightStyle', - 'sas': 'sas::SasStyle', - 'staroffice' : 'staroffice::StarofficeStyle', - 'stata': 'stata_light::StataLightStyle', - 'stata-light': 'stata_light::StataLightStyle', - 'stata-dark': 'stata_dark::StataDarkStyle', - 'inkpot': 'inkpot::InkPotStyle', - 'zenburn': 'zenburn::ZenburnStyle', - 'gruvbox-dark': 'gruvbox::GruvboxDarkStyle', - 'gruvbox-light': 'gruvbox::GruvboxLightStyle', - 'dracula': 'dracula::DraculaStyle', - 'one-dark': 'onedark::OneDarkStyle', - 'lilypond' : 'lilypond::LilyPondStyle', - 'nord': 'nord::NordStyle', - 'nord-darker': 'nord::NordDarkerStyle', - 'github-dark': 'gh_dark::GhDarkStyle' -} +#: This list is deprecated. Use `pygments.styles.STYLES` instead +STYLE_MAP = {v[1]: v[0].split('.')[-1] + '::' + k for k, v in STYLES.items()} + +#: Internal reverse mapping to make `get_style_by_name` more efficient +_STYLE_NAME_TO_MODULE_MAP = {v[1]: (v[0], k) for k, v in STYLES.items()} def get_style_by_name(name): @@ -73,8 +29,8 @@ def get_style_by_name(name): Will raise :exc:`pygments.util.ClassNotFound` if no style of that name is found. """ - if name in STYLE_MAP: - mod, cls = STYLE_MAP[name].split('::') + if name in _STYLE_NAME_TO_MODULE_MAP: + mod, cls = _STYLE_NAME_TO_MODULE_MAP[name] builtin = "yes" else: for found_name, style in find_plugin_styles(): @@ -82,14 +38,15 @@ def get_style_by_name(name): return style # perhaps it got dropped into our styles package builtin = "" - mod = name + mod = 'pygments.styles.' + name cls = name.title() + "Style" try: - mod = __import__('pygments.styles.' + mod, None, None, [cls]) + mod = __import__(mod, None, None, [cls]) except ImportError: raise ClassNotFound("Could not find style module %r" % mod + - (builtin and ", though it should be builtin") + ".") + (builtin and ", though it should be builtin") + + ".") try: return getattr(mod, cls) except AttributeError: @@ -98,6 +55,7 @@ def get_style_by_name(name): def get_all_styles(): """Return a generator for all styles by name, both builtin and plugin.""" - yield from STYLE_MAP + for v in STYLES.values(): + yield v[1] for name, _ in find_plugin_styles(): yield name diff --git a/myenv/Lib/site-packages/pip/_vendor/pygments/styles/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pygments/styles/__pycache__/__init__.cpython-311.pyc index e84156eeeeaeb8e3f69c5ac62abbf82e7d025b00..d94631d7670ffdfbcf2229ef4babdabed2949b02 100644 GIT binary patch delta 1649 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 PhnK<, !"``), built up using :class:`Word`, -:class:`Literal`, and :class:`And` elements -(the :meth:`'+'` operators create :class:`And` expressions, -and the strings are auto-converted to :class:`Literal` expressions):: - - from pip._vendor.pyparsing import Word, alphas - - # define grammar of a greeting - greet = Word(alphas) + "," + Word(alphas) + "!" - - hello = "Hello, World!" - print(hello, "->", greet.parse_string(hello)) - -The program outputs the following:: - - Hello, World! -> ['Hello', ',', 'World', '!'] - -The Python representation of the grammar is quite readable, owing to the -self-explanatory class names, and the use of :class:`'+'`, -:class:`'|'`, :class:`'^'` and :class:`'&'` operators. - -The :class:`ParseResults` object returned from -:class:`ParserElement.parse_string` can be -accessed as a nested list, a dictionary, or an object with named -attributes. - -The pyparsing module handles some of the problems that are typically -vexing when writing text parsers: - - - extra or missing whitespace (the above program will also handle - "Hello,World!", "Hello , World !", etc.) - - quoted strings - - embedded comments - - -Getting Started - ------------------ -Visit the classes :class:`ParserElement` and :class:`ParseResults` to -see the base classes that most other pyparsing -classes inherit from. Use the docstrings for examples of how to: - - - construct literal match expressions from :class:`Literal` and - :class:`CaselessLiteral` classes - - construct character word-group expressions using the :class:`Word` - class - - see how to create repetitive expressions using :class:`ZeroOrMore` - and :class:`OneOrMore` classes - - use :class:`'+'`, :class:`'|'`, :class:`'^'`, - and :class:`'&'` operators to combine simple expressions into - more complex ones - - associate names with your parsed results using - :class:`ParserElement.set_results_name` - - access the parsed data, which is returned as a :class:`ParseResults` - object - - find some helpful expression short-cuts like :class:`DelimitedList` - and :class:`one_of` - - find more useful common expressions in the :class:`pyparsing_common` - namespace class -""" -from typing import NamedTuple - - -class version_info(NamedTuple): - major: int - minor: int - micro: int - releaselevel: str - serial: int - - @property - def __version__(self): - return ( - f"{self.major}.{self.minor}.{self.micro}" - + ( - f"{'r' if self.releaselevel[0] == 'c' else ''}{self.releaselevel[0]}{self.serial}", - "", - )[self.releaselevel == "final"] - ) - - def __str__(self): - return f"{__name__} {self.__version__} / {__version_time__}" - - def __repr__(self): - return f"{__name__}.{type(self).__name__}({', '.join('{}={!r}'.format(*nv) for nv in zip(self._fields, self))})" - - -__version_info__ = version_info(3, 1, 0, "final", 1) -__version_time__ = "18 Jun 2023 14:05 UTC" -__version__ = __version_info__.__version__ -__versionTime__ = __version_time__ -__author__ = "Paul McGuire " - -from .util import * -from .exceptions import * -from .actions import * -from .core import __diag__, __compat__ -from .results import * -from .core import * # type: ignore[misc, assignment] -from .core import _builtin_exprs as core_builtin_exprs -from .helpers import * # type: ignore[misc, assignment] -from .helpers import _builtin_exprs as helper_builtin_exprs - -from .unicode import unicode_set, UnicodeRangeList, pyparsing_unicode as unicode -from .testing import pyparsing_test as testing -from .common import ( - pyparsing_common as common, - _builtin_exprs as common_builtin_exprs, -) - -# define backward compat synonyms -if "pyparsing_unicode" not in globals(): - pyparsing_unicode = unicode # type: ignore[misc] -if "pyparsing_common" not in globals(): - pyparsing_common = common # type: ignore[misc] -if "pyparsing_test" not in globals(): - pyparsing_test = testing # type: ignore[misc] - -core_builtin_exprs += common_builtin_exprs + helper_builtin_exprs - - -__all__ = [ - "__version__", - "__version_time__", - "__author__", - "__compat__", - "__diag__", - "And", - "AtLineStart", - "AtStringStart", - "CaselessKeyword", - "CaselessLiteral", - "CharsNotIn", - "CloseMatch", - "Combine", - "DelimitedList", - "Dict", - "Each", - "Empty", - "FollowedBy", - "Forward", - "GoToColumn", - "Group", - "IndentedBlock", - "Keyword", - "LineEnd", - "LineStart", - "Literal", - "Located", - "PrecededBy", - "MatchFirst", - "NoMatch", - "NotAny", - "OneOrMore", - "OnlyOnce", - "OpAssoc", - "Opt", - "Optional", - "Or", - "ParseBaseException", - "ParseElementEnhance", - "ParseException", - "ParseExpression", - "ParseFatalException", - "ParseResults", - "ParseSyntaxException", - "ParserElement", - "PositionToken", - "QuotedString", - "RecursiveGrammarException", - "Regex", - "SkipTo", - "StringEnd", - "StringStart", - "Suppress", - "Token", - "TokenConverter", - "White", - "Word", - "WordEnd", - "WordStart", - "ZeroOrMore", - "Char", - "alphanums", - "alphas", - "alphas8bit", - "any_close_tag", - "any_open_tag", - "autoname_elements", - "c_style_comment", - "col", - "common_html_entity", - "condition_as_parse_action", - "counted_array", - "cpp_style_comment", - "dbl_quoted_string", - "dbl_slash_comment", - "delimited_list", - "dict_of", - "empty", - "hexnums", - "html_comment", - "identchars", - "identbodychars", - "infix_notation", - "java_style_comment", - "line", - "line_end", - "line_start", - "lineno", - "make_html_tags", - "make_xml_tags", - "match_only_at_col", - "match_previous_expr", - "match_previous_literal", - "nested_expr", - "null_debug_action", - "nums", - "one_of", - "original_text_for", - "printables", - "punc8bit", - "pyparsing_common", - "pyparsing_test", - "pyparsing_unicode", - "python_style_comment", - "quoted_string", - "remove_quotes", - "replace_with", - "replace_html_entity", - "rest_of_line", - "sgl_quoted_string", - "srange", - "string_end", - "string_start", - "token_map", - "trace_parse_action", - "ungroup", - "unicode_set", - "unicode_string", - "with_attribute", - "with_class", - # pre-PEP8 compatibility names - "__versionTime__", - "anyCloseTag", - "anyOpenTag", - "cStyleComment", - "commonHTMLEntity", - "conditionAsParseAction", - "countedArray", - "cppStyleComment", - "dblQuotedString", - "dblSlashComment", - "delimitedList", - "dictOf", - "htmlComment", - "indentedBlock", - "infixNotation", - "javaStyleComment", - "lineEnd", - "lineStart", - "locatedExpr", - "makeHTMLTags", - "makeXMLTags", - "matchOnlyAtCol", - "matchPreviousExpr", - "matchPreviousLiteral", - "nestedExpr", - "nullDebugAction", - "oneOf", - "opAssoc", - "originalTextFor", - "pythonStyleComment", - "quotedString", - "removeQuotes", - "replaceHTMLEntity", - "replaceWith", - "restOfLine", - "sglQuotedString", - "stringEnd", - "stringStart", - "tokenMap", - "traceParseAction", - "unicodeString", - "withAttribute", - "withClass", -] diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/__init__.cpython-311.pyc deleted file mode 100644 index a8956af012bf26bb9be5328a7bc760bcd14b6619..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8242 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/common.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/common.cpython-311.pyc deleted file mode 100644 index 96479f02a6a52bd18482d6a18b3876f9b7da94c8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 14880 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 BBtZZG diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/core.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/core.cpython-311.pyc deleted file mode 100644 index 793788494ad4e2f68839fcd3760421eee01d31bc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 295453 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
o7quF#Cn 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 X2$hmhnKb#pbfM@f^$7v&B=7$PSg~!N diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/exceptions.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/exceptions.cpython-311.pyc deleted file mode 100644 index 928fee23d495c000669505023409f8cb610c4172..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13720 zcmeHOUu+x6dEezfQ4}Rg7WH4Y*E;(o`Xt%%-?Q%Qi~q=HJ2~Cu?8_xOC-jQDk|^_E zc1hc0sH?7VTjgTpc&P#_hz?)@<0`{>aDhDBLx37ZAMPP&NrQ#i1zZ>?`VgQfXxKpk zqYwRkv*dC~N@>$JMIXANXJ===`R1E%X1@8&H{(BVZFO;YPXE=9<__-RxPPRN%F|qq zJd5)jcbk(qi4Soz`kSBO*|%lJB3UGB$QriI*uwT1d)P7K2sh0%g`G1_o~{>*e(IJrsgSlm`g`5dy| z!@qKVC-S*PZ{=HRk~>rQken3O(RMKjn<1e~?*7~gKKQ3UGd(P?1$l0{r!KFT<+UQO zts$?E<#~|TF89@y>t}f#$lKOX-+;tlMxt83 zA88>mrpkUbt^_0V{&>`{h>>|&)!G#~77_!pdMN?~jOK+3(j}et$SB zB|;Q;`~BZdh#@`aF87S8cyaagW}9oe!2F{=@?u~^e$r8I|JdpWH#x2TLwZdzoskgAX!ee`0_oV6N9SqGJs znr2#>Ir@`!NH*CaS!A1J-I9Yta^1AgxaC%9r{uoLe+~}!bmj(zywtaqMx=h|j9TZA25vUZ^g}OtTL+=10a%McxxdyfNZT9g-Yzv` zLhRDEy@RH>~v-lK@aVP{rqN)mWQAH3#A)!3^1SP=+dX-Mqtf6Q?vxe1q z%@)I4*4l_xR{U~ErWv8xL}gyRYgfpaDP0tFQ$RXWdMUuzm1SBDrpi&Mq^sz z6dJ`aUp7?^&FMlLZP0AgJe7nN=uv2NY!%)mbp?J=j~as z-EtON+E!jG_6)3?xpl7C+mF}zmGe(}D1z@n`Y!GmTCo+J1I4bswS!q}&bu20n^*A1 ztii9zBm|6h;)CWd)8co~HmrlZWC?LgSoN^B@nOr7mFLp@a%bFFl{jwE&_eC}S>orp zC0m^AQu#@9abqpSiiCRa8Feei)3&UMYo!dwrMaqAsU5A5Ws5SB9i}J@hGxSfHA|K{>0CAa>q=W|^OYZhtASS*J1Z=+21==<&|7lV%B%9Xz7>C^N|CP1 zPdl!03V-Wr+L0ym(D3}Wvb8nwTuoos)w9&H)i_JHRP8p#K?}akx#^# zT^}9#ebm@E1|y^99$0dx-PK-@TA@EnhQHEjhjrm4tXyh>KTcL5x%v416F1P)`ksaao8j$ih2G zP)CGdBrYp}Pm~*wX91WfDJqCUD5%B_-qAT$$iPlu9aCgg1-w&{BgTb*m{4U@0@l^_ z42))FK@o$<8h07oV5flqQL#E%O&p_g0t3BszzYB&;+QBNcqC)T3CY`(Fg zjzW4tO~hhRr7FB2K>Tuh4cW?KhlBGAjFT=T6&G1m;2j|J>NBJs6C?<>AdE=zoR|p3 zk53%&LEcCrJS!_yMM%CThg6}gM5YQgP8wyprH&z;np9`77FY+(B_ga!fl#penh=~5 zrlS#glyRC%01=qkF(To55Xn#kah4@kX8))Vjf9dW=F};3Vi4Pac{DJVh=ZK?hDGJ7 ztc5^QthU9<#<9tr;9=uItY#tr%DkLg6d%7ivf};9gl!KBJBgL zscj-@8?=U`h77~1xvAp@feu>~D`p4wC#|gSm2w>~c;N;Aos?x#Kvq*Aih+G2t_%{X zMQe_cIOoH$kk;yF@#*MkF|Z)N;Kx%|^de}Qt}9|JCMzlD>-x6j#0%c#>(iQo5j7?U z0IC8}MOJo!qh?i;s@5?t#}zq{z!nJ#4~Bzr%@xFU3B42v$O;*2%|R?9l0u+Gb723K z2uCzqJc)W}G1J<>BN&Ou${bAz71H^QnTTzXRh8pfvy3q&E10>ObIuRsCx(CkQBZTt zVM`~;)Lgcy(p;!piL2Lx@deEilr*a-NeZownr$%}jQCnLE0nC+*+^FQBBR_M1>Bmz zID|<_;7g8Zd{DE@&1u#-B}^3&Ak&&D^pp6c4M|pscf|m)w+_lWU>`zaFyc45G_{-c zRt^3gZ=gC3cIpSPYJh1&TyxJ#8~qiX!@1hula}_CP1+OpfeWl=iWo4?^*1lqW z+|rc^{N2DU%vA1b&H<=lsg&X!MHAG>}ctsVR{xEd^UkK{Th@Y^`8zw^!m1?PdB^8h5tOniLo z2gi!t+aGn0KI|UdxL6oF@ufZ2J(};HE_6??y!p7Z`_sd#hgZ%#?iO|7P~mvTKm{EEFo(c63b+>g(F_HNek)0y>|ymzGF9m#n|{z=%K{l=fU z@3=GPi{75w7k+%9IIz1gurJs9b^Px83J1>U(J#C8H!AF+3cFCD5jeT-!Ccqy;|69~ zUt#D-Zs%M0ebHAq_EkNa_f8kQ(>eBo#DhE6Co^Y&&sWpA;S;$Y`u%;c@I;qqExw-4 zdq)f2(VTbmNqg5?$EU80z1TBY;`omKqPH(I_0)-@oow?51{w=?8k z1KJ%Jb!1bXokegP&Zjg$`Xb``gSfHnLEM1ch*K%{d=8j;&j9jRocYwx4YOq|vU6Bd zqDoT0;#Xd()gWwAa4snX6j@}(6Bb{f3C0#JvRYFWH-*7(PKkzLQKPV(3T&5nEgF#8G&+~&yJSb4BxF}@Htx~UdXv#xp5Xt%zcu@#H0 zWCV1uZV1<*S{*1E7EFi+VCxk^GR)E;@L8E**SFaOq3`l+#ZgHReSgXbQazjKhwA$i z(5Zy?mbu@!Fi%qKdq~ICJIY;!tYP1WK|1%o+hS3I-1}4VHA0aVxV8S)O zn?h(ZRTZMVLoGC^gR)b7Tc{%v{SlE@71EuNRu{6iJI#5|-hyXu&bjyZqL90M>f66f zA^N%vSoL2WD0i(2_1kaJ3uULeH_;2~{t5D)Rh812Ikfuf+NJex zDINCLf{7Z6J7BNUR&tqp;^{1ShH}m!T^hqKAd})u8rn`n8uDo&ra$D9Qof0}@+|~D z3!B*rITOsbP?P zQM}5i6syE9@sUKF=3n{A(wJ*_%$&@%)tb>IOWN{LH(W9%8LF({=78+?sI%F#WQ`1N z#n)U1HpHMeJ7AXJI7?eokUDFUyv!Ca39jxs$@qvxYQm~g%a>p9mz4oz zrdkAHgto>Dq9UZ4eWSt%+5E|rV-!nrXz~T`^SP?aE}XhR-F?+n)qfo)C-|fd0bqk> z4~y}@f@YsrqKTN+R6eoM-Mge5Wj_KeeZ{7IpAh1~Srzh4=JoNZ-9$#@_f5w?{ z{>H)WeD%?e;}3Tn|3dm@@JsKndh=d;qCh5O!L^nP*jF9vfjA1@4^$V?RnM>Y@fA2?eW zI7?MM>FHZJSKQXUI+F9qYv&N)M-24XgEN2qRXvt_|AWH&v*kFboO0vzqp8QHpMXd` z!l)hAW&42rrWN|Dx02+UMjw%0H}_2InZHCeDjlIMbB{gSGKYSUyp_y3dzoM<>xo^j zgS}hdsb6F}bFEeXDj(u0S5el0voz&s*s~T;pOIDj$dcwG@VaBtn(XZoJn&V-Bw5JE zyJSmSlo83AHCst=(VsMoNZMwep5)0-+a%tcHdp7zMLpIm$wDyEt(^+RJB zp3=uX`Dx59C5F-%0H$=^n*rqm`RaZQ(oGfC5)Eyb$&uCNG?A0&=c7)+Ok{dahS;{OuNUykyojt3^R-DD|{?)75lb=RcT8b?_ z*!eZL6?^(_U;pv-Vn^TF=-O**qlJ#)jlugj9<)4gKX4b0zLjgA#@4O34O_R~wv}_V zTk8Gf!;e4Adv+E)J9EyRjf*DP4mP~T5ux=di+AHgd#GB=Owe0&!%`W2Y;sxtUw2Oa zzwb{F^sU1GvhU9rEK@f`?3Lw7lh2rzF!DqT$AwsIoGu!S;0J#<~2aTdc7gv&# zH3^l%;|w^Kt?9_n#DRmtp~FXnlSf}YHdOWg>eO_lfvRHbq_Hso#4M`Y{THh$M5C$oUP}#W^Ma`EZ66mdEugqi&!*yq4#V{-EXbi4{NUsmPev004jhCl zaF8wLoCLwZ0=(!+^1ug_B(A#zs1CSt%*P$NDvh%fIJYZo<2c%{E>2ZX zgW&>J8F%=5aj2uyGPw*v^aBAPQkn%d=P@GmB?VP@VUtj^?r0aTTq%28uUskjCG;K@ z;7Vq#WoHa!C%#byn6n8|qqR}i0n~DMogh+FKtF&z8;BK;{P;ClnT@jBMmPo04?&I# zmz0Ej<%+@H$1CTtcvQAmZy;{oUTIBbi8sZj<-EV8LWH=nGG5@}MtS7f^U$*=D{V~W zJqHRN^3yf~J%UPX9V6^aSJo=qJ-YkT0OlCzI!_BWTdz0UfYN$xQ2Z;HsD#9Tm$wUR z7g_!A7ZI?Uo<^&8QZ2N-^zC3r0nAOW5D?UW$E9e1-2bp2n#b=KBXIWV6APF!NHh-k z2myLD>&Zw`vtLTUGHTAZ*@Y`Hq%{MzhoW&6)H{gUje&x}srwz7!nGFW0xYMzMMTb+ z62-YhJgH+HwxyuOUPnE&&($30W}Mq8^OQ_mcjdbjs1(pnN=Z<_6iAz0w!L5nAuOQN za&-wBST_9?Z6|ZKlTVu6%jcHQeRQs9L|m=Q=aV=$b2Yz|mj-spm)@Vju zJDu&mv-5suVb|eY&*6gWNX|yTyzNNI=IC%NpD*=u-mc>Akz#8{sl{X8Q{oUjY3nH2 z>BGSx)?*+`X4=e8A@E*o!u3I1~XO9lr@aBz;!g1xU~G3WLhDULS#9KY6C;^@6eDDWr? zrscrN9X?jFw%LW^*T2EuR77Awar;Z_ejJxgXXx{#E!Txg5Cgf}aHEr1VLIRtKY&-@q9*w8stawJ(EzH*$XRMM1 z(ABE7)h@H*cTt4du__RVFDN)ICGT3tbZdzbjmO|r0~6^ zp>bLaMFw;9)C#(3KsHkqR8p3->Kxf$k3=S_wN|Q{(A6`2*H&jPm22p*dYkioN~7T4 z@J}ThShYDNOS|1!;%WkYP*8#2aZq%!L2*`$iy=dusRSDq@8L$?7#k4`g6Nv3ji`B) z07l^s1)bjGA}d>H>9~fz7>^)b2ZST%H9(MP4A9$jFEAJm%K&F_xqR3^t=xqC^_uu& zN~541!?i&ZR?61tgEZk#@)B1ZWsMTsgGp_A87Mx=4S@p?kn20ls8bXErK5_ACI2$bx3wt zE{E3lu6|A7n*1iN833nL`{!R+lZ@|*_GgoZrdhXEF`XC+O3>yNLg9eOtoXdn6(cth zlGt?=c`iOyz8i5(eyxHa2{5wjJJ7luF%%jCH9&LuCIxUk^-aw{F{;-~`Kbh)YvmHJ z*NV6)%?TZH8jdn3??37Oze_ja*+Hy+ndK7Qlq%y@t=*jSHB4hOcxBitHMFJjjoYci zG$QoVf#R+Sx^cQA$A0=4n5HoR662vUV8y>@bmmC6OwE2h+?b>F$}*iA*s|tHLAiyZ z^(dF&y40>Mi$P#`w*3CRBrn}>0l4){ZComhoz8it=;xebB2W98Hnq}Zh#7v>5o8@u z{Frhn5QzWVjDN*!6I8+sp}@`C4-mj82M*qTmf;b4Q~K7Su1>1KH>g=~nP-%0Od`;1 ziFh!iAJQ>TA49){-x;pen#%tJLZR~k%^Hg(G{@HfsUs8R_sR16lxBZZk>#tJ^K??d z<*Z{JmDC2#L5-o-)ziB9Xx-Z-<+ z86DCPtQ}mR%&K=%_YeMJ@(cBs$uD2})#y{AdtN2R-I4vdu6?=vXA1kL^IdNjy57!l z+lqrP+Y&=3 Kx5#JX`QHH^YgSSK diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/helpers.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/helpers.cpython-311.pyc deleted file mode 100644 index 326735adb69f7c6af028b71a7c0f3500c5a78129..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 54139 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 Z#JxpvSEcZOrnVow)Vqw%h*Eyl`UOXpq%!~j diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/results.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/results.cpython-311.pyc deleted file mode 100644 index 5356273791a85c95644de4908f82d4b680f0a0e8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 37860 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/util.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/util.cpython-311.pyc deleted file mode 100644 index a36d532a4ed58b2172a47509d42fd29bcb01c8de..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16794 zcmch8X>1!;o@W(VyeWzjW$U)f*5NR=}ow2)6(&ycqNh@=bvg zAn<&c{rz8&#Y0x&o@wl3@n5grRqy!U@72Grt8;S*1Hb$E`2X3$aeqq>rQj$=9t>JI z?j|R35+CD6j5|NVvuDeQh25q4Xa$wvp`K}0`ps7zw4RRwJ9;;scntB_*w_X$8=U-E= znT?XDB9BbfgrEj#uC$UDPj%> zkHsrXc9 zyk=TK1BrN~G&2|z=fj_#AM8WlZ*sHzEO(C5S-8L{Zzn5CpEHRNrOfmXFr%|PparQy zsV<(aNl)pC<4OI zR-@|Zzlf) z3nBDuCQyy^eUwO(uI2$!+N9l6e9%huaI+;H99VBGVK z16t!i&O7h`gW@74+2DZ)geLw$9{>oB%i_K^%<@tViGXEThECn$l^&G7Wl^@^rVEVR zseMsYx^a8xJQNF0j!EGoGtD(KUCQV}F|`RG#VtSe=Ldd$;LhOP?)>)WwC&HOIHeaE zf5Z+SSDrwFN|4@J(M@GL64vb@4W!h=fj@uo*Du~Vb@vDP9sSyl{$dY@f zt<+OR0>nhss{pBrUqN^wC%kaKV^iv-jF1^#bmfFi zxbniL!X`2Ga;7_@E(UXgh$}CMg$6P8(tVqM)#9-Y@~a%dudJNC;mX^^q&CjintnUi z`W&u&-BGRXXzF+YN#}EI{kZbJW18<+>IM3-MPxnuGKF4&<2WY6m(=KttXpG=h%SJ6 zOz3t+PEITFs>P;hV%Yhw5g~CfX905uLR_+(M+(LpNSZnt7^$V2aTm)p#VtG+Z^(bN*CKnVXMs<^?q#MjvfR53EG zD8!*6iP-dHT)Y@fo{h%Eu!wPj1MNWiG?*A9Wn8`(i^gSD467nVL{$cx3MUha+Q(Wv zbryO~R8h^gz|rH=lVh?X?&)*0B14I!d{9iHAcS*xI+hfRoDR(XZ1_SHQX7?$2~oZ@ zMRGbB9#chhhiXLQQ`5;}w^(CiGNe4Zkqj%WgH)*0+?0}t$g0{Wf(Og2^g)K82hY3; z)+#H{$7JHmeNhTx!o)Cxx)+OG2H8yc_DIH73V(n*wD?3R;!@NLLO3 z=)77IbBtyo1`{#mC~~&puSNh;+-e)=s!R13{0*6boL|IskHL?+mcsA%e%Na~899L2 z*RtyJYrnks@yMO0@Ad4@_3TgYN$Hap(Vc zG7ukw1Q^1S@=Rm^lKZEU0Bgr21M#0p0<1Mg8R8#_1js01bf7$o7+FD#&jl@I{I8U` zx}BCXo=^r*nutT)3;^`s$a($O4=xL? z4SF4RPs|=9T{iRQtg}|ha-IlI2u$Eu33wT6#CzmG|{(zTVUe1z+R!=t6W!Sc>F*TQ%QS zBt5z3&TGHkvAiSwbjGo?q9qhXw_5vf;&tG285n_QGz z5axxlVYy(dG%G(rl~1WI3zvWjA*LhHJP`v8Rym0X>vd32UZMD_1iApgs|a;U$Y1QL0AnyT z)BF8>rE+hf8I??4>TK(#^z)gn`Ipl88U3t8N zCyD1AJ$lqY5_lO5e3)rjZwORd{R@C^zolOL8`HKzQ|sc1v}()Tdez{LN58#s{?K>#$XK=y-HIVQ^HF|Dm|4D=ra7<%y$S zbzF5`bzODe$XuM6`e2Tb0XBrClb&Y3)( zEX-;~i8|)otyAYwJlb7qd!0JMBi`dF)%j=f^)ioChR|S zP7&w@sPgZc^5w_KxgjtPEf^fS5*g<0)eALeg&eZYJ7%pFrhCm)^AM|4;t*Okxjp!# zK#C36R}I7Gql^iaq}EhoN_Rkt!GQ=}2obW>RdU%9UrHeuR7fmrX3KZZ011P4QA|Au zK&+`G3|9P2nIFAZw^*0%FL*bkPh=*R!i(p!-Ffde&ATn<-BxJrNWYNjUr%gQPoDMh z#m4&D4d~2DbT&`BX57!%mP2{+EC#bCrLQD08RI6uit;uMk-9{)V@wW{Ia|MTa+tWe zNL69aub&d2%V4Z|q7tiju4(&>Gtpcm1koS@`Al zkGJO=`?SWswB!4Pn&9e$1NnP_*W%i~%6%tr{!yi!62_d=3OABY3IUlWtP7x0xV4aQ zTMG=~Mz!c~hLVtZK-yKMa3hNWc7p(h&W+e40nkqSXCn^UEgNx44k*M<-SP74r%%e0 ziJ3ez*ZN^;PbQ)>;9@ddR3gxEQZ?Lj zr(oq#17cFazJyw=RVpKnT_&GJR1w1wa;}L9MUs_g;T(&|l?@vW5-SSBhhV%}mUb|I z2NXE?2NgL2zgO(CIIR{NC$}H`#E~$Xlnggjm99^M$%_92!fUdeD~*sSnK7lA*+0@aYD(t?Ja_(MgE?=osun8ZTD74H_?}Ap5AmLt!r5}q*|HQ^lJd?j&DoW6b`?4Z4ZWG+yt6gOuJ1s*4ve!F?baK6 zH6qPfDhU*GV4`1jIph$Mvru$p9jGjwtswJKIVe;7?V5cRzKS7Kw(x!LyK{ha*-`$|gVl zlY5On$Tj|;;BQ*=e&O%F=kH$b$@#nU{@t2?ch0~28|ykX?u$L?!D}xs1@hj`9J{{# z#>4qr$n_xMJkaLnIJ!H>p#r>_OSby$ND=r4_M{=GC4f)vBx2*YK~sb zpB{~hwKd9|-)gK7>4a=?f;=NPm8e;)&=>1U{D`TB{|>n-32u|9+U_~q^3D#;*^zU0 z6bY>=4av9|VGRXcwWjngdjA;$e?s6-3H*!z>sXDAtxyI5DyEY9mok5=7Msnv$`SBc zZF^QZ6S!?Q@J18(EViv+l_lVG+Im+x6Esx%@@3N*H0{*$b>&? z&hB}?J@4(&ygg|i8BW)A*Mck4y=2QfH)+mI*y>!HwBqrl-<{ugZC~mnTeDNTOOcCx zslrbuUd~o+6QJRQf=dU-RjxP}+>&M9O=_eOD$U@sno!NbP@Y<2L9*gWFrS1ga7U57 zK>J3jW!AFbn&9B@w?A5JR=S~*r2Z5GTsNSpvKIJVPjg(Q1E{v9s_utn7~B z=H0hz4y6L83!{(=bHbdh@^sm(t-2qV_&NKWBiUT)HMTEI@m%$`x>AW`XDNma4#z}| zu8a2Z*7ANDI~H4&lC7Ada!b{#Gv}DK&pL`nHa5>%v;K0)atyvA*KCaksd{ugckN2D zt6XE&QJr6vSJRT@B1$)pjo9P7_$_M>vBsZ!H^$ zL=v;?Y>mVhk+QXtMWLoiR@DPUD<+Adlo>~NEknjmvQ4+bEY^i7MZTa+ps%`v?JVPn zA*~@?Q)Iuu^MgHuq_RkHUsR>Ttg0NralZ>S`#Q=^6q(tJ0yy3~Wu8?bD~jbO)D@XxoqEoLka9&Dp+micaf2J%4Cv%RNtf&eOiq zwQbp_J#i%8^_iLl}gE zamXf2lhxq$@4WqxA7xS*hw_*~M{8whT6&Yo#Vc6&%z?+5f=AW-94)KVDTwj*j;wR( z@Y3OQG83M^l)kha&N+*Fb0)H&B*ocS3_XH+Ug2y0fEujmZ*v?LZAtJ{cKO-I>GC?2 z|0lhqsC?A>(@r+^I;U(zIL-(N=jxN!$>LW9Kk2A<}`Tt9e z^#A}ZbH2UCwY(<>{HpKD_UG$+wfbH&gN-`a$mm32uKHuBs*p9y$VnH@C8BZNt|k^8Wpre}9f$zwg+b72ZGb;fX&B zET6vBcDwCP_|~R-9s6?~`!i#ivAe?=Yq5<&^Y&cx_T}gE&3m=xy}72-cLo4*&z!{d zxs-oqSbJue5}HnbWwkUkqF)Udpa}vr-ZrlODHB2O@QCJpdo|zQwDrEH?)v_P{h6oc z4_!Ny6PgX0wZvjobV)pgSd)4QPv=8cXi8JL-l${72AbH zg{{5vBaqs5u-nUHTfq4Vrj6#>2y>Qr+xOP8t*s^5=lOGlnJnM~5ywZ?Sxb2jnNAy* zPw=2DnKCRO-Hca$C^F9{n@VM%kP~ZUp$3!d(3YvJqb)NYKT^|LTd9Rw(^c78sm^1i zYRm|w5$`Y+_I2Loz*(q@x1)xst|Q%yS1Q}d?sAVnF~FL#$pBTyHALT^j8DhuAUzp& z?7U$WDk-4Ug znY|e)7ud0M3c$FsZxo~69gMR@P{j=9P-xLf+hAG-4S`=X1gr9wD5Q{vYV@4gVX5N^ zc{Cok*R)%y5@L|(EcQB?3-m5s0HDj;%ep$#ItW26K2Bg5U-M|J5Sg+llbw)tNuPOHkM!(f|diu&=! zN3WLtiot)Emqv^(kwsG6CCBJdIM%TW4 z!+xz{|6N{dIC#%-Fy}b=RprZV? zRWG-3kiWC{H_zra3>a7H_?4l;#x1zLQs~^Qb?!oeNcXIKI%eC*N0gQY6> z#cmcYv~_&Q-qXC|slUNz_RT+c?YW%LX5e*&6b2d>rL_-{tB}`e&T!a}%{Mc`T$h7# zB*8v}U>^_w&vw50{Hq6WM7Hv?!y*CV3juuIfP<>%X+Lz59_VZ>KCTdnRWQtpFz>?k4l6NEc;)r(8+$|`^=JW9ne|_QpICnPa_w03S&$(pJ$lmp!;hZSNzeO2^Y&qkc1nKq6EYMwS^5{^7Ld=8_sBQ

9rSpVzyN_43A{vr7$5U~ z>w<)RVCLdw9!6alLl>A<&-jR;;SgQ2VH)ODFFlgz!1rdx_g6=hzriETl6n}u$EFF- z-{*WO_A7ApDfTOH-W2;4xW-)RDscW>=_+u&xkp_Eu0QvOT=(5|>8|wH{I+Y`QjUV) zNxhIB$XqhMwbBGJ#jn~o@&owL>e28kmi~2R?q1H~NwsF4%JI#4zFFg&S1on?TYP$W zm81KT)wpMicjL)`U>=qhv&O2pwk0?JL%mK&mytBs93UbPl{MQLA`GoEava%;g?l=gKw<3KkLKDHKoMQLA` zGlqCOj~#=xAT#(CrG8z`YP9o>#z-2M*??fqAgKa0aX)xw)f(ing9lJ>c+N iEqIj|_(6UNW!U}Fa?7&&PXBV9wt1hC^xcp#i~k1zwavo- diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/actions.py b/myenv/Lib/site-packages/pip/_vendor/pyparsing/actions.py deleted file mode 100644 index ca6e4c6..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/pyparsing/actions.py +++ /dev/null @@ -1,217 +0,0 @@ -# actions.py - -from .exceptions import ParseException -from .util import col, replaced_by_pep8 - - -class OnlyOnce: - """ - Wrapper for parse actions, to ensure they are only called once. - """ - - def __init__(self, method_call): - from .core import _trim_arity - - self.callable = _trim_arity(method_call) - self.called = False - - def __call__(self, s, l, t): - if not self.called: - results = self.callable(s, l, t) - self.called = True - return results - raise ParseException(s, l, "OnlyOnce obj called multiple times w/out reset") - - def reset(self): - """ - Allow the associated parse action to be called once more. - """ - - self.called = False - - -def match_only_at_col(n): - """ - Helper method for defining parse actions that require matching at - a specific column in the input text. - """ - - def verify_col(strg, locn, toks): - if col(locn, strg) != n: - raise ParseException(strg, locn, f"matched token not at column {n}") - - return verify_col - - -def replace_with(repl_str): - """ - Helper method for common parse actions that simply return - a literal value. Especially useful when used with - :class:`transform_string` (). - - Example:: - - num = Word(nums).set_parse_action(lambda toks: int(toks[0])) - na = one_of("N/A NA").set_parse_action(replace_with(math.nan)) - term = na | num - - term[1, ...].parse_string("324 234 N/A 234") # -> [324, 234, nan, 234] - """ - return lambda s, l, t: [repl_str] - - -def remove_quotes(s, l, t): - """ - Helper parse action for removing quotation marks from parsed - quoted strings. - - Example:: - - # by default, quotation marks are included in parsed results - quoted_string.parse_string("'Now is the Winter of our Discontent'") # -> ["'Now is the Winter of our Discontent'"] - - # use remove_quotes to strip quotation marks from parsed results - quoted_string.set_parse_action(remove_quotes) - quoted_string.parse_string("'Now is the Winter of our Discontent'") # -> ["Now is the Winter of our Discontent"] - """ - return t[0][1:-1] - - -def with_attribute(*args, **attr_dict): - """ - Helper to create a validating parse action to be used with start - tags created with :class:`make_xml_tags` or - :class:`make_html_tags`. Use ``with_attribute`` to qualify - a starting tag with a required attribute value, to avoid false - matches on common tags such as ```` or ``

``. - - Call ``with_attribute`` with a series of attribute names and - values. Specify the list of filter attributes names and values as: - - - keyword arguments, as in ``(align="right")``, or - - as an explicit dict with ``**`` operator, when an attribute - name is also a Python reserved word, as in ``**{"class":"Customer", "align":"right"}`` - - a list of name-value tuples, as in ``(("ns1:class", "Customer"), ("ns2:align", "right"))`` - - For attribute names with a namespace prefix, you must use the second - form. Attribute names are matched insensitive to upper/lower case. - - If just testing for ``class`` (with or without a namespace), use - :class:`with_class`. - - To verify that the attribute exists, but without specifying a value, - pass ``with_attribute.ANY_VALUE`` as the value. - - Example:: - - html = ''' -
- Some text -
1 4 0 1 0
-
1,3 2,3 1,1
-
this has no type
-
- - ''' - div,div_end = make_html_tags("div") - - # only match div tag having a type attribute with value "grid" - div_grid = div().set_parse_action(with_attribute(type="grid")) - grid_expr = div_grid + SkipTo(div | div_end)("body") - for grid_header in grid_expr.search_string(html): - print(grid_header.body) - - # construct a match with any div tag having a type attribute, regardless of the value - div_any_type = div().set_parse_action(with_attribute(type=with_attribute.ANY_VALUE)) - div_expr = div_any_type + SkipTo(div | div_end)("body") - for div_header in div_expr.search_string(html): - print(div_header.body) - - prints:: - - 1 4 0 1 0 - - 1 4 0 1 0 - 1,3 2,3 1,1 - """ - if args: - attrs = args[:] - else: - attrs = attr_dict.items() - attrs = [(k, v) for k, v in attrs] - - def pa(s, l, tokens): - for attrName, attrValue in attrs: - if attrName not in tokens: - raise ParseException(s, l, "no matching attribute " + attrName) - if attrValue != with_attribute.ANY_VALUE and tokens[attrName] != attrValue: - raise ParseException( - s, - l, - f"attribute {attrName!r} has value {tokens[attrName]!r}, must be {attrValue!r}", - ) - - return pa - - -with_attribute.ANY_VALUE = object() # type: ignore [attr-defined] - - -def with_class(classname, namespace=""): - """ - Simplified version of :class:`with_attribute` when - matching on a div class - made difficult because ``class`` is - a reserved word in Python. - - Example:: - - html = ''' -
- Some text -
1 4 0 1 0
-
1,3 2,3 1,1
-
this <div> has no class
-
- - ''' - div,div_end = make_html_tags("div") - div_grid = div().set_parse_action(with_class("grid")) - - grid_expr = div_grid + SkipTo(div | div_end)("body") - for grid_header in grid_expr.search_string(html): - print(grid_header.body) - - div_any_type = div().set_parse_action(with_class(withAttribute.ANY_VALUE)) - div_expr = div_any_type + SkipTo(div | div_end)("body") - for div_header in div_expr.search_string(html): - print(div_header.body) - - prints:: - - 1 4 0 1 0 - - 1 4 0 1 0 - 1,3 2,3 1,1 - """ - classattr = f"{namespace}:class" if namespace else "class" - return with_attribute(**{classattr: classname}) - - -# pre-PEP8 compatibility symbols -# fmt: off -@replaced_by_pep8(replace_with) -def replaceWith(): ... - -@replaced_by_pep8(remove_quotes) -def removeQuotes(): ... - -@replaced_by_pep8(with_attribute) -def withAttribute(): ... - -@replaced_by_pep8(with_class) -def withClass(): ... - -@replaced_by_pep8(match_only_at_col) -def matchOnlyAtCol(): ... - -# fmt: on diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/common.py b/myenv/Lib/site-packages/pip/_vendor/pyparsing/common.py deleted file mode 100644 index 7a666b2..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/pyparsing/common.py +++ /dev/null @@ -1,432 +0,0 @@ -# common.py -from .core import * -from .helpers import DelimitedList, any_open_tag, any_close_tag -from datetime import datetime - - -# some other useful expressions - using lower-case class name since we are really using this as a namespace -class pyparsing_common: - """Here are some common low-level expressions that may be useful in - jump-starting parser development: - - - numeric forms (:class:`integers`, :class:`reals`, - :class:`scientific notation`) - - common :class:`programming identifiers` - - network addresses (:class:`MAC`, - :class:`IPv4`, :class:`IPv6`) - - ISO8601 :class:`dates` and - :class:`datetime` - - :class:`UUID` - - :class:`comma-separated list` - - :class:`url` - - Parse actions: - - - :class:`convert_to_integer` - - :class:`convert_to_float` - - :class:`convert_to_date` - - :class:`convert_to_datetime` - - :class:`strip_html_tags` - - :class:`upcase_tokens` - - :class:`downcase_tokens` - - Example:: - - pyparsing_common.number.run_tests(''' - # any int or real number, returned as the appropriate type - 100 - -100 - +100 - 3.14159 - 6.02e23 - 1e-12 - ''') - - pyparsing_common.fnumber.run_tests(''' - # any int or real number, returned as float - 100 - -100 - +100 - 3.14159 - 6.02e23 - 1e-12 - ''') - - pyparsing_common.hex_integer.run_tests(''' - # hex numbers - 100 - FF - ''') - - pyparsing_common.fraction.run_tests(''' - # fractions - 1/2 - -3/4 - ''') - - pyparsing_common.mixed_integer.run_tests(''' - # mixed fractions - 1 - 1/2 - -3/4 - 1-3/4 - ''') - - import uuid - pyparsing_common.uuid.set_parse_action(token_map(uuid.UUID)) - pyparsing_common.uuid.run_tests(''' - # uuid - 12345678-1234-5678-1234-567812345678 - ''') - - prints:: - - # any int or real number, returned as the appropriate type - 100 - [100] - - -100 - [-100] - - +100 - [100] - - 3.14159 - [3.14159] - - 6.02e23 - [6.02e+23] - - 1e-12 - [1e-12] - - # any int or real number, returned as float - 100 - [100.0] - - -100 - [-100.0] - - +100 - [100.0] - - 3.14159 - [3.14159] - - 6.02e23 - [6.02e+23] - - 1e-12 - [1e-12] - - # hex numbers - 100 - [256] - - FF - [255] - - # fractions - 1/2 - [0.5] - - -3/4 - [-0.75] - - # mixed fractions - 1 - [1] - - 1/2 - [0.5] - - -3/4 - [-0.75] - - 1-3/4 - [1.75] - - # uuid - 12345678-1234-5678-1234-567812345678 - [UUID('12345678-1234-5678-1234-567812345678')] - """ - - convert_to_integer = token_map(int) - """ - Parse action for converting parsed integers to Python int - """ - - convert_to_float = token_map(float) - """ - Parse action for converting parsed numbers to Python float - """ - - integer = Word(nums).set_name("integer").set_parse_action(convert_to_integer) - """expression that parses an unsigned integer, returns an int""" - - hex_integer = ( - Word(hexnums).set_name("hex integer").set_parse_action(token_map(int, 16)) - ) - """expression that parses a hexadecimal integer, returns an int""" - - signed_integer = ( - Regex(r"[+-]?\d+") - .set_name("signed integer") - .set_parse_action(convert_to_integer) - ) - """expression that parses an integer with optional leading sign, returns an int""" - - fraction = ( - signed_integer().set_parse_action(convert_to_float) - + "/" - + signed_integer().set_parse_action(convert_to_float) - ).set_name("fraction") - """fractional expression of an integer divided by an integer, returns a float""" - fraction.add_parse_action(lambda tt: tt[0] / tt[-1]) - - mixed_integer = ( - fraction | signed_integer + Opt(Opt("-").suppress() + fraction) - ).set_name("fraction or mixed integer-fraction") - """mixed integer of the form 'integer - fraction', with optional leading integer, returns float""" - mixed_integer.add_parse_action(sum) - - real = ( - Regex(r"[+-]?(?:\d+\.\d*|\.\d+)") - .set_name("real number") - .set_parse_action(convert_to_float) - ) - """expression that parses a floating point number and returns a float""" - - sci_real = ( - Regex(r"[+-]?(?:\d+(?:[eE][+-]?\d+)|(?:\d+\.\d*|\.\d+)(?:[eE][+-]?\d+)?)") - .set_name("real number with scientific notation") - .set_parse_action(convert_to_float) - ) - """expression that parses a floating point number with optional - scientific notation and returns a float""" - - # streamlining this expression makes the docs nicer-looking - number = (sci_real | real | signed_integer).setName("number").streamline() - """any numeric expression, returns the corresponding Python type""" - - fnumber = ( - Regex(r"[+-]?\d+\.?\d*([eE][+-]?\d+)?") - .set_name("fnumber") - .set_parse_action(convert_to_float) - ) - """any int or real number, returned as float""" - - identifier = Word(identchars, identbodychars).set_name("identifier") - """typical code identifier (leading alpha or '_', followed by 0 or more alphas, nums, or '_')""" - - ipv4_address = Regex( - r"(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})(\.(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})){3}" - ).set_name("IPv4 address") - "IPv4 address (``0.0.0.0 - 255.255.255.255``)" - - _ipv6_part = Regex(r"[0-9a-fA-F]{1,4}").set_name("hex_integer") - _full_ipv6_address = (_ipv6_part + (":" + _ipv6_part) * 7).set_name( - "full IPv6 address" - ) - _short_ipv6_address = ( - Opt(_ipv6_part + (":" + _ipv6_part) * (0, 6)) - + "::" - + Opt(_ipv6_part + (":" + _ipv6_part) * (0, 6)) - ).set_name("short IPv6 address") - _short_ipv6_address.add_condition( - lambda t: sum(1 for tt in t if pyparsing_common._ipv6_part.matches(tt)) < 8 - ) - _mixed_ipv6_address = ("::ffff:" + ipv4_address).set_name("mixed IPv6 address") - ipv6_address = Combine( - (_full_ipv6_address | _mixed_ipv6_address | _short_ipv6_address).set_name( - "IPv6 address" - ) - ).set_name("IPv6 address") - "IPv6 address (long, short, or mixed form)" - - mac_address = Regex( - r"[0-9a-fA-F]{2}([:.-])[0-9a-fA-F]{2}(?:\1[0-9a-fA-F]{2}){4}" - ).set_name("MAC address") - "MAC address xx:xx:xx:xx:xx (may also have '-' or '.' delimiters)" - - @staticmethod - def convert_to_date(fmt: str = "%Y-%m-%d"): - """ - Helper to create a parse action for converting parsed date string to Python datetime.date - - Params - - - fmt - format to be passed to datetime.strptime (default= ``"%Y-%m-%d"``) - - Example:: - - date_expr = pyparsing_common.iso8601_date.copy() - date_expr.set_parse_action(pyparsing_common.convert_to_date()) - print(date_expr.parse_string("1999-12-31")) - - prints:: - - [datetime.date(1999, 12, 31)] - """ - - def cvt_fn(ss, ll, tt): - try: - return datetime.strptime(tt[0], fmt).date() - except ValueError as ve: - raise ParseException(ss, ll, str(ve)) - - return cvt_fn - - @staticmethod - def convert_to_datetime(fmt: str = "%Y-%m-%dT%H:%M:%S.%f"): - """Helper to create a parse action for converting parsed - datetime string to Python datetime.datetime - - Params - - - fmt - format to be passed to datetime.strptime (default= ``"%Y-%m-%dT%H:%M:%S.%f"``) - - Example:: - - dt_expr = pyparsing_common.iso8601_datetime.copy() - dt_expr.set_parse_action(pyparsing_common.convert_to_datetime()) - print(dt_expr.parse_string("1999-12-31T23:59:59.999")) - - prints:: - - [datetime.datetime(1999, 12, 31, 23, 59, 59, 999000)] - """ - - def cvt_fn(s, l, t): - try: - return datetime.strptime(t[0], fmt) - except ValueError as ve: - raise ParseException(s, l, str(ve)) - - return cvt_fn - - iso8601_date = Regex( - r"(?P\d{4})(?:-(?P\d\d)(?:-(?P\d\d))?)?" - ).set_name("ISO8601 date") - "ISO8601 date (``yyyy-mm-dd``)" - - iso8601_datetime = Regex( - r"(?P\d{4})-(?P\d\d)-(?P\d\d)[T ](?P\d\d):(?P\d\d)(:(?P\d\d(\.\d*)?)?)?(?PZ|[+-]\d\d:?\d\d)?" - ).set_name("ISO8601 datetime") - "ISO8601 datetime (``yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)``) - trailing seconds, milliseconds, and timezone optional; accepts separating ``'T'`` or ``' '``" - - uuid = Regex(r"[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}").set_name("UUID") - "UUID (``xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx``)" - - _html_stripper = any_open_tag.suppress() | any_close_tag.suppress() - - @staticmethod - def strip_html_tags(s: str, l: int, tokens: ParseResults): - """Parse action to remove HTML tags from web page HTML source - - Example:: - - # strip HTML links from normal text - text = 'More info at the
pyparsing wiki page' - td, td_end = make_html_tags("TD") - table_text = td + SkipTo(td_end).set_parse_action(pyparsing_common.strip_html_tags)("body") + td_end - print(table_text.parse_string(text).body) - - Prints:: - - More info at the pyparsing wiki page - """ - return pyparsing_common._html_stripper.transform_string(tokens[0]) - - _commasepitem = ( - Combine( - OneOrMore( - ~Literal(",") - + ~LineEnd() - + Word(printables, exclude_chars=",") - + Opt(White(" \t") + ~FollowedBy(LineEnd() | ",")) - ) - ) - .streamline() - .set_name("commaItem") - ) - comma_separated_list = DelimitedList( - Opt(quoted_string.copy() | _commasepitem, default="") - ).set_name("comma separated list") - """Predefined expression of 1 or more printable words or quoted strings, separated by commas.""" - - upcase_tokens = staticmethod(token_map(lambda t: t.upper())) - """Parse action to convert tokens to upper case.""" - - downcase_tokens = staticmethod(token_map(lambda t: t.lower())) - """Parse action to convert tokens to lower case.""" - - # fmt: off - url = Regex( - # https://mathiasbynens.be/demo/url-regex - # https://gist.github.com/dperini/729294 - r"(?P" + - # protocol identifier (optional) - # short syntax // still required - r"(?:(?:(?Phttps?|ftp):)?\/\/)" + - # user:pass BasicAuth (optional) - r"(?:(?P\S+(?::\S*)?)@)?" + - r"(?P" + - # IP address exclusion - # private & local networks - r"(?!(?:10|127)(?:\.\d{1,3}){3})" + - r"(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})" + - r"(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})" + - # IP address dotted notation octets - # excludes loopback network 0.0.0.0 - # excludes reserved space >= 224.0.0.0 - # excludes network & broadcast addresses - # (first & last IP address of each class) - r"(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])" + - r"(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}" + - r"(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))" + - r"|" + - # host & domain names, may end with dot - # can be replaced by a shortest alternative - # (?![-_])(?:[-\w\u00a1-\uffff]{0,63}[^-_]\.)+ - r"(?:" + - r"(?:" + - r"[a-z0-9\u00a1-\uffff]" + - r"[a-z0-9\u00a1-\uffff_-]{0,62}" + - r")?" + - r"[a-z0-9\u00a1-\uffff]\." + - r")+" + - # TLD identifier name, may end with dot - r"(?:[a-z\u00a1-\uffff]{2,}\.?)" + - r")" + - # port number (optional) - r"(:(?P\d{2,5}))?" + - # resource path (optional) - r"(?P\/[^?# ]*)?" + - # query string (optional) - r"(\?(?P[^#]*))?" + - # fragment (optional) - r"(#(?P\S*))?" + - r")" - ).set_name("url") - """URL (http/https/ftp scheme)""" - # fmt: on - - # pre-PEP8 compatibility names - convertToInteger = convert_to_integer - """Deprecated - use :class:`convert_to_integer`""" - convertToFloat = convert_to_float - """Deprecated - use :class:`convert_to_float`""" - convertToDate = convert_to_date - """Deprecated - use :class:`convert_to_date`""" - convertToDatetime = convert_to_datetime - """Deprecated - use :class:`convert_to_datetime`""" - stripHTMLTags = strip_html_tags - """Deprecated - use :class:`strip_html_tags`""" - upcaseTokens = upcase_tokens - """Deprecated - use :class:`upcase_tokens`""" - downcaseTokens = downcase_tokens - """Deprecated - use :class:`downcase_tokens`""" - - -_builtin_exprs = [ - v for v in vars(pyparsing_common).values() if isinstance(v, ParserElement) -] diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/core.py b/myenv/Lib/site-packages/pip/_vendor/pyparsing/core.py deleted file mode 100644 index 8d5a856..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/pyparsing/core.py +++ /dev/null @@ -1,6115 +0,0 @@ -# -# core.py -# - -from collections import deque -import os -import typing -from typing import ( - Any, - Callable, - Generator, - List, - NamedTuple, - Sequence, - Set, - TextIO, - Tuple, - Union, - cast, -) -from abc import ABC, abstractmethod -from enum import Enum -import string -import copy -import warnings -import re -import sys -from collections.abc import Iterable -import traceback -import types -from operator import itemgetter -from functools import wraps -from threading import RLock -from pathlib import Path - -from .util import ( - _FifoCache, - _UnboundedCache, - __config_flags, - _collapse_string_to_ranges, - _escape_regex_range_chars, - _bslash, - _flatten, - LRUMemo as _LRUMemo, - UnboundedMemo as _UnboundedMemo, - replaced_by_pep8, -) -from .exceptions import * -from .actions import * -from .results import ParseResults, _ParseResultsWithOffset -from .unicode import pyparsing_unicode - -_MAX_INT = sys.maxsize -str_type: Tuple[type, ...] = (str, bytes) - -# -# Copyright (c) 2003-2022 Paul T. McGuire -# -# Permission is hereby granted, free of charge, to any person obtaining -# a copy of this software and associated documentation files (the -# "Software"), to deal in the Software without restriction, including -# without limitation the rights to use, copy, modify, merge, publish, -# distribute, sublicense, and/or sell copies of the Software, and to -# permit persons to whom the Software is furnished to do so, subject to -# the following conditions: -# -# The above copyright notice and this permission notice shall be -# included in all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -# - - -if sys.version_info >= (3, 8): - from functools import cached_property -else: - - class cached_property: - def __init__(self, func): - self._func = func - - def __get__(self, instance, owner=None): - ret = instance.__dict__[self._func.__name__] = self._func(instance) - return ret - - -class __compat__(__config_flags): - """ - A cross-version compatibility configuration for pyparsing features that will be - released in a future version. By setting values in this configuration to True, - those features can be enabled in prior versions for compatibility development - and testing. - - - ``collect_all_And_tokens`` - flag to enable fix for Issue #63 that fixes erroneous grouping - of results names when an :class:`And` expression is nested within an :class:`Or` or :class:`MatchFirst`; - maintained for compatibility, but setting to ``False`` no longer restores pre-2.3.1 - behavior - """ - - _type_desc = "compatibility" - - collect_all_And_tokens = True - - _all_names = [__ for __ in locals() if not __.startswith("_")] - _fixed_names = """ - collect_all_And_tokens - """.split() - - -class __diag__(__config_flags): - _type_desc = "diagnostic" - - warn_multiple_tokens_in_named_alternation = False - warn_ungrouped_named_tokens_in_collection = False - warn_name_set_on_empty_Forward = False - warn_on_parse_using_empty_Forward = False - warn_on_assignment_to_Forward = False - warn_on_multiple_string_args_to_oneof = False - warn_on_match_first_with_lshift_operator = False - enable_debug_on_named_expressions = False - - _all_names = [__ for __ in locals() if not __.startswith("_")] - _warning_names = [name for name in _all_names if name.startswith("warn")] - _debug_names = [name for name in _all_names if name.startswith("enable_debug")] - - @classmethod - def enable_all_warnings(cls) -> None: - for name in cls._warning_names: - cls.enable(name) - - -class Diagnostics(Enum): - """ - Diagnostic configuration (all default to disabled) - - - ``warn_multiple_tokens_in_named_alternation`` - flag to enable warnings when a results - name is defined on a :class:`MatchFirst` or :class:`Or` expression with one or more :class:`And` subexpressions - - ``warn_ungrouped_named_tokens_in_collection`` - flag to enable warnings when a results - name is defined on a containing expression with ungrouped subexpressions that also - have results names - - ``warn_name_set_on_empty_Forward`` - flag to enable warnings when a :class:`Forward` is defined - with a results name, but has no contents defined - - ``warn_on_parse_using_empty_Forward`` - flag to enable warnings when a :class:`Forward` is - defined in a grammar but has never had an expression attached to it - - ``warn_on_assignment_to_Forward`` - flag to enable warnings when a :class:`Forward` is defined - but is overwritten by assigning using ``'='`` instead of ``'<<='`` or ``'<<'`` - - ``warn_on_multiple_string_args_to_oneof`` - flag to enable warnings when :class:`one_of` is - incorrectly called with multiple str arguments - - ``enable_debug_on_named_expressions`` - flag to auto-enable debug on all subsequent - calls to :class:`ParserElement.set_name` - - Diagnostics are enabled/disabled by calling :class:`enable_diag` and :class:`disable_diag`. - All warnings can be enabled by calling :class:`enable_all_warnings`. - """ - - warn_multiple_tokens_in_named_alternation = 0 - warn_ungrouped_named_tokens_in_collection = 1 - warn_name_set_on_empty_Forward = 2 - warn_on_parse_using_empty_Forward = 3 - warn_on_assignment_to_Forward = 4 - warn_on_multiple_string_args_to_oneof = 5 - warn_on_match_first_with_lshift_operator = 6 - enable_debug_on_named_expressions = 7 - - -def enable_diag(diag_enum: Diagnostics) -> None: - """ - Enable a global pyparsing diagnostic flag (see :class:`Diagnostics`). - """ - __diag__.enable(diag_enum.name) - - -def disable_diag(diag_enum: Diagnostics) -> None: - """ - Disable a global pyparsing diagnostic flag (see :class:`Diagnostics`). - """ - __diag__.disable(diag_enum.name) - - -def enable_all_warnings() -> None: - """ - Enable all global pyparsing diagnostic warnings (see :class:`Diagnostics`). - """ - __diag__.enable_all_warnings() - - -# hide abstract class -del __config_flags - - -def _should_enable_warnings( - cmd_line_warn_options: typing.Iterable[str], warn_env_var: typing.Optional[str] -) -> bool: - enable = bool(warn_env_var) - for warn_opt in cmd_line_warn_options: - w_action, w_message, w_category, w_module, w_line = (warn_opt + "::::").split( - ":" - )[:5] - if not w_action.lower().startswith("i") and ( - not (w_message or w_category or w_module) or w_module == "pyparsing" - ): - enable = True - elif w_action.lower().startswith("i") and w_module in ("pyparsing", ""): - enable = False - return enable - - -if _should_enable_warnings( - sys.warnoptions, os.environ.get("PYPARSINGENABLEALLWARNINGS") -): - enable_all_warnings() - - -# build list of single arg builtins, that can be used as parse actions -_single_arg_builtins = { - sum, - len, - sorted, - reversed, - list, - tuple, - set, - any, - all, - min, - max, -} - -_generatorType = types.GeneratorType -ParseImplReturnType = Tuple[int, Any] -PostParseReturnType = Union[ParseResults, Sequence[ParseResults]] -ParseAction = Union[ - Callable[[], Any], - Callable[[ParseResults], Any], - Callable[[int, ParseResults], Any], - Callable[[str, int, ParseResults], Any], -] -ParseCondition = Union[ - Callable[[], bool], - Callable[[ParseResults], bool], - Callable[[int, ParseResults], bool], - Callable[[str, int, ParseResults], bool], -] -ParseFailAction = Callable[[str, int, "ParserElement", Exception], None] -DebugStartAction = Callable[[str, int, "ParserElement", bool], None] -DebugSuccessAction = Callable[ - [str, int, int, "ParserElement", ParseResults, bool], None -] -DebugExceptionAction = Callable[[str, int, "ParserElement", Exception, bool], None] - - -alphas = string.ascii_uppercase + string.ascii_lowercase -identchars = pyparsing_unicode.Latin1.identchars -identbodychars = pyparsing_unicode.Latin1.identbodychars -nums = "0123456789" -hexnums = nums + "ABCDEFabcdef" -alphanums = alphas + nums -printables = "".join([c for c in string.printable if c not in string.whitespace]) - -_trim_arity_call_line: traceback.StackSummary = None # type: ignore[assignment] - - -def _trim_arity(func, max_limit=3): - """decorator to trim function calls to match the arity of the target""" - global _trim_arity_call_line - - if func in _single_arg_builtins: - return lambda s, l, t: func(t) - - limit = 0 - found_arity = False - - # synthesize what would be returned by traceback.extract_stack at the call to - # user's parse action 'func', so that we don't incur call penalty at parse time - - # fmt: off - LINE_DIFF = 7 - # IF ANY CODE CHANGES, EVEN JUST COMMENTS OR BLANK LINES, BETWEEN THE NEXT LINE AND - # THE CALL TO FUNC INSIDE WRAPPER, LINE_DIFF MUST BE MODIFIED!!!! - _trim_arity_call_line = (_trim_arity_call_line or traceback.extract_stack(limit=2)[-1]) - pa_call_line_synth = (_trim_arity_call_line[0], _trim_arity_call_line[1] + LINE_DIFF) - - def wrapper(*args): - nonlocal found_arity, limit - while 1: - try: - ret = func(*args[limit:]) - found_arity = True - return ret - except TypeError as te: - # re-raise TypeErrors if they did not come from our arity testing - if found_arity: - raise - else: - tb = te.__traceback__ - frames = traceback.extract_tb(tb, limit=2) - frame_summary = frames[-1] - trim_arity_type_error = ( - [frame_summary[:2]][-1][:2] == pa_call_line_synth - ) - del tb - - if trim_arity_type_error: - if limit < max_limit: - limit += 1 - continue - - raise - # fmt: on - - # copy func name to wrapper for sensible debug output - # (can't use functools.wraps, since that messes with function signature) - func_name = getattr(func, "__name__", getattr(func, "__class__").__name__) - wrapper.__name__ = func_name - wrapper.__doc__ = func.__doc__ - - return wrapper - - -def condition_as_parse_action( - fn: ParseCondition, message: typing.Optional[str] = None, fatal: bool = False -) -> ParseAction: - """ - Function to convert a simple predicate function that returns ``True`` or ``False`` - into a parse action. Can be used in places when a parse action is required - and :class:`ParserElement.add_condition` cannot be used (such as when adding a condition - to an operator level in :class:`infix_notation`). - - Optional keyword arguments: - - - ``message`` - define a custom message to be used in the raised exception - - ``fatal`` - if True, will raise :class:`ParseFatalException` to stop parsing immediately; - otherwise will raise :class:`ParseException` - - """ - msg = message if message is not None else "failed user-defined condition" - exc_type = ParseFatalException if fatal else ParseException - fn = _trim_arity(fn) - - @wraps(fn) - def pa(s, l, t): - if not bool(fn(s, l, t)): - raise exc_type(s, l, msg) - - return pa - - -def _default_start_debug_action( - instring: str, loc: int, expr: "ParserElement", cache_hit: bool = False -): - cache_hit_str = "*" if cache_hit else "" - print( - ( - f"{cache_hit_str}Match {expr} at loc {loc}({lineno(loc, instring)},{col(loc, instring)})\n" - f" {line(loc, instring)}\n" - f" {' ' * (col(loc, instring) - 1)}^" - ) - ) - - -def _default_success_debug_action( - instring: str, - startloc: int, - endloc: int, - expr: "ParserElement", - toks: ParseResults, - cache_hit: bool = False, -): - cache_hit_str = "*" if cache_hit else "" - print(f"{cache_hit_str}Matched {expr} -> {toks.as_list()}") - - -def _default_exception_debug_action( - instring: str, - loc: int, - expr: "ParserElement", - exc: Exception, - cache_hit: bool = False, -): - cache_hit_str = "*" if cache_hit else "" - print(f"{cache_hit_str}Match {expr} failed, {type(exc).__name__} raised: {exc}") - - -def null_debug_action(*args): - """'Do-nothing' debug action, to suppress debugging output during parsing.""" - - -class ParserElement(ABC): - """Abstract base level parser element class.""" - - DEFAULT_WHITE_CHARS: str = " \n\t\r" - verbose_stacktrace: bool = False - _literalStringClass: type = None # type: ignore[assignment] - - @staticmethod - def set_default_whitespace_chars(chars: str) -> None: - r""" - Overrides the default whitespace chars - - Example:: - - # default whitespace chars are space, and newline - Word(alphas)[1, ...].parse_string("abc def\nghi jkl") # -> ['abc', 'def', 'ghi', 'jkl'] - - # change to just treat newline as significant - ParserElement.set_default_whitespace_chars(" \t") - Word(alphas)[1, ...].parse_string("abc def\nghi jkl") # -> ['abc', 'def'] - """ - ParserElement.DEFAULT_WHITE_CHARS = chars - - # update whitespace all parse expressions defined in this module - for expr in _builtin_exprs: - if expr.copyDefaultWhiteChars: - expr.whiteChars = set(chars) - - @staticmethod - def inline_literals_using(cls: type) -> None: - """ - Set class to be used for inclusion of string literals into a parser. - - Example:: - - # default literal class used is Literal - integer = Word(nums) - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - date_str.parse_string("1999/12/31") # -> ['1999', '/', '12', '/', '31'] - - - # change to Suppress - ParserElement.inline_literals_using(Suppress) - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - date_str.parse_string("1999/12/31") # -> ['1999', '12', '31'] - """ - ParserElement._literalStringClass = cls - - @classmethod - def using_each(cls, seq, **class_kwargs): - """ - Yields a sequence of class(obj, **class_kwargs) for obj in seq. - - Example:: - - LPAR, RPAR, LBRACE, RBRACE, SEMI = Suppress.using_each("(){};") - - """ - yield from (cls(obj, **class_kwargs) for obj in seq) - - class DebugActions(NamedTuple): - debug_try: typing.Optional[DebugStartAction] - debug_match: typing.Optional[DebugSuccessAction] - debug_fail: typing.Optional[DebugExceptionAction] - - def __init__(self, savelist: bool = False): - self.parseAction: List[ParseAction] = list() - self.failAction: typing.Optional[ParseFailAction] = None - self.customName: str = None # type: ignore[assignment] - self._defaultName: typing.Optional[str] = None - self.resultsName: str = None # type: ignore[assignment] - self.saveAsList = savelist - self.skipWhitespace = True - self.whiteChars = set(ParserElement.DEFAULT_WHITE_CHARS) - self.copyDefaultWhiteChars = True - # used when checking for left-recursion - self.mayReturnEmpty = False - self.keepTabs = False - self.ignoreExprs: List["ParserElement"] = list() - self.debug = False - self.streamlined = False - # optimize exception handling for subclasses that don't advance parse index - self.mayIndexError = True - self.errmsg = "" - # mark results names as modal (report only last) or cumulative (list all) - self.modalResults = True - # custom debug actions - self.debugActions = self.DebugActions(None, None, None) - # avoid redundant calls to preParse - self.callPreparse = True - self.callDuringTry = False - self.suppress_warnings_: List[Diagnostics] = [] - - def suppress_warning(self, warning_type: Diagnostics) -> "ParserElement": - """ - Suppress warnings emitted for a particular diagnostic on this expression. - - Example:: - - base = pp.Forward() - base.suppress_warning(Diagnostics.warn_on_parse_using_empty_Forward) - - # statement would normally raise a warning, but is now suppressed - print(base.parse_string("x")) - - """ - self.suppress_warnings_.append(warning_type) - return self - - def visit_all(self): - """General-purpose method to yield all expressions and sub-expressions - in a grammar. Typically just for internal use. - """ - to_visit = deque([self]) - seen = set() - while to_visit: - cur = to_visit.popleft() - - # guard against looping forever through recursive grammars - if cur in seen: - continue - seen.add(cur) - - to_visit.extend(cur.recurse()) - yield cur - - def copy(self) -> "ParserElement": - """ - Make a copy of this :class:`ParserElement`. Useful for defining - different parse actions for the same parsing pattern, using copies of - the original parse element. - - Example:: - - integer = Word(nums).set_parse_action(lambda toks: int(toks[0])) - integerK = integer.copy().add_parse_action(lambda toks: toks[0] * 1024) + Suppress("K") - integerM = integer.copy().add_parse_action(lambda toks: toks[0] * 1024 * 1024) + Suppress("M") - - print((integerK | integerM | integer)[1, ...].parse_string("5K 100 640K 256M")) - - prints:: - - [5120, 100, 655360, 268435456] - - Equivalent form of ``expr.copy()`` is just ``expr()``:: - - integerM = integer().add_parse_action(lambda toks: toks[0] * 1024 * 1024) + Suppress("M") - """ - cpy = copy.copy(self) - cpy.parseAction = self.parseAction[:] - cpy.ignoreExprs = self.ignoreExprs[:] - if self.copyDefaultWhiteChars: - cpy.whiteChars = set(ParserElement.DEFAULT_WHITE_CHARS) - return cpy - - def set_results_name( - self, name: str, list_all_matches: bool = False, *, listAllMatches: bool = False - ) -> "ParserElement": - """ - Define name for referencing matching tokens as a nested attribute - of the returned parse results. - - Normally, results names are assigned as you would assign keys in a dict: - any existing value is overwritten by later values. If it is necessary to - keep all values captured for a particular results name, call ``set_results_name`` - with ``list_all_matches`` = True. - - NOTE: ``set_results_name`` returns a *copy* of the original :class:`ParserElement` object; - this is so that the client can define a basic element, such as an - integer, and reference it in multiple places with different names. - - You can also set results names using the abbreviated syntax, - ``expr("name")`` in place of ``expr.set_results_name("name")`` - - see :class:`__call__`. If ``list_all_matches`` is required, use - ``expr("name*")``. - - Example:: - - date_str = (integer.set_results_name("year") + '/' - + integer.set_results_name("month") + '/' - + integer.set_results_name("day")) - - # equivalent form: - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - """ - listAllMatches = listAllMatches or list_all_matches - return self._setResultsName(name, listAllMatches) - - def _setResultsName(self, name, listAllMatches=False): - if name is None: - return self - newself = self.copy() - if name.endswith("*"): - name = name[:-1] - listAllMatches = True - newself.resultsName = name - newself.modalResults = not listAllMatches - return newself - - def set_break(self, break_flag: bool = True) -> "ParserElement": - """ - Method to invoke the Python pdb debugger when this element is - about to be parsed. Set ``break_flag`` to ``True`` to enable, ``False`` to - disable. - """ - if break_flag: - _parseMethod = self._parse - - def breaker(instring, loc, doActions=True, callPreParse=True): - import pdb - - # this call to pdb.set_trace() is intentional, not a checkin error - pdb.set_trace() - return _parseMethod(instring, loc, doActions, callPreParse) - - breaker._originalParseMethod = _parseMethod # type: ignore [attr-defined] - self._parse = breaker # type: ignore [assignment] - else: - if hasattr(self._parse, "_originalParseMethod"): - self._parse = self._parse._originalParseMethod # type: ignore [attr-defined, assignment] - return self - - def set_parse_action(self, *fns: ParseAction, **kwargs) -> "ParserElement": - """ - Define one or more actions to perform when successfully matching parse element definition. - - Parse actions can be called to perform data conversions, do extra validation, - update external data structures, or enhance or replace the parsed tokens. - Each parse action ``fn`` is a callable method with 0-3 arguments, called as - ``fn(s, loc, toks)`` , ``fn(loc, toks)`` , ``fn(toks)`` , or just ``fn()`` , where: - - - ``s`` = the original string being parsed (see note below) - - ``loc`` = the location of the matching substring - - ``toks`` = a list of the matched tokens, packaged as a :class:`ParseResults` object - - The parsed tokens are passed to the parse action as ParseResults. They can be - modified in place using list-style append, extend, and pop operations to update - the parsed list elements; and with dictionary-style item set and del operations - to add, update, or remove any named results. If the tokens are modified in place, - it is not necessary to return them with a return statement. - - Parse actions can also completely replace the given tokens, with another ``ParseResults`` - object, or with some entirely different object (common for parse actions that perform data - conversions). A convenient way to build a new parse result is to define the values - using a dict, and then create the return value using :class:`ParseResults.from_dict`. - - If None is passed as the ``fn`` parse action, all previously added parse actions for this - expression are cleared. - - Optional keyword arguments: - - - ``call_during_try`` = (default= ``False``) indicate if parse action should be run during - lookaheads and alternate testing. For parse actions that have side effects, it is - important to only call the parse action once it is determined that it is being - called as part of a successful parse. For parse actions that perform additional - validation, then call_during_try should be passed as True, so that the validation - code is included in the preliminary "try" parses. - - Note: the default parsing behavior is to expand tabs in the input string - before starting the parsing process. See :class:`parse_string` for more - information on parsing strings containing ```` s, and suggested - methods to maintain a consistent view of the parsed string, the parse - location, and line and column positions within the parsed string. - - Example:: - - # parse dates in the form YYYY/MM/DD - - # use parse action to convert toks from str to int at parse time - def convert_to_int(toks): - return int(toks[0]) - - # use a parse action to verify that the date is a valid date - def is_valid_date(instring, loc, toks): - from datetime import date - year, month, day = toks[::2] - try: - date(year, month, day) - except ValueError: - raise ParseException(instring, loc, "invalid date given") - - integer = Word(nums) - date_str = integer + '/' + integer + '/' + integer - - # add parse actions - integer.set_parse_action(convert_to_int) - date_str.set_parse_action(is_valid_date) - - # note that integer fields are now ints, not strings - date_str.run_tests(''' - # successful parse - note that integer fields were converted to ints - 1999/12/31 - - # fail - invalid date - 1999/13/31 - ''') - """ - if list(fns) == [None]: - self.parseAction = [] - else: - if not all(callable(fn) for fn in fns): - raise TypeError("parse actions must be callable") - self.parseAction = [_trim_arity(fn) for fn in fns] - self.callDuringTry = kwargs.get( - "call_during_try", kwargs.get("callDuringTry", False) - ) - return self - - def add_parse_action(self, *fns: ParseAction, **kwargs) -> "ParserElement": - """ - Add one or more parse actions to expression's list of parse actions. See :class:`set_parse_action`. - - See examples in :class:`copy`. - """ - self.parseAction += [_trim_arity(fn) for fn in fns] - self.callDuringTry = self.callDuringTry or kwargs.get( - "call_during_try", kwargs.get("callDuringTry", False) - ) - return self - - def add_condition(self, *fns: ParseCondition, **kwargs) -> "ParserElement": - """Add a boolean predicate function to expression's list of parse actions. See - :class:`set_parse_action` for function call signatures. Unlike ``set_parse_action``, - functions passed to ``add_condition`` need to return boolean success/fail of the condition. - - Optional keyword arguments: - - - ``message`` = define a custom message to be used in the raised exception - - ``fatal`` = if True, will raise ParseFatalException to stop parsing immediately; otherwise will raise - ParseException - - ``call_during_try`` = boolean to indicate if this method should be called during internal tryParse calls, - default=False - - Example:: - - integer = Word(nums).set_parse_action(lambda toks: int(toks[0])) - year_int = integer.copy() - year_int.add_condition(lambda toks: toks[0] >= 2000, message="Only support years 2000 and later") - date_str = year_int + '/' + integer + '/' + integer - - result = date_str.parse_string("1999/12/31") # -> Exception: Only support years 2000 and later (at char 0), - (line:1, col:1) - """ - for fn in fns: - self.parseAction.append( - condition_as_parse_action( - fn, - message=str(kwargs.get("message")), - fatal=bool(kwargs.get("fatal", False)), - ) - ) - - self.callDuringTry = self.callDuringTry or kwargs.get( - "call_during_try", kwargs.get("callDuringTry", False) - ) - return self - - def set_fail_action(self, fn: ParseFailAction) -> "ParserElement": - """ - Define action to perform if parsing fails at this expression. - Fail acton fn is a callable function that takes the arguments - ``fn(s, loc, expr, err)`` where: - - - ``s`` = string being parsed - - ``loc`` = location where expression match was attempted and failed - - ``expr`` = the parse expression that failed - - ``err`` = the exception thrown - - The function returns no value. It may throw :class:`ParseFatalException` - if it is desired to stop parsing immediately.""" - self.failAction = fn - return self - - def _skipIgnorables(self, instring: str, loc: int) -> int: - if not self.ignoreExprs: - return loc - exprsFound = True - ignore_expr_fns = [e._parse for e in self.ignoreExprs] - while exprsFound: - exprsFound = False - for ignore_fn in ignore_expr_fns: - try: - while 1: - loc, dummy = ignore_fn(instring, loc) - exprsFound = True - except ParseException: - pass - return loc - - def preParse(self, instring: str, loc: int) -> int: - if self.ignoreExprs: - loc = self._skipIgnorables(instring, loc) - - if self.skipWhitespace: - instrlen = len(instring) - white_chars = self.whiteChars - while loc < instrlen and instring[loc] in white_chars: - loc += 1 - - return loc - - def parseImpl(self, instring, loc, doActions=True): - return loc, [] - - def postParse(self, instring, loc, tokenlist): - return tokenlist - - # @profile - def _parseNoCache( - self, instring, loc, doActions=True, callPreParse=True - ) -> Tuple[int, ParseResults]: - TRY, MATCH, FAIL = 0, 1, 2 - debugging = self.debug # and doActions) - len_instring = len(instring) - - if debugging or self.failAction: - # print("Match {} at loc {}({}, {})".format(self, loc, lineno(loc, instring), col(loc, instring))) - try: - if callPreParse and self.callPreparse: - pre_loc = self.preParse(instring, loc) - else: - pre_loc = loc - tokens_start = pre_loc - if self.debugActions.debug_try: - self.debugActions.debug_try(instring, tokens_start, self, False) - if self.mayIndexError or pre_loc >= len_instring: - try: - loc, tokens = self.parseImpl(instring, pre_loc, doActions) - except IndexError: - raise ParseException(instring, len_instring, self.errmsg, self) - else: - loc, tokens = self.parseImpl(instring, pre_loc, doActions) - except Exception as err: - # print("Exception raised:", err) - if self.debugActions.debug_fail: - self.debugActions.debug_fail( - instring, tokens_start, self, err, False - ) - if self.failAction: - self.failAction(instring, tokens_start, self, err) - raise - else: - if callPreParse and self.callPreparse: - pre_loc = self.preParse(instring, loc) - else: - pre_loc = loc - tokens_start = pre_loc - if self.mayIndexError or pre_loc >= len_instring: - try: - loc, tokens = self.parseImpl(instring, pre_loc, doActions) - except IndexError: - raise ParseException(instring, len_instring, self.errmsg, self) - else: - loc, tokens = self.parseImpl(instring, pre_loc, doActions) - - tokens = self.postParse(instring, loc, tokens) - - ret_tokens = ParseResults( - tokens, self.resultsName, asList=self.saveAsList, modal=self.modalResults - ) - if self.parseAction and (doActions or self.callDuringTry): - if debugging: - try: - for fn in self.parseAction: - try: - tokens = fn(instring, tokens_start, ret_tokens) # type: ignore [call-arg, arg-type] - except IndexError as parse_action_exc: - exc = ParseException("exception raised in parse action") - raise exc from parse_action_exc - - if tokens is not None and tokens is not ret_tokens: - ret_tokens = ParseResults( - tokens, - self.resultsName, - asList=self.saveAsList - and isinstance(tokens, (ParseResults, list)), - modal=self.modalResults, - ) - except Exception as err: - # print "Exception raised in user parse action:", err - if self.debugActions.debug_fail: - self.debugActions.debug_fail( - instring, tokens_start, self, err, False - ) - raise - else: - for fn in self.parseAction: - try: - tokens = fn(instring, tokens_start, ret_tokens) # type: ignore [call-arg, arg-type] - except IndexError as parse_action_exc: - exc = ParseException("exception raised in parse action") - raise exc from parse_action_exc - - if tokens is not None and tokens is not ret_tokens: - ret_tokens = ParseResults( - tokens, - self.resultsName, - asList=self.saveAsList - and isinstance(tokens, (ParseResults, list)), - modal=self.modalResults, - ) - if debugging: - # print("Matched", self, "->", ret_tokens.as_list()) - if self.debugActions.debug_match: - self.debugActions.debug_match( - instring, tokens_start, loc, self, ret_tokens, False - ) - - return loc, ret_tokens - - def try_parse( - self, - instring: str, - loc: int, - *, - raise_fatal: bool = False, - do_actions: bool = False, - ) -> int: - try: - return self._parse(instring, loc, doActions=do_actions)[0] - except ParseFatalException: - if raise_fatal: - raise - raise ParseException(instring, loc, self.errmsg, self) - - def can_parse_next(self, instring: str, loc: int, do_actions: bool = False) -> bool: - try: - self.try_parse(instring, loc, do_actions=do_actions) - except (ParseException, IndexError): - return False - else: - return True - - # cache for left-recursion in Forward references - recursion_lock = RLock() - recursion_memos: typing.Dict[ - Tuple[int, "Forward", bool], Tuple[int, Union[ParseResults, Exception]] - ] = {} - - class _CacheType(dict): - """ - class to help type checking - """ - - not_in_cache: bool - - def get(self, *args): - ... - - def set(self, *args): - ... - - # argument cache for optimizing repeated calls when backtracking through recursive expressions - packrat_cache = ( - _CacheType() - ) # set later by enable_packrat(); this is here so that reset_cache() doesn't fail - packrat_cache_lock = RLock() - packrat_cache_stats = [0, 0] - - # this method gets repeatedly called during backtracking with the same arguments - - # we can cache these arguments and save ourselves the trouble of re-parsing the contained expression - def _parseCache( - self, instring, loc, doActions=True, callPreParse=True - ) -> Tuple[int, ParseResults]: - HIT, MISS = 0, 1 - TRY, MATCH, FAIL = 0, 1, 2 - lookup = (self, instring, loc, callPreParse, doActions) - with ParserElement.packrat_cache_lock: - cache = ParserElement.packrat_cache - value = cache.get(lookup) - if value is cache.not_in_cache: - ParserElement.packrat_cache_stats[MISS] += 1 - try: - value = self._parseNoCache(instring, loc, doActions, callPreParse) - except ParseBaseException as pe: - # cache a copy of the exception, without the traceback - cache.set(lookup, pe.__class__(*pe.args)) - raise - else: - cache.set(lookup, (value[0], value[1].copy(), loc)) - return value - else: - ParserElement.packrat_cache_stats[HIT] += 1 - if self.debug and self.debugActions.debug_try: - try: - self.debugActions.debug_try(instring, loc, self, cache_hit=True) # type: ignore [call-arg] - except TypeError: - pass - if isinstance(value, Exception): - if self.debug and self.debugActions.debug_fail: - try: - self.debugActions.debug_fail( - instring, loc, self, value, cache_hit=True # type: ignore [call-arg] - ) - except TypeError: - pass - raise value - - value = cast(Tuple[int, ParseResults, int], value) - loc_, result, endloc = value[0], value[1].copy(), value[2] - if self.debug and self.debugActions.debug_match: - try: - self.debugActions.debug_match( - instring, loc_, endloc, self, result, cache_hit=True # type: ignore [call-arg] - ) - except TypeError: - pass - - return loc_, result - - _parse = _parseNoCache - - @staticmethod - def reset_cache() -> None: - ParserElement.packrat_cache.clear() - ParserElement.packrat_cache_stats[:] = [0] * len( - ParserElement.packrat_cache_stats - ) - ParserElement.recursion_memos.clear() - - _packratEnabled = False - _left_recursion_enabled = False - - @staticmethod - def disable_memoization() -> None: - """ - Disables active Packrat or Left Recursion parsing and their memoization - - This method also works if neither Packrat nor Left Recursion are enabled. - This makes it safe to call before activating Packrat nor Left Recursion - to clear any previous settings. - """ - ParserElement.reset_cache() - ParserElement._left_recursion_enabled = False - ParserElement._packratEnabled = False - ParserElement._parse = ParserElement._parseNoCache - - @staticmethod - def enable_left_recursion( - cache_size_limit: typing.Optional[int] = None, *, force=False - ) -> None: - """ - Enables "bounded recursion" parsing, which allows for both direct and indirect - left-recursion. During parsing, left-recursive :class:`Forward` elements are - repeatedly matched with a fixed recursion depth that is gradually increased - until finding the longest match. - - Example:: - - from pip._vendor import pyparsing as pp - pp.ParserElement.enable_left_recursion() - - E = pp.Forward("E") - num = pp.Word(pp.nums) - # match `num`, or `num '+' num`, or `num '+' num '+' num`, ... - E <<= E + '+' - num | num - - print(E.parse_string("1+2+3")) - - Recursion search naturally memoizes matches of ``Forward`` elements and may - thus skip reevaluation of parse actions during backtracking. This may break - programs with parse actions which rely on strict ordering of side-effects. - - Parameters: - - - ``cache_size_limit`` - (default=``None``) - memoize at most this many - ``Forward`` elements during matching; if ``None`` (the default), - memoize all ``Forward`` elements. - - Bounded Recursion parsing works similar but not identical to Packrat parsing, - thus the two cannot be used together. Use ``force=True`` to disable any - previous, conflicting settings. - """ - if force: - ParserElement.disable_memoization() - elif ParserElement._packratEnabled: - raise RuntimeError("Packrat and Bounded Recursion are not compatible") - if cache_size_limit is None: - ParserElement.recursion_memos = _UnboundedMemo() # type: ignore[assignment] - elif cache_size_limit > 0: - ParserElement.recursion_memos = _LRUMemo(capacity=cache_size_limit) # type: ignore[assignment] - else: - raise NotImplementedError("Memo size of %s" % cache_size_limit) - ParserElement._left_recursion_enabled = True - - @staticmethod - def enable_packrat(cache_size_limit: int = 128, *, force: bool = False) -> None: - """ - Enables "packrat" parsing, which adds memoizing to the parsing logic. - Repeated parse attempts at the same string location (which happens - often in many complex grammars) can immediately return a cached value, - instead of re-executing parsing/validating code. Memoizing is done of - both valid results and parsing exceptions. - - Parameters: - - - ``cache_size_limit`` - (default= ``128``) - if an integer value is provided - will limit the size of the packrat cache; if None is passed, then - the cache size will be unbounded; if 0 is passed, the cache will - be effectively disabled. - - This speedup may break existing programs that use parse actions that - have side-effects. For this reason, packrat parsing is disabled when - you first import pyparsing. To activate the packrat feature, your - program must call the class method :class:`ParserElement.enable_packrat`. - For best results, call ``enable_packrat()`` immediately after - importing pyparsing. - - Example:: - - from pip._vendor import pyparsing - pyparsing.ParserElement.enable_packrat() - - Packrat parsing works similar but not identical to Bounded Recursion parsing, - thus the two cannot be used together. Use ``force=True`` to disable any - previous, conflicting settings. - """ - if force: - ParserElement.disable_memoization() - elif ParserElement._left_recursion_enabled: - raise RuntimeError("Packrat and Bounded Recursion are not compatible") - if not ParserElement._packratEnabled: - ParserElement._packratEnabled = True - if cache_size_limit is None: - ParserElement.packrat_cache = _UnboundedCache() - else: - ParserElement.packrat_cache = _FifoCache(cache_size_limit) # type: ignore[assignment] - ParserElement._parse = ParserElement._parseCache - - def parse_string( - self, instring: str, parse_all: bool = False, *, parseAll: bool = False - ) -> ParseResults: - """ - Parse a string with respect to the parser definition. This function is intended as the primary interface to the - client code. - - :param instring: The input string to be parsed. - :param parse_all: If set, the entire input string must match the grammar. - :param parseAll: retained for pre-PEP8 compatibility, will be removed in a future release. - :raises ParseException: Raised if ``parse_all`` is set and the input string does not match the whole grammar. - :returns: the parsed data as a :class:`ParseResults` object, which may be accessed as a `list`, a `dict`, or - an object with attributes if the given parser includes results names. - - If the input string is required to match the entire grammar, ``parse_all`` flag must be set to ``True``. This - is also equivalent to ending the grammar with :class:`StringEnd`\\ (). - - To report proper column numbers, ``parse_string`` operates on a copy of the input string where all tabs are - converted to spaces (8 spaces per tab, as per the default in ``string.expandtabs``). If the input string - contains tabs and the grammar uses parse actions that use the ``loc`` argument to index into the string - being parsed, one can ensure a consistent view of the input string by doing one of the following: - - - calling ``parse_with_tabs`` on your grammar before calling ``parse_string`` (see :class:`parse_with_tabs`), - - define your parse action using the full ``(s,loc,toks)`` signature, and reference the input string using the - parse action's ``s`` argument, or - - explicitly expand the tabs in your input string before calling ``parse_string``. - - Examples: - - By default, partial matches are OK. - - >>> res = Word('a').parse_string('aaaaabaaa') - >>> print(res) - ['aaaaa'] - - The parsing behavior varies by the inheriting class of this abstract class. Please refer to the children - directly to see more examples. - - It raises an exception if parse_all flag is set and instring does not match the whole grammar. - - >>> res = Word('a').parse_string('aaaaabaaa', parse_all=True) - Traceback (most recent call last): - ... - pyparsing.ParseException: Expected end of text, found 'b' (at char 5), (line:1, col:6) - """ - parseAll = parse_all or parseAll - - ParserElement.reset_cache() - if not self.streamlined: - self.streamline() - for e in self.ignoreExprs: - e.streamline() - if not self.keepTabs: - instring = instring.expandtabs() - try: - loc, tokens = self._parse(instring, 0) - if parseAll: - loc = self.preParse(instring, loc) - se = Empty() + StringEnd() - se._parse(instring, loc) - except ParseBaseException as exc: - if ParserElement.verbose_stacktrace: - raise - else: - # catch and re-raise exception from here, clearing out pyparsing internal stack trace - raise exc.with_traceback(None) - else: - return tokens - - def scan_string( - self, - instring: str, - max_matches: int = _MAX_INT, - overlap: bool = False, - *, - debug: bool = False, - maxMatches: int = _MAX_INT, - ) -> Generator[Tuple[ParseResults, int, int], None, None]: - """ - Scan the input string for expression matches. Each match will return the - matching tokens, start location, and end location. May be called with optional - ``max_matches`` argument, to clip scanning after 'n' matches are found. If - ``overlap`` is specified, then overlapping matches will be reported. - - Note that the start and end locations are reported relative to the string - being parsed. See :class:`parse_string` for more information on parsing - strings with embedded tabs. - - Example:: - - source = "sldjf123lsdjjkf345sldkjf879lkjsfd987" - print(source) - for tokens, start, end in Word(alphas).scan_string(source): - print(' '*start + '^'*(end-start)) - print(' '*start + tokens[0]) - - prints:: - - sldjf123lsdjjkf345sldkjf879lkjsfd987 - ^^^^^ - sldjf - ^^^^^^^ - lsdjjkf - ^^^^^^ - sldkjf - ^^^^^^ - lkjsfd - """ - maxMatches = min(maxMatches, max_matches) - if not self.streamlined: - self.streamline() - for e in self.ignoreExprs: - e.streamline() - - if not self.keepTabs: - instring = str(instring).expandtabs() - instrlen = len(instring) - loc = 0 - preparseFn = self.preParse - parseFn = self._parse - ParserElement.resetCache() - matches = 0 - try: - while loc <= instrlen and matches < maxMatches: - try: - preloc: int = preparseFn(instring, loc) - nextLoc: int - tokens: ParseResults - nextLoc, tokens = parseFn(instring, preloc, callPreParse=False) - except ParseException: - loc = preloc + 1 - else: - if nextLoc > loc: - matches += 1 - if debug: - print( - { - "tokens": tokens.asList(), - "start": preloc, - "end": nextLoc, - } - ) - yield tokens, preloc, nextLoc - if overlap: - nextloc = preparseFn(instring, loc) - if nextloc > loc: - loc = nextLoc - else: - loc += 1 - else: - loc = nextLoc - else: - loc = preloc + 1 - except ParseBaseException as exc: - if ParserElement.verbose_stacktrace: - raise - else: - # catch and re-raise exception from here, clears out pyparsing internal stack trace - raise exc.with_traceback(None) - - def transform_string(self, instring: str, *, debug: bool = False) -> str: - """ - Extension to :class:`scan_string`, to modify matching text with modified tokens that may - be returned from a parse action. To use ``transform_string``, define a grammar and - attach a parse action to it that modifies the returned token list. - Invoking ``transform_string()`` on a target string will then scan for matches, - and replace the matched text patterns according to the logic in the parse - action. ``transform_string()`` returns the resulting transformed string. - - Example:: - - wd = Word(alphas) - wd.set_parse_action(lambda toks: toks[0].title()) - - print(wd.transform_string("now is the winter of our discontent made glorious summer by this sun of york.")) - - prints:: - - Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York. - """ - out: List[str] = [] - lastE = 0 - # force preservation of s, to minimize unwanted transformation of string, and to - # keep string locs straight between transform_string and scan_string - self.keepTabs = True - try: - for t, s, e in self.scan_string(instring, debug=debug): - out.append(instring[lastE:s]) - if t: - if isinstance(t, ParseResults): - out += t.as_list() - elif isinstance(t, Iterable) and not isinstance(t, str_type): - out.extend(t) - else: - out.append(t) - lastE = e - out.append(instring[lastE:]) - out = [o for o in out if o] - return "".join([str(s) for s in _flatten(out)]) - except ParseBaseException as exc: - if ParserElement.verbose_stacktrace: - raise - else: - # catch and re-raise exception from here, clears out pyparsing internal stack trace - raise exc.with_traceback(None) - - def search_string( - self, - instring: str, - max_matches: int = _MAX_INT, - *, - debug: bool = False, - maxMatches: int = _MAX_INT, - ) -> ParseResults: - """ - Another extension to :class:`scan_string`, simplifying the access to the tokens found - to match the given parse expression. May be called with optional - ``max_matches`` argument, to clip searching after 'n' matches are found. - - Example:: - - # a capitalized word starts with an uppercase letter, followed by zero or more lowercase letters - cap_word = Word(alphas.upper(), alphas.lower()) - - print(cap_word.search_string("More than Iron, more than Lead, more than Gold I need Electricity")) - - # the sum() builtin can be used to merge results into a single ParseResults object - print(sum(cap_word.search_string("More than Iron, more than Lead, more than Gold I need Electricity"))) - - prints:: - - [['More'], ['Iron'], ['Lead'], ['Gold'], ['I'], ['Electricity']] - ['More', 'Iron', 'Lead', 'Gold', 'I', 'Electricity'] - """ - maxMatches = min(maxMatches, max_matches) - try: - return ParseResults( - [t for t, s, e in self.scan_string(instring, maxMatches, debug=debug)] - ) - except ParseBaseException as exc: - if ParserElement.verbose_stacktrace: - raise - else: - # catch and re-raise exception from here, clears out pyparsing internal stack trace - raise exc.with_traceback(None) - - def split( - self, - instring: str, - maxsplit: int = _MAX_INT, - include_separators: bool = False, - *, - includeSeparators=False, - ) -> Generator[str, None, None]: - """ - Generator method to split a string using the given expression as a separator. - May be called with optional ``maxsplit`` argument, to limit the number of splits; - and the optional ``include_separators`` argument (default= ``False``), if the separating - matching text should be included in the split results. - - Example:: - - punc = one_of(list(".,;:/-!?")) - print(list(punc.split("This, this?, this sentence, is badly punctuated!"))) - - prints:: - - ['This', ' this', '', ' this sentence', ' is badly punctuated', ''] - """ - includeSeparators = includeSeparators or include_separators - last = 0 - for t, s, e in self.scan_string(instring, max_matches=maxsplit): - yield instring[last:s] - if includeSeparators: - yield t[0] - last = e - yield instring[last:] - - def __add__(self, other) -> "ParserElement": - """ - Implementation of ``+`` operator - returns :class:`And`. Adding strings to a :class:`ParserElement` - converts them to :class:`Literal`\\ s by default. - - Example:: - - greet = Word(alphas) + "," + Word(alphas) + "!" - hello = "Hello, World!" - print(hello, "->", greet.parse_string(hello)) - - prints:: - - Hello, World! -> ['Hello', ',', 'World', '!'] - - ``...`` may be used as a parse expression as a short form of :class:`SkipTo`:: - - Literal('start') + ... + Literal('end') - - is equivalent to:: - - Literal('start') + SkipTo('end')("_skipped*") + Literal('end') - - Note that the skipped text is returned with '_skipped' as a results name, - and to support having multiple skips in the same parser, the value returned is - a list of all skipped text. - """ - if other is Ellipsis: - return _PendingSkip(self) - - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return And([self, other]) - - def __radd__(self, other) -> "ParserElement": - """ - Implementation of ``+`` operator when left operand is not a :class:`ParserElement` - """ - if other is Ellipsis: - return SkipTo(self)("_skipped*") + self - - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return other + self - - def __sub__(self, other) -> "ParserElement": - """ - Implementation of ``-`` operator, returns :class:`And` with error stop - """ - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return self + And._ErrorStop() + other - - def __rsub__(self, other) -> "ParserElement": - """ - Implementation of ``-`` operator when left operand is not a :class:`ParserElement` - """ - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return other - self - - def __mul__(self, other) -> "ParserElement": - """ - Implementation of ``*`` operator, allows use of ``expr * 3`` in place of - ``expr + expr + expr``. Expressions may also be multiplied by a 2-integer - tuple, similar to ``{min, max}`` multipliers in regular expressions. Tuples - may also include ``None`` as in: - - - ``expr*(n, None)`` or ``expr*(n, )`` is equivalent - to ``expr*n + ZeroOrMore(expr)`` - (read as "at least n instances of ``expr``") - - ``expr*(None, n)`` is equivalent to ``expr*(0, n)`` - (read as "0 to n instances of ``expr``") - - ``expr*(None, None)`` is equivalent to ``ZeroOrMore(expr)`` - - ``expr*(1, None)`` is equivalent to ``OneOrMore(expr)`` - - Note that ``expr*(None, n)`` does not raise an exception if - more than n exprs exist in the input stream; that is, - ``expr*(None, n)`` does not enforce a maximum number of expr - occurrences. If this behavior is desired, then write - ``expr*(None, n) + ~expr`` - """ - if other is Ellipsis: - other = (0, None) - elif isinstance(other, tuple) and other[:1] == (Ellipsis,): - other = ((0,) + other[1:] + (None,))[:2] - - if isinstance(other, int): - minElements, optElements = other, 0 - elif isinstance(other, tuple): - other = tuple(o if o is not Ellipsis else None for o in other) - other = (other + (None, None))[:2] - if other[0] is None: - other = (0, other[1]) - if isinstance(other[0], int) and other[1] is None: - if other[0] == 0: - return ZeroOrMore(self) - if other[0] == 1: - return OneOrMore(self) - else: - return self * other[0] + ZeroOrMore(self) - elif isinstance(other[0], int) and isinstance(other[1], int): - minElements, optElements = other - optElements -= minElements - else: - return NotImplemented - else: - return NotImplemented - - if minElements < 0: - raise ValueError("cannot multiply ParserElement by negative value") - if optElements < 0: - raise ValueError( - "second tuple value must be greater or equal to first tuple value" - ) - if minElements == optElements == 0: - return And([]) - - if optElements: - - def makeOptionalList(n): - if n > 1: - return Opt(self + makeOptionalList(n - 1)) - else: - return Opt(self) - - if minElements: - if minElements == 1: - ret = self + makeOptionalList(optElements) - else: - ret = And([self] * minElements) + makeOptionalList(optElements) - else: - ret = makeOptionalList(optElements) - else: - if minElements == 1: - ret = self - else: - ret = And([self] * minElements) - return ret - - def __rmul__(self, other) -> "ParserElement": - return self.__mul__(other) - - def __or__(self, other) -> "ParserElement": - """ - Implementation of ``|`` operator - returns :class:`MatchFirst` - """ - if other is Ellipsis: - return _PendingSkip(self, must_skip=True) - - if isinstance(other, str_type): - # `expr | ""` is equivalent to `Opt(expr)` - if other == "": - return Opt(self) - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return MatchFirst([self, other]) - - def __ror__(self, other) -> "ParserElement": - """ - Implementation of ``|`` operator when left operand is not a :class:`ParserElement` - """ - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return other | self - - def __xor__(self, other) -> "ParserElement": - """ - Implementation of ``^`` operator - returns :class:`Or` - """ - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return Or([self, other]) - - def __rxor__(self, other) -> "ParserElement": - """ - Implementation of ``^`` operator when left operand is not a :class:`ParserElement` - """ - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return other ^ self - - def __and__(self, other) -> "ParserElement": - """ - Implementation of ``&`` operator - returns :class:`Each` - """ - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return Each([self, other]) - - def __rand__(self, other) -> "ParserElement": - """ - Implementation of ``&`` operator when left operand is not a :class:`ParserElement` - """ - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return other & self - - def __invert__(self) -> "ParserElement": - """ - Implementation of ``~`` operator - returns :class:`NotAny` - """ - return NotAny(self) - - # disable __iter__ to override legacy use of sequential access to __getitem__ to - # iterate over a sequence - __iter__ = None - - def __getitem__(self, key): - """ - use ``[]`` indexing notation as a short form for expression repetition: - - - ``expr[n]`` is equivalent to ``expr*n`` - - ``expr[m, n]`` is equivalent to ``expr*(m, n)`` - - ``expr[n, ...]`` or ``expr[n,]`` is equivalent - to ``expr*n + ZeroOrMore(expr)`` - (read as "at least n instances of ``expr``") - - ``expr[..., n]`` is equivalent to ``expr*(0, n)`` - (read as "0 to n instances of ``expr``") - - ``expr[...]`` and ``expr[0, ...]`` are equivalent to ``ZeroOrMore(expr)`` - - ``expr[1, ...]`` is equivalent to ``OneOrMore(expr)`` - - ``None`` may be used in place of ``...``. - - Note that ``expr[..., n]`` and ``expr[m, n]`` do not raise an exception - if more than ``n`` ``expr``\\ s exist in the input stream. If this behavior is - desired, then write ``expr[..., n] + ~expr``. - - For repetition with a stop_on expression, use slice notation: - - - ``expr[...: end_expr]`` and ``expr[0, ...: end_expr]`` are equivalent to ``ZeroOrMore(expr, stop_on=end_expr)`` - - ``expr[1, ...: end_expr]`` is equivalent to ``OneOrMore(expr, stop_on=end_expr)`` - - """ - - stop_on_defined = False - stop_on = NoMatch() - if isinstance(key, slice): - key, stop_on = key.start, key.stop - if key is None: - key = ... - stop_on_defined = True - elif isinstance(key, tuple) and isinstance(key[-1], slice): - key, stop_on = (key[0], key[1].start), key[1].stop - stop_on_defined = True - - # convert single arg keys to tuples - if isinstance(key, str_type): - key = (key,) - try: - iter(key) - except TypeError: - key = (key, key) - - if len(key) > 2: - raise TypeError( - f"only 1 or 2 index arguments supported ({key[:5]}{f'... [{len(key)}]' if len(key) > 5 else ''})" - ) - - # clip to 2 elements - ret = self * tuple(key[:2]) - ret = typing.cast(_MultipleMatch, ret) - - if stop_on_defined: - ret.stopOn(stop_on) - - return ret - - def __call__(self, name: typing.Optional[str] = None) -> "ParserElement": - """ - Shortcut for :class:`set_results_name`, with ``list_all_matches=False``. - - If ``name`` is given with a trailing ``'*'`` character, then ``list_all_matches`` will be - passed as ``True``. - - If ``name`` is omitted, same as calling :class:`copy`. - - Example:: - - # these are equivalent - userdata = Word(alphas).set_results_name("name") + Word(nums + "-").set_results_name("socsecno") - userdata = Word(alphas)("name") + Word(nums + "-")("socsecno") - """ - if name is not None: - return self._setResultsName(name) - else: - return self.copy() - - def suppress(self) -> "ParserElement": - """ - Suppresses the output of this :class:`ParserElement`; useful to keep punctuation from - cluttering up returned output. - """ - return Suppress(self) - - def ignore_whitespace(self, recursive: bool = True) -> "ParserElement": - """ - Enables the skipping of whitespace before matching the characters in the - :class:`ParserElement`'s defined pattern. - - :param recursive: If ``True`` (the default), also enable whitespace skipping in child elements (if any) - """ - self.skipWhitespace = True - return self - - def leave_whitespace(self, recursive: bool = True) -> "ParserElement": - """ - Disables the skipping of whitespace before matching the characters in the - :class:`ParserElement`'s defined pattern. This is normally only used internally by - the pyparsing module, but may be needed in some whitespace-sensitive grammars. - - :param recursive: If true (the default), also disable whitespace skipping in child elements (if any) - """ - self.skipWhitespace = False - return self - - def set_whitespace_chars( - self, chars: Union[Set[str], str], copy_defaults: bool = False - ) -> "ParserElement": - """ - Overrides the default whitespace chars - """ - self.skipWhitespace = True - self.whiteChars = set(chars) - self.copyDefaultWhiteChars = copy_defaults - return self - - def parse_with_tabs(self) -> "ParserElement": - """ - Overrides default behavior to expand ```` s to spaces before parsing the input string. - Must be called before ``parse_string`` when the input grammar contains elements that - match ```` characters. - """ - self.keepTabs = True - return self - - def ignore(self, other: "ParserElement") -> "ParserElement": - """ - Define expression to be ignored (e.g., comments) while doing pattern - matching; may be called repeatedly, to define multiple comment or other - ignorable patterns. - - Example:: - - patt = Word(alphas)[1, ...] - patt.parse_string('ablaj /* comment */ lskjd') - # -> ['ablaj'] - - patt.ignore(c_style_comment) - patt.parse_string('ablaj /* comment */ lskjd') - # -> ['ablaj', 'lskjd'] - """ - import typing - - if isinstance(other, str_type): - other = Suppress(other) - - if isinstance(other, Suppress): - if other not in self.ignoreExprs: - self.ignoreExprs.append(other) - else: - self.ignoreExprs.append(Suppress(other.copy())) - return self - - def set_debug_actions( - self, - start_action: DebugStartAction, - success_action: DebugSuccessAction, - exception_action: DebugExceptionAction, - ) -> "ParserElement": - """ - Customize display of debugging messages while doing pattern matching: - - - ``start_action`` - method to be called when an expression is about to be parsed; - should have the signature ``fn(input_string: str, location: int, expression: ParserElement, cache_hit: bool)`` - - - ``success_action`` - method to be called when an expression has successfully parsed; - should have the signature ``fn(input_string: str, start_location: int, end_location: int, expression: ParserELement, parsed_tokens: ParseResults, cache_hit: bool)`` - - - ``exception_action`` - method to be called when expression fails to parse; - should have the signature ``fn(input_string: str, location: int, expression: ParserElement, exception: Exception, cache_hit: bool)`` - """ - self.debugActions = self.DebugActions( - start_action or _default_start_debug_action, # type: ignore[truthy-function] - success_action or _default_success_debug_action, # type: ignore[truthy-function] - exception_action or _default_exception_debug_action, # type: ignore[truthy-function] - ) - self.debug = True - return self - - def set_debug(self, flag: bool = True, recurse: bool = False) -> "ParserElement": - """ - Enable display of debugging messages while doing pattern matching. - Set ``flag`` to ``True`` to enable, ``False`` to disable. - Set ``recurse`` to ``True`` to set the debug flag on this expression and all sub-expressions. - - Example:: - - wd = Word(alphas).set_name("alphaword") - integer = Word(nums).set_name("numword") - term = wd | integer - - # turn on debugging for wd - wd.set_debug() - - term[1, ...].parse_string("abc 123 xyz 890") - - prints:: - - Match alphaword at loc 0(1,1) - Matched alphaword -> ['abc'] - Match alphaword at loc 3(1,4) - Exception raised:Expected alphaword (at char 4), (line:1, col:5) - Match alphaword at loc 7(1,8) - Matched alphaword -> ['xyz'] - Match alphaword at loc 11(1,12) - Exception raised:Expected alphaword (at char 12), (line:1, col:13) - Match alphaword at loc 15(1,16) - Exception raised:Expected alphaword (at char 15), (line:1, col:16) - - The output shown is that produced by the default debug actions - custom debug actions can be - specified using :class:`set_debug_actions`. Prior to attempting - to match the ``wd`` expression, the debugging message ``"Match at loc (,)"`` - is shown. Then if the parse succeeds, a ``"Matched"`` message is shown, or an ``"Exception raised"`` - message is shown. Also note the use of :class:`set_name` to assign a human-readable name to the expression, - which makes debugging and exception messages easier to understand - for instance, the default - name created for the :class:`Word` expression without calling ``set_name`` is ``"W:(A-Za-z)"``. - """ - if recurse: - for expr in self.visit_all(): - expr.set_debug(flag, recurse=False) - return self - - if flag: - self.set_debug_actions( - _default_start_debug_action, - _default_success_debug_action, - _default_exception_debug_action, - ) - else: - self.debug = False - return self - - @property - def default_name(self) -> str: - if self._defaultName is None: - self._defaultName = self._generateDefaultName() - return self._defaultName - - @abstractmethod - def _generateDefaultName(self) -> str: - """ - Child classes must define this method, which defines how the ``default_name`` is set. - """ - - def set_name(self, name: str) -> "ParserElement": - """ - Define name for this expression, makes debugging and exception messages clearer. - - Example:: - - Word(nums).parse_string("ABC") # -> Exception: Expected W:(0-9) (at char 0), (line:1, col:1) - Word(nums).set_name("integer").parse_string("ABC") # -> Exception: Expected integer (at char 0), (line:1, col:1) - """ - self.customName = name - self.errmsg = "Expected " + self.name - if __diag__.enable_debug_on_named_expressions: - self.set_debug() - return self - - @property - def name(self) -> str: - # This will use a user-defined name if available, but otherwise defaults back to the auto-generated name - return self.customName if self.customName is not None else self.default_name - - def __str__(self) -> str: - return self.name - - def __repr__(self) -> str: - return str(self) - - def streamline(self) -> "ParserElement": - self.streamlined = True - self._defaultName = None - return self - - def recurse(self) -> List["ParserElement"]: - return [] - - def _checkRecursion(self, parseElementList): - subRecCheckList = parseElementList[:] + [self] - for e in self.recurse(): - e._checkRecursion(subRecCheckList) - - def validate(self, validateTrace=None) -> None: - """ - Check defined expressions for valid structure, check for infinite recursive definitions. - """ - warnings.warn( - "ParserElement.validate() is deprecated, and should not be used to check for left recursion", - DeprecationWarning, - stacklevel=2, - ) - self._checkRecursion([]) - - def parse_file( - self, - file_or_filename: Union[str, Path, TextIO], - encoding: str = "utf-8", - parse_all: bool = False, - *, - parseAll: bool = False, - ) -> ParseResults: - """ - Execute the parse expression on the given file or filename. - If a filename is specified (instead of a file object), - the entire file is opened, read, and closed before parsing. - """ - parseAll = parseAll or parse_all - try: - file_or_filename = typing.cast(TextIO, file_or_filename) - file_contents = file_or_filename.read() - except AttributeError: - file_or_filename = typing.cast(str, file_or_filename) - with open(file_or_filename, "r", encoding=encoding) as f: - file_contents = f.read() - try: - return self.parse_string(file_contents, parseAll) - except ParseBaseException as exc: - if ParserElement.verbose_stacktrace: - raise - else: - # catch and re-raise exception from here, clears out pyparsing internal stack trace - raise exc.with_traceback(None) - - def __eq__(self, other): - if self is other: - return True - elif isinstance(other, str_type): - return self.matches(other, parse_all=True) - elif isinstance(other, ParserElement): - return vars(self) == vars(other) - return False - - def __hash__(self): - return id(self) - - def matches( - self, test_string: str, parse_all: bool = True, *, parseAll: bool = True - ) -> bool: - """ - Method for quick testing of a parser against a test string. Good for simple - inline microtests of sub expressions while building up larger parser. - - Parameters: - - - ``test_string`` - to test against this expression for a match - - ``parse_all`` - (default= ``True``) - flag to pass to :class:`parse_string` when running tests - - Example:: - - expr = Word(nums) - assert expr.matches("100") - """ - parseAll = parseAll and parse_all - try: - self.parse_string(str(test_string), parse_all=parseAll) - return True - except ParseBaseException: - return False - - def run_tests( - self, - tests: Union[str, List[str]], - parse_all: bool = True, - comment: typing.Optional[Union["ParserElement", str]] = "#", - full_dump: bool = True, - print_results: bool = True, - failure_tests: bool = False, - post_parse: typing.Optional[Callable[[str, ParseResults], str]] = None, - file: typing.Optional[TextIO] = None, - with_line_numbers: bool = False, - *, - parseAll: bool = True, - fullDump: bool = True, - printResults: bool = True, - failureTests: bool = False, - postParse: typing.Optional[Callable[[str, ParseResults], str]] = None, - ) -> Tuple[bool, List[Tuple[str, Union[ParseResults, Exception]]]]: - """ - Execute the parse expression on a series of test strings, showing each - test, the parsed results or where the parse failed. Quick and easy way to - run a parse expression against a list of sample strings. - - Parameters: - - - ``tests`` - a list of separate test strings, or a multiline string of test strings - - ``parse_all`` - (default= ``True``) - flag to pass to :class:`parse_string` when running tests - - ``comment`` - (default= ``'#'``) - expression for indicating embedded comments in the test - string; pass None to disable comment filtering - - ``full_dump`` - (default= ``True``) - dump results as list followed by results names in nested outline; - if False, only dump nested list - - ``print_results`` - (default= ``True``) prints test output to stdout - - ``failure_tests`` - (default= ``False``) indicates if these tests are expected to fail parsing - - ``post_parse`` - (default= ``None``) optional callback for successful parse results; called as - `fn(test_string, parse_results)` and returns a string to be added to the test output - - ``file`` - (default= ``None``) optional file-like object to which test output will be written; - if None, will default to ``sys.stdout`` - - ``with_line_numbers`` - default= ``False``) show test strings with line and column numbers - - Returns: a (success, results) tuple, where success indicates that all tests succeeded - (or failed if ``failure_tests`` is True), and the results contain a list of lines of each - test's output - - Example:: - - number_expr = pyparsing_common.number.copy() - - result = number_expr.run_tests(''' - # unsigned integer - 100 - # negative integer - -100 - # float with scientific notation - 6.02e23 - # integer with scientific notation - 1e-12 - ''') - print("Success" if result[0] else "Failed!") - - result = number_expr.run_tests(''' - # stray character - 100Z - # missing leading digit before '.' - -.100 - # too many '.' - 3.14.159 - ''', failure_tests=True) - print("Success" if result[0] else "Failed!") - - prints:: - - # unsigned integer - 100 - [100] - - # negative integer - -100 - [-100] - - # float with scientific notation - 6.02e23 - [6.02e+23] - - # integer with scientific notation - 1e-12 - [1e-12] - - Success - - # stray character - 100Z - ^ - FAIL: Expected end of text (at char 3), (line:1, col:4) - - # missing leading digit before '.' - -.100 - ^ - FAIL: Expected {real number with scientific notation | real number | signed integer} (at char 0), (line:1, col:1) - - # too many '.' - 3.14.159 - ^ - FAIL: Expected end of text (at char 4), (line:1, col:5) - - Success - - Each test string must be on a single line. If you want to test a string that spans multiple - lines, create a test like this:: - - expr.run_tests(r"this is a test\\n of strings that spans \\n 3 lines") - - (Note that this is a raw string literal, you must include the leading ``'r'``.) - """ - from .testing import pyparsing_test - - parseAll = parseAll and parse_all - fullDump = fullDump and full_dump - printResults = printResults and print_results - failureTests = failureTests or failure_tests - postParse = postParse or post_parse - if isinstance(tests, str_type): - tests = typing.cast(str, tests) - line_strip = type(tests).strip - tests = [line_strip(test_line) for test_line in tests.rstrip().splitlines()] - comment_specified = comment is not None - if comment_specified: - if isinstance(comment, str_type): - comment = typing.cast(str, comment) - comment = Literal(comment) - comment = typing.cast(ParserElement, comment) - if file is None: - file = sys.stdout - print_ = file.write - - result: Union[ParseResults, Exception] - allResults: List[Tuple[str, Union[ParseResults, Exception]]] = [] - comments: List[str] = [] - success = True - NL = Literal(r"\n").add_parse_action(replace_with("\n")).ignore(quoted_string) - BOM = "\ufeff" - for t in tests: - if comment_specified and comment.matches(t, False) or comments and not t: - comments.append( - pyparsing_test.with_line_numbers(t) if with_line_numbers else t - ) - continue - if not t: - continue - out = [ - "\n" + "\n".join(comments) if comments else "", - pyparsing_test.with_line_numbers(t) if with_line_numbers else t, - ] - comments = [] - try: - # convert newline marks to actual newlines, and strip leading BOM if present - t = NL.transform_string(t.lstrip(BOM)) - result = self.parse_string(t, parse_all=parseAll) - except ParseBaseException as pe: - fatal = "(FATAL)" if isinstance(pe, ParseFatalException) else "" - out.append(pe.explain()) - out.append("FAIL: " + str(pe)) - if ParserElement.verbose_stacktrace: - out.extend(traceback.format_tb(pe.__traceback__)) - success = success and failureTests - result = pe - except Exception as exc: - out.append(f"FAIL-EXCEPTION: {type(exc).__name__}: {exc}") - if ParserElement.verbose_stacktrace: - out.extend(traceback.format_tb(exc.__traceback__)) - success = success and failureTests - result = exc - else: - success = success and not failureTests - if postParse is not None: - try: - pp_value = postParse(t, result) - if pp_value is not None: - if isinstance(pp_value, ParseResults): - out.append(pp_value.dump()) - else: - out.append(str(pp_value)) - else: - out.append(result.dump()) - except Exception as e: - out.append(result.dump(full=fullDump)) - out.append( - f"{postParse.__name__} failed: {type(e).__name__}: {e}" - ) - else: - out.append(result.dump(full=fullDump)) - out.append("") - - if printResults: - print_("\n".join(out)) - - allResults.append((t, result)) - - return success, allResults - - def create_diagram( - self, - output_html: Union[TextIO, Path, str], - vertical: int = 3, - show_results_names: bool = False, - show_groups: bool = False, - embed: bool = False, - **kwargs, - ) -> None: - """ - Create a railroad diagram for the parser. - - Parameters: - - - ``output_html`` (str or file-like object) - output target for generated - diagram HTML - - ``vertical`` (int) - threshold for formatting multiple alternatives vertically - instead of horizontally (default=3) - - ``show_results_names`` - bool flag whether diagram should show annotations for - defined results names - - ``show_groups`` - bool flag whether groups should be highlighted with an unlabeled surrounding box - - ``embed`` - bool flag whether generated HTML should omit , , and tags to embed - the resulting HTML in an enclosing HTML source - - ``head`` - str containing additional HTML to insert into the section of the generated code; - can be used to insert custom CSS styling - - ``body`` - str containing additional HTML to insert at the beginning of the section of the - generated code - - Additional diagram-formatting keyword arguments can also be included; - see railroad.Diagram class. - """ - - try: - from .diagram import to_railroad, railroad_to_html - except ImportError as ie: - raise Exception( - "must ``pip install pyparsing[diagrams]`` to generate parser railroad diagrams" - ) from ie - - self.streamline() - - railroad = to_railroad( - self, - vertical=vertical, - show_results_names=show_results_names, - show_groups=show_groups, - diagram_kwargs=kwargs, - ) - if isinstance(output_html, (str, Path)): - with open(output_html, "w", encoding="utf-8") as diag_file: - diag_file.write(railroad_to_html(railroad, embed=embed, **kwargs)) - else: - # we were passed a file-like object, just write to it - output_html.write(railroad_to_html(railroad, embed=embed, **kwargs)) - - # Compatibility synonyms - # fmt: off - @staticmethod - @replaced_by_pep8(inline_literals_using) - def inlineLiteralsUsing(): ... - - @staticmethod - @replaced_by_pep8(set_default_whitespace_chars) - def setDefaultWhitespaceChars(): ... - - @replaced_by_pep8(set_results_name) - def setResultsName(self): ... - - @replaced_by_pep8(set_break) - def setBreak(self): ... - - @replaced_by_pep8(set_parse_action) - def setParseAction(self): ... - - @replaced_by_pep8(add_parse_action) - def addParseAction(self): ... - - @replaced_by_pep8(add_condition) - def addCondition(self): ... - - @replaced_by_pep8(set_fail_action) - def setFailAction(self): ... - - @replaced_by_pep8(try_parse) - def tryParse(self): ... - - @staticmethod - @replaced_by_pep8(enable_left_recursion) - def enableLeftRecursion(): ... - - @staticmethod - @replaced_by_pep8(enable_packrat) - def enablePackrat(): ... - - @replaced_by_pep8(parse_string) - def parseString(self): ... - - @replaced_by_pep8(scan_string) - def scanString(self): ... - - @replaced_by_pep8(transform_string) - def transformString(self): ... - - @replaced_by_pep8(search_string) - def searchString(self): ... - - @replaced_by_pep8(ignore_whitespace) - def ignoreWhitespace(self): ... - - @replaced_by_pep8(leave_whitespace) - def leaveWhitespace(self): ... - - @replaced_by_pep8(set_whitespace_chars) - def setWhitespaceChars(self): ... - - @replaced_by_pep8(parse_with_tabs) - def parseWithTabs(self): ... - - @replaced_by_pep8(set_debug_actions) - def setDebugActions(self): ... - - @replaced_by_pep8(set_debug) - def setDebug(self): ... - - @replaced_by_pep8(set_name) - def setName(self): ... - - @replaced_by_pep8(parse_file) - def parseFile(self): ... - - @replaced_by_pep8(run_tests) - def runTests(self): ... - - canParseNext = can_parse_next - resetCache = reset_cache - defaultName = default_name - # fmt: on - - -class _PendingSkip(ParserElement): - # internal placeholder class to hold a place were '...' is added to a parser element, - # once another ParserElement is added, this placeholder will be replaced with a SkipTo - def __init__(self, expr: ParserElement, must_skip: bool = False): - super().__init__() - self.anchor = expr - self.must_skip = must_skip - - def _generateDefaultName(self) -> str: - return str(self.anchor + Empty()).replace("Empty", "...") - - def __add__(self, other) -> "ParserElement": - skipper = SkipTo(other).set_name("...")("_skipped*") - if self.must_skip: - - def must_skip(t): - if not t._skipped or t._skipped.as_list() == [""]: - del t[0] - t.pop("_skipped", None) - - def show_skip(t): - if t._skipped.as_list()[-1:] == [""]: - t.pop("_skipped") - t["_skipped"] = "missing <" + repr(self.anchor) + ">" - - return ( - self.anchor + skipper().add_parse_action(must_skip) - | skipper().add_parse_action(show_skip) - ) + other - - return self.anchor + skipper + other - - def __repr__(self): - return self.defaultName - - def parseImpl(self, *args): - raise Exception( - "use of `...` expression without following SkipTo target expression" - ) - - -class Token(ParserElement): - """Abstract :class:`ParserElement` subclass, for defining atomic - matching patterns. - """ - - def __init__(self): - super().__init__(savelist=False) - - def _generateDefaultName(self) -> str: - return type(self).__name__ - - -class NoMatch(Token): - """ - A token that will never match. - """ - - def __init__(self): - super().__init__() - self.mayReturnEmpty = True - self.mayIndexError = False - self.errmsg = "Unmatchable token" - - def parseImpl(self, instring, loc, doActions=True): - raise ParseException(instring, loc, self.errmsg, self) - - -class Literal(Token): - """ - Token to exactly match a specified string. - - Example:: - - Literal('blah').parse_string('blah') # -> ['blah'] - Literal('blah').parse_string('blahfooblah') # -> ['blah'] - Literal('blah').parse_string('bla') # -> Exception: Expected "blah" - - For case-insensitive matching, use :class:`CaselessLiteral`. - - For keyword matching (force word break before and after the matched string), - use :class:`Keyword` or :class:`CaselessKeyword`. - """ - - def __new__(cls, match_string: str = "", *, matchString: str = ""): - # Performance tuning: select a subclass with optimized parseImpl - if cls is Literal: - match_string = matchString or match_string - if not match_string: - return super().__new__(Empty) - if len(match_string) == 1: - return super().__new__(_SingleCharLiteral) - - # Default behavior - return super().__new__(cls) - - # Needed to make copy.copy() work correctly if we customize __new__ - def __getnewargs__(self): - return (self.match,) - - def __init__(self, match_string: str = "", *, matchString: str = ""): - super().__init__() - match_string = matchString or match_string - self.match = match_string - self.matchLen = len(match_string) - self.firstMatchChar = match_string[:1] - self.errmsg = "Expected " + self.name - self.mayReturnEmpty = False - self.mayIndexError = False - - def _generateDefaultName(self) -> str: - return repr(self.match) - - def parseImpl(self, instring, loc, doActions=True): - if instring[loc] == self.firstMatchChar and instring.startswith( - self.match, loc - ): - return loc + self.matchLen, self.match - raise ParseException(instring, loc, self.errmsg, self) - - -class Empty(Literal): - """ - An empty token, will always match. - """ - - def __init__(self, match_string="", *, matchString=""): - super().__init__("") - self.mayReturnEmpty = True - self.mayIndexError = False - - def _generateDefaultName(self) -> str: - return "Empty" - - def parseImpl(self, instring, loc, doActions=True): - return loc, [] - - -class _SingleCharLiteral(Literal): - def parseImpl(self, instring, loc, doActions=True): - if instring[loc] == self.firstMatchChar: - return loc + 1, self.match - raise ParseException(instring, loc, self.errmsg, self) - - -ParserElement._literalStringClass = Literal - - -class Keyword(Token): - """ - Token to exactly match a specified string as a keyword, that is, - it must be immediately preceded and followed by whitespace or - non-keyword characters. Compare with :class:`Literal`: - - - ``Literal("if")`` will match the leading ``'if'`` in - ``'ifAndOnlyIf'``. - - ``Keyword("if")`` will not; it will only match the leading - ``'if'`` in ``'if x=1'``, or ``'if(y==2)'`` - - Accepts two optional constructor arguments in addition to the - keyword string: - - - ``ident_chars`` is a string of characters that would be valid - identifier characters, defaulting to all alphanumerics + "_" and - "$" - - ``caseless`` allows case-insensitive matching, default is ``False``. - - Example:: - - Keyword("start").parse_string("start") # -> ['start'] - Keyword("start").parse_string("starting") # -> Exception - - For case-insensitive matching, use :class:`CaselessKeyword`. - """ - - DEFAULT_KEYWORD_CHARS = alphanums + "_$" - - def __init__( - self, - match_string: str = "", - ident_chars: typing.Optional[str] = None, - caseless: bool = False, - *, - matchString: str = "", - identChars: typing.Optional[str] = None, - ): - super().__init__() - identChars = identChars or ident_chars - if identChars is None: - identChars = Keyword.DEFAULT_KEYWORD_CHARS - match_string = matchString or match_string - self.match = match_string - self.matchLen = len(match_string) - try: - self.firstMatchChar = match_string[0] - except IndexError: - raise ValueError("null string passed to Keyword; use Empty() instead") - self.errmsg = f"Expected {type(self).__name__} {self.name}" - self.mayReturnEmpty = False - self.mayIndexError = False - self.caseless = caseless - if caseless: - self.caselessmatch = match_string.upper() - identChars = identChars.upper() - self.identChars = set(identChars) - - def _generateDefaultName(self) -> str: - return repr(self.match) - - def parseImpl(self, instring, loc, doActions=True): - errmsg = self.errmsg - errloc = loc - if self.caseless: - if instring[loc : loc + self.matchLen].upper() == self.caselessmatch: - if loc == 0 or instring[loc - 1].upper() not in self.identChars: - if ( - loc >= len(instring) - self.matchLen - or instring[loc + self.matchLen].upper() not in self.identChars - ): - return loc + self.matchLen, self.match - else: - # followed by keyword char - errmsg += ", was immediately followed by keyword character" - errloc = loc + self.matchLen - else: - # preceded by keyword char - errmsg += ", keyword was immediately preceded by keyword character" - errloc = loc - 1 - # else no match just raise plain exception - - else: - if ( - instring[loc] == self.firstMatchChar - and self.matchLen == 1 - or instring.startswith(self.match, loc) - ): - if loc == 0 or instring[loc - 1] not in self.identChars: - if ( - loc >= len(instring) - self.matchLen - or instring[loc + self.matchLen] not in self.identChars - ): - return loc + self.matchLen, self.match - else: - # followed by keyword char - errmsg += ( - ", keyword was immediately followed by keyword character" - ) - errloc = loc + self.matchLen - else: - # preceded by keyword char - errmsg += ", keyword was immediately preceded by keyword character" - errloc = loc - 1 - # else no match just raise plain exception - - raise ParseException(instring, errloc, errmsg, self) - - @staticmethod - def set_default_keyword_chars(chars) -> None: - """ - Overrides the default characters used by :class:`Keyword` expressions. - """ - Keyword.DEFAULT_KEYWORD_CHARS = chars - - setDefaultKeywordChars = set_default_keyword_chars - - -class CaselessLiteral(Literal): - """ - Token to match a specified string, ignoring case of letters. - Note: the matched results will always be in the case of the given - match string, NOT the case of the input text. - - Example:: - - CaselessLiteral("CMD")[1, ...].parse_string("cmd CMD Cmd10") - # -> ['CMD', 'CMD', 'CMD'] - - (Contrast with example for :class:`CaselessKeyword`.) - """ - - def __init__(self, match_string: str = "", *, matchString: str = ""): - match_string = matchString or match_string - super().__init__(match_string.upper()) - # Preserve the defining literal. - self.returnString = match_string - self.errmsg = "Expected " + self.name - - def parseImpl(self, instring, loc, doActions=True): - if instring[loc : loc + self.matchLen].upper() == self.match: - return loc + self.matchLen, self.returnString - raise ParseException(instring, loc, self.errmsg, self) - - -class CaselessKeyword(Keyword): - """ - Caseless version of :class:`Keyword`. - - Example:: - - CaselessKeyword("CMD")[1, ...].parse_string("cmd CMD Cmd10") - # -> ['CMD', 'CMD'] - - (Contrast with example for :class:`CaselessLiteral`.) - """ - - def __init__( - self, - match_string: str = "", - ident_chars: typing.Optional[str] = None, - *, - matchString: str = "", - identChars: typing.Optional[str] = None, - ): - identChars = identChars or ident_chars - match_string = matchString or match_string - super().__init__(match_string, identChars, caseless=True) - - -class CloseMatch(Token): - """A variation on :class:`Literal` which matches "close" matches, - that is, strings with at most 'n' mismatching characters. - :class:`CloseMatch` takes parameters: - - - ``match_string`` - string to be matched - - ``caseless`` - a boolean indicating whether to ignore casing when comparing characters - - ``max_mismatches`` - (``default=1``) maximum number of - mismatches allowed to count as a match - - The results from a successful parse will contain the matched text - from the input string and the following named results: - - - ``mismatches`` - a list of the positions within the - match_string where mismatches were found - - ``original`` - the original match_string used to compare - against the input string - - If ``mismatches`` is an empty list, then the match was an exact - match. - - Example:: - - patt = CloseMatch("ATCATCGAATGGA") - patt.parse_string("ATCATCGAAXGGA") # -> (['ATCATCGAAXGGA'], {'mismatches': [[9]], 'original': ['ATCATCGAATGGA']}) - patt.parse_string("ATCAXCGAAXGGA") # -> Exception: Expected 'ATCATCGAATGGA' (with up to 1 mismatches) (at char 0), (line:1, col:1) - - # exact match - patt.parse_string("ATCATCGAATGGA") # -> (['ATCATCGAATGGA'], {'mismatches': [[]], 'original': ['ATCATCGAATGGA']}) - - # close match allowing up to 2 mismatches - patt = CloseMatch("ATCATCGAATGGA", max_mismatches=2) - patt.parse_string("ATCAXCGAAXGGA") # -> (['ATCAXCGAAXGGA'], {'mismatches': [[4, 9]], 'original': ['ATCATCGAATGGA']}) - """ - - def __init__( - self, - match_string: str, - max_mismatches: typing.Optional[int] = None, - *, - maxMismatches: int = 1, - caseless=False, - ): - maxMismatches = max_mismatches if max_mismatches is not None else maxMismatches - super().__init__() - self.match_string = match_string - self.maxMismatches = maxMismatches - self.errmsg = f"Expected {self.match_string!r} (with up to {self.maxMismatches} mismatches)" - self.caseless = caseless - self.mayIndexError = False - self.mayReturnEmpty = False - - def _generateDefaultName(self) -> str: - return f"{type(self).__name__}:{self.match_string!r}" - - def parseImpl(self, instring, loc, doActions=True): - start = loc - instrlen = len(instring) - maxloc = start + len(self.match_string) - - if maxloc <= instrlen: - match_string = self.match_string - match_stringloc = 0 - mismatches = [] - maxMismatches = self.maxMismatches - - for match_stringloc, s_m in enumerate( - zip(instring[loc:maxloc], match_string) - ): - src, mat = s_m - if self.caseless: - src, mat = src.lower(), mat.lower() - - if src != mat: - mismatches.append(match_stringloc) - if len(mismatches) > maxMismatches: - break - else: - loc = start + match_stringloc + 1 - results = ParseResults([instring[start:loc]]) - results["original"] = match_string - results["mismatches"] = mismatches - return loc, results - - raise ParseException(instring, loc, self.errmsg, self) - - -class Word(Token): - """Token for matching words composed of allowed character sets. - - Parameters: - - - ``init_chars`` - string of all characters that should be used to - match as a word; "ABC" will match "AAA", "ABAB", "CBAC", etc.; - if ``body_chars`` is also specified, then this is the string of - initial characters - - ``body_chars`` - string of characters that - can be used for matching after a matched initial character as - given in ``init_chars``; if omitted, same as the initial characters - (default=``None``) - - ``min`` - minimum number of characters to match (default=1) - - ``max`` - maximum number of characters to match (default=0) - - ``exact`` - exact number of characters to match (default=0) - - ``as_keyword`` - match as a keyword (default=``False``) - - ``exclude_chars`` - characters that might be - found in the input ``body_chars`` string but which should not be - accepted for matching ;useful to define a word of all - printables except for one or two characters, for instance - (default=``None``) - - :class:`srange` is useful for defining custom character set strings - for defining :class:`Word` expressions, using range notation from - regular expression character sets. - - A common mistake is to use :class:`Word` to match a specific literal - string, as in ``Word("Address")``. Remember that :class:`Word` - uses the string argument to define *sets* of matchable characters. - This expression would match "Add", "AAA", "dAred", or any other word - made up of the characters 'A', 'd', 'r', 'e', and 's'. To match an - exact literal string, use :class:`Literal` or :class:`Keyword`. - - pyparsing includes helper strings for building Words: - - - :class:`alphas` - - :class:`nums` - - :class:`alphanums` - - :class:`hexnums` - - :class:`alphas8bit` (alphabetic characters in ASCII range 128-255 - - accented, tilded, umlauted, etc.) - - :class:`punc8bit` (non-alphabetic characters in ASCII range - 128-255 - currency, symbols, superscripts, diacriticals, etc.) - - :class:`printables` (any non-whitespace character) - - ``alphas``, ``nums``, and ``printables`` are also defined in several - Unicode sets - see :class:`pyparsing_unicode``. - - Example:: - - # a word composed of digits - integer = Word(nums) # equivalent to Word("0123456789") or Word(srange("0-9")) - - # a word with a leading capital, and zero or more lowercase - capital_word = Word(alphas.upper(), alphas.lower()) - - # hostnames are alphanumeric, with leading alpha, and '-' - hostname = Word(alphas, alphanums + '-') - - # roman numeral (not a strict parser, accepts invalid mix of characters) - roman = Word("IVXLCDM") - - # any string of non-whitespace characters, except for ',' - csv_value = Word(printables, exclude_chars=",") - """ - - def __init__( - self, - init_chars: str = "", - body_chars: typing.Optional[str] = None, - min: int = 1, - max: int = 0, - exact: int = 0, - as_keyword: bool = False, - exclude_chars: typing.Optional[str] = None, - *, - initChars: typing.Optional[str] = None, - bodyChars: typing.Optional[str] = None, - asKeyword: bool = False, - excludeChars: typing.Optional[str] = None, - ): - initChars = initChars or init_chars - bodyChars = bodyChars or body_chars - asKeyword = asKeyword or as_keyword - excludeChars = excludeChars or exclude_chars - super().__init__() - if not initChars: - raise ValueError( - f"invalid {type(self).__name__}, initChars cannot be empty string" - ) - - initChars_set = set(initChars) - if excludeChars: - excludeChars_set = set(excludeChars) - initChars_set -= excludeChars_set - if bodyChars: - bodyChars = "".join(set(bodyChars) - excludeChars_set) - self.initChars = initChars_set - self.initCharsOrig = "".join(sorted(initChars_set)) - - if bodyChars: - self.bodyChars = set(bodyChars) - self.bodyCharsOrig = "".join(sorted(bodyChars)) - else: - self.bodyChars = initChars_set - self.bodyCharsOrig = self.initCharsOrig - - self.maxSpecified = max > 0 - - if min < 1: - raise ValueError( - "cannot specify a minimum length < 1; use Opt(Word()) if zero-length word is permitted" - ) - - if self.maxSpecified and min > max: - raise ValueError( - f"invalid args, if min and max both specified min must be <= max (min={min}, max={max})" - ) - - self.minLen = min - - if max > 0: - self.maxLen = max - else: - self.maxLen = _MAX_INT - - if exact > 0: - min = max = exact - self.maxLen = exact - self.minLen = exact - - self.errmsg = "Expected " + self.name - self.mayIndexError = False - self.asKeyword = asKeyword - if self.asKeyword: - self.errmsg += " as a keyword" - - # see if we can make a regex for this Word - if " " not in (self.initChars | self.bodyChars): - if len(self.initChars) == 1: - re_leading_fragment = re.escape(self.initCharsOrig) - else: - re_leading_fragment = f"[{_collapse_string_to_ranges(self.initChars)}]" - - if self.bodyChars == self.initChars: - if max == 0: - repeat = "+" - elif max == 1: - repeat = "" - else: - if self.minLen != self.maxLen: - repeat = f"{{{self.minLen},{'' if self.maxLen == _MAX_INT else self.maxLen}}}" - else: - repeat = f"{{{self.minLen}}}" - self.reString = f"{re_leading_fragment}{repeat}" - else: - if max == 1: - re_body_fragment = "" - repeat = "" - else: - re_body_fragment = f"[{_collapse_string_to_ranges(self.bodyChars)}]" - if max == 0: - repeat = "*" - elif max == 2: - repeat = "?" if min <= 1 else "" - else: - if min != max: - repeat = f"{{{min - 1 if min > 0 else 0},{max - 1}}}" - else: - repeat = f"{{{min - 1 if min > 0 else 0}}}" - - self.reString = ( - f"{re_leading_fragment}" f"{re_body_fragment}" f"{repeat}" - ) - - if self.asKeyword: - self.reString = rf"\b{self.reString}\b" - - try: - self.re = re.compile(self.reString) - except re.error: - self.re = None # type: ignore[assignment] - else: - self.re_match = self.re.match - self.parseImpl = self.parseImpl_regex # type: ignore[assignment] - - def _generateDefaultName(self) -> str: - def charsAsStr(s): - max_repr_len = 16 - s = _collapse_string_to_ranges(s, re_escape=False) - if len(s) > max_repr_len: - return s[: max_repr_len - 3] + "..." - else: - return s - - if self.initChars != self.bodyChars: - base = f"W:({charsAsStr(self.initChars)}, {charsAsStr(self.bodyChars)})" - else: - base = f"W:({charsAsStr(self.initChars)})" - - # add length specification - if self.minLen > 1 or self.maxLen != _MAX_INT: - if self.minLen == self.maxLen: - if self.minLen == 1: - return base[2:] - else: - return base + f"{{{self.minLen}}}" - elif self.maxLen == _MAX_INT: - return base + f"{{{self.minLen},...}}" - else: - return base + f"{{{self.minLen},{self.maxLen}}}" - return base - - def parseImpl(self, instring, loc, doActions=True): - if instring[loc] not in self.initChars: - raise ParseException(instring, loc, self.errmsg, self) - - start = loc - loc += 1 - instrlen = len(instring) - bodychars = self.bodyChars - maxloc = start + self.maxLen - maxloc = min(maxloc, instrlen) - while loc < maxloc and instring[loc] in bodychars: - loc += 1 - - throwException = False - if loc - start < self.minLen: - throwException = True - elif self.maxSpecified and loc < instrlen and instring[loc] in bodychars: - throwException = True - elif self.asKeyword: - if ( - start > 0 - and instring[start - 1] in bodychars - or loc < instrlen - and instring[loc] in bodychars - ): - throwException = True - - if throwException: - raise ParseException(instring, loc, self.errmsg, self) - - return loc, instring[start:loc] - - def parseImpl_regex(self, instring, loc, doActions=True): - result = self.re_match(instring, loc) - if not result: - raise ParseException(instring, loc, self.errmsg, self) - - loc = result.end() - return loc, result.group() - - -class Char(Word): - """A short-cut class for defining :class:`Word` ``(characters, exact=1)``, - when defining a match of any single character in a string of - characters. - """ - - def __init__( - self, - charset: str, - as_keyword: bool = False, - exclude_chars: typing.Optional[str] = None, - *, - asKeyword: bool = False, - excludeChars: typing.Optional[str] = None, - ): - asKeyword = asKeyword or as_keyword - excludeChars = excludeChars or exclude_chars - super().__init__( - charset, exact=1, as_keyword=asKeyword, exclude_chars=excludeChars - ) - - -class Regex(Token): - r"""Token for matching strings that match a given regular - expression. Defined with string specifying the regular expression in - a form recognized by the stdlib Python `re module `_. - If the given regex contains named groups (defined using ``(?P...)``), - these will be preserved as named :class:`ParseResults`. - - If instead of the Python stdlib ``re`` module you wish to use a different RE module - (such as the ``regex`` module), you can do so by building your ``Regex`` object with - a compiled RE that was compiled using ``regex``. - - Example:: - - realnum = Regex(r"[+-]?\d+\.\d*") - # ref: https://stackoverflow.com/questions/267399/how-do-you-match-only-valid-roman-numerals-with-a-regular-expression - roman = Regex(r"M{0,4}(CM|CD|D?{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})") - - # named fields in a regex will be returned as named results - date = Regex(r'(?P\d{4})-(?P\d\d?)-(?P\d\d?)') - - # the Regex class will accept re's compiled using the regex module - import regex - parser = pp.Regex(regex.compile(r'[0-9]')) - """ - - def __init__( - self, - pattern: Any, - flags: Union[re.RegexFlag, int] = 0, - as_group_list: bool = False, - as_match: bool = False, - *, - asGroupList: bool = False, - asMatch: bool = False, - ): - """The parameters ``pattern`` and ``flags`` are passed - to the ``re.compile()`` function as-is. See the Python - `re module `_ module for an - explanation of the acceptable patterns and flags. - """ - super().__init__() - asGroupList = asGroupList or as_group_list - asMatch = asMatch or as_match - - if isinstance(pattern, str_type): - if not pattern: - raise ValueError("null string passed to Regex; use Empty() instead") - - self._re = None - self.reString = self.pattern = pattern - self.flags = flags - - elif hasattr(pattern, "pattern") and hasattr(pattern, "match"): - self._re = pattern - self.pattern = self.reString = pattern.pattern - self.flags = flags - - else: - raise TypeError( - "Regex may only be constructed with a string or a compiled RE object" - ) - - self.errmsg = "Expected " + self.name - self.mayIndexError = False - self.asGroupList = asGroupList - self.asMatch = asMatch - if self.asGroupList: - self.parseImpl = self.parseImplAsGroupList # type: ignore [assignment] - if self.asMatch: - self.parseImpl = self.parseImplAsMatch # type: ignore [assignment] - - @cached_property - def re(self): - if self._re: - return self._re - else: - try: - return re.compile(self.pattern, self.flags) - except re.error: - raise ValueError(f"invalid pattern ({self.pattern!r}) passed to Regex") - - @cached_property - def re_match(self): - return self.re.match - - @cached_property - def mayReturnEmpty(self): - return self.re_match("") is not None - - def _generateDefaultName(self) -> str: - return "Re:({})".format(repr(self.pattern).replace("\\\\", "\\")) - - def parseImpl(self, instring, loc, doActions=True): - result = self.re_match(instring, loc) - if not result: - raise ParseException(instring, loc, self.errmsg, self) - - loc = result.end() - ret = ParseResults(result.group()) - d = result.groupdict() - if d: - for k, v in d.items(): - ret[k] = v - return loc, ret - - def parseImplAsGroupList(self, instring, loc, doActions=True): - result = self.re_match(instring, loc) - if not result: - raise ParseException(instring, loc, self.errmsg, self) - - loc = result.end() - ret = result.groups() - return loc, ret - - def parseImplAsMatch(self, instring, loc, doActions=True): - result = self.re_match(instring, loc) - if not result: - raise ParseException(instring, loc, self.errmsg, self) - - loc = result.end() - ret = result - return loc, ret - - def sub(self, repl: str) -> ParserElement: - r""" - Return :class:`Regex` with an attached parse action to transform the parsed - result as if called using `re.sub(expr, repl, string) `_. - - Example:: - - make_html = Regex(r"(\w+):(.*?):").sub(r"<\1>\2") - print(make_html.transform_string("h1:main title:")) - # prints "

main title

" - """ - if self.asGroupList: - raise TypeError("cannot use sub() with Regex(as_group_list=True)") - - if self.asMatch and callable(repl): - raise TypeError( - "cannot use sub() with a callable with Regex(as_match=True)" - ) - - if self.asMatch: - - def pa(tokens): - return tokens[0].expand(repl) - - else: - - def pa(tokens): - return self.re.sub(repl, tokens[0]) - - return self.add_parse_action(pa) - - -class QuotedString(Token): - r""" - Token for matching strings that are delimited by quoting characters. - - Defined with the following parameters: - - - ``quote_char`` - string of one or more characters defining the - quote delimiting string - - ``esc_char`` - character to re_escape quotes, typically backslash - (default= ``None``) - - ``esc_quote`` - special quote sequence to re_escape an embedded quote - string (such as SQL's ``""`` to re_escape an embedded ``"``) - (default= ``None``) - - ``multiline`` - boolean indicating whether quotes can span - multiple lines (default= ``False``) - - ``unquote_results`` - boolean indicating whether the matched text - should be unquoted (default= ``True``) - - ``end_quote_char`` - string of one or more characters defining the - end of the quote delimited string (default= ``None`` => same as - quote_char) - - ``convert_whitespace_escapes`` - convert escaped whitespace - (``'\t'``, ``'\n'``, etc.) to actual whitespace - (default= ``True``) - - Example:: - - qs = QuotedString('"') - print(qs.search_string('lsjdf "This is the quote" sldjf')) - complex_qs = QuotedString('{{', end_quote_char='}}') - print(complex_qs.search_string('lsjdf {{This is the "quote"}} sldjf')) - sql_qs = QuotedString('"', esc_quote='""') - print(sql_qs.search_string('lsjdf "This is the quote with ""embedded"" quotes" sldjf')) - - prints:: - - [['This is the quote']] - [['This is the "quote"']] - [['This is the quote with "embedded" quotes']] - """ - ws_map = dict(((r"\t", "\t"), (r"\n", "\n"), (r"\f", "\f"), (r"\r", "\r"))) - - def __init__( - self, - quote_char: str = "", - esc_char: typing.Optional[str] = None, - esc_quote: typing.Optional[str] = None, - multiline: bool = False, - unquote_results: bool = True, - end_quote_char: typing.Optional[str] = None, - convert_whitespace_escapes: bool = True, - *, - quoteChar: str = "", - escChar: typing.Optional[str] = None, - escQuote: typing.Optional[str] = None, - unquoteResults: bool = True, - endQuoteChar: typing.Optional[str] = None, - convertWhitespaceEscapes: bool = True, - ): - super().__init__() - escChar = escChar or esc_char - escQuote = escQuote or esc_quote - unquoteResults = unquoteResults and unquote_results - endQuoteChar = endQuoteChar or end_quote_char - convertWhitespaceEscapes = ( - convertWhitespaceEscapes and convert_whitespace_escapes - ) - quote_char = quoteChar or quote_char - - # remove white space from quote chars - wont work anyway - quote_char = quote_char.strip() - if not quote_char: - raise ValueError("quote_char cannot be the empty string") - - if endQuoteChar is None: - endQuoteChar = quote_char - else: - endQuoteChar = endQuoteChar.strip() - if not endQuoteChar: - raise ValueError("end_quote_char cannot be the empty string") - - self.quoteChar: str = quote_char - self.quoteCharLen: int = len(quote_char) - self.firstQuoteChar: str = quote_char[0] - self.endQuoteChar: str = endQuoteChar - self.endQuoteCharLen: int = len(endQuoteChar) - self.escChar: str = escChar or "" - self.escQuote: str = escQuote or "" - self.unquoteResults: bool = unquoteResults - self.convertWhitespaceEscapes: bool = convertWhitespaceEscapes - self.multiline = multiline - - sep = "" - inner_pattern = "" - - if escQuote: - inner_pattern += rf"{sep}(?:{re.escape(escQuote)})" - sep = "|" - - if escChar: - inner_pattern += rf"{sep}(?:{re.escape(escChar)}.)" - sep = "|" - self.escCharReplacePattern = re.escape(escChar) + "(.)" - - if len(self.endQuoteChar) > 1: - inner_pattern += ( - f"{sep}(?:" - + "|".join( - f"(?:{re.escape(self.endQuoteChar[:i])}(?!{re.escape(self.endQuoteChar[i:])}))" - for i in range(len(self.endQuoteChar) - 1, 0, -1) - ) - + ")" - ) - sep = "|" - - self.flags = re.RegexFlag(0) - - if multiline: - self.flags = re.MULTILINE | re.DOTALL - inner_pattern += ( - rf"{sep}(?:[^{_escape_regex_range_chars(self.endQuoteChar[0])}" - rf"{(_escape_regex_range_chars(escChar) if escChar is not None else '')}])" - ) - else: - inner_pattern += ( - rf"{sep}(?:[^{_escape_regex_range_chars(self.endQuoteChar[0])}\n\r" - rf"{(_escape_regex_range_chars(escChar) if escChar is not None else '')}])" - ) - - self.pattern = "".join( - [ - re.escape(self.quoteChar), - "(?:", - inner_pattern, - ")*", - re.escape(self.endQuoteChar), - ] - ) - - if self.unquoteResults: - if self.convertWhitespaceEscapes: - self.unquote_scan_re = re.compile( - rf"({'|'.join(re.escape(k) for k in self.ws_map)})|({re.escape(self.escChar)}.)|(\n|.)", - flags=self.flags, - ) - else: - self.unquote_scan_re = re.compile( - rf"({re.escape(self.escChar)}.)|(\n|.)", flags=self.flags - ) - - try: - self.re = re.compile(self.pattern, self.flags) - self.reString = self.pattern - self.re_match = self.re.match - except re.error: - raise ValueError(f"invalid pattern {self.pattern!r} passed to Regex") - - self.errmsg = "Expected " + self.name - self.mayIndexError = False - self.mayReturnEmpty = True - - def _generateDefaultName(self) -> str: - if self.quoteChar == self.endQuoteChar and isinstance(self.quoteChar, str_type): - return f"string enclosed in {self.quoteChar!r}" - - return f"quoted string, starting with {self.quoteChar} ending with {self.endQuoteChar}" - - def parseImpl(self, instring, loc, doActions=True): - result = ( - instring[loc] == self.firstQuoteChar - and self.re_match(instring, loc) - or None - ) - if not result: - raise ParseException(instring, loc, self.errmsg, self) - - loc = result.end() - ret = result.group() - - if self.unquoteResults: - # strip off quotes - ret = ret[self.quoteCharLen : -self.endQuoteCharLen] - - if isinstance(ret, str_type): - if self.convertWhitespaceEscapes: - ret = "".join( - self.ws_map[match.group(1)] - if match.group(1) - else match.group(2)[-1] - if match.group(2) - else match.group(3) - for match in self.unquote_scan_re.finditer(ret) - ) - else: - ret = "".join( - match.group(1)[-1] if match.group(1) else match.group(2) - for match in self.unquote_scan_re.finditer(ret) - ) - - # replace escaped quotes - if self.escQuote: - ret = ret.replace(self.escQuote, self.endQuoteChar) - - return loc, ret - - -class CharsNotIn(Token): - """Token for matching words composed of characters *not* in a given - set (will include whitespace in matched characters if not listed in - the provided exclusion set - see example). Defined with string - containing all disallowed characters, and an optional minimum, - maximum, and/or exact length. The default value for ``min`` is - 1 (a minimum value < 1 is not valid); the default values for - ``max`` and ``exact`` are 0, meaning no maximum or exact - length restriction. - - Example:: - - # define a comma-separated-value as anything that is not a ',' - csv_value = CharsNotIn(',') - print(DelimitedList(csv_value).parse_string("dkls,lsdkjf,s12 34,@!#,213")) - - prints:: - - ['dkls', 'lsdkjf', 's12 34', '@!#', '213'] - """ - - def __init__( - self, - not_chars: str = "", - min: int = 1, - max: int = 0, - exact: int = 0, - *, - notChars: str = "", - ): - super().__init__() - self.skipWhitespace = False - self.notChars = not_chars or notChars - self.notCharsSet = set(self.notChars) - - if min < 1: - raise ValueError( - "cannot specify a minimum length < 1; use " - "Opt(CharsNotIn()) if zero-length char group is permitted" - ) - - self.minLen = min - - if max > 0: - self.maxLen = max - else: - self.maxLen = _MAX_INT - - if exact > 0: - self.maxLen = exact - self.minLen = exact - - self.errmsg = "Expected " + self.name - self.mayReturnEmpty = self.minLen == 0 - self.mayIndexError = False - - def _generateDefaultName(self) -> str: - not_chars_str = _collapse_string_to_ranges(self.notChars) - if len(not_chars_str) > 16: - return f"!W:({self.notChars[: 16 - 3]}...)" - else: - return f"!W:({self.notChars})" - - def parseImpl(self, instring, loc, doActions=True): - notchars = self.notCharsSet - if instring[loc] in notchars: - raise ParseException(instring, loc, self.errmsg, self) - - start = loc - loc += 1 - maxlen = min(start + self.maxLen, len(instring)) - while loc < maxlen and instring[loc] not in notchars: - loc += 1 - - if loc - start < self.minLen: - raise ParseException(instring, loc, self.errmsg, self) - - return loc, instring[start:loc] - - -class White(Token): - """Special matching class for matching whitespace. Normally, - whitespace is ignored by pyparsing grammars. This class is included - when some whitespace structures are significant. Define with - a string containing the whitespace characters to be matched; default - is ``" \\t\\r\\n"``. Also takes optional ``min``, - ``max``, and ``exact`` arguments, as defined for the - :class:`Word` class. - """ - - whiteStrs = { - " ": "", - "\t": "", - "\n": "", - "\r": "", - "\f": "", - "\u00A0": "", - "\u1680": "", - "\u180E": "", - "\u2000": "", - "\u2001": "", - "\u2002": "", - "\u2003": "", - "\u2004": "", - "\u2005": "", - "\u2006": "", - "\u2007": "", - "\u2008": "", - "\u2009": "", - "\u200A": "", - "\u200B": "", - "\u202F": "", - "\u205F": "", - "\u3000": "", - } - - def __init__(self, ws: str = " \t\r\n", min: int = 1, max: int = 0, exact: int = 0): - super().__init__() - self.matchWhite = ws - self.set_whitespace_chars( - "".join(c for c in self.whiteStrs if c not in self.matchWhite), - copy_defaults=True, - ) - # self.leave_whitespace() - self.mayReturnEmpty = True - self.errmsg = "Expected " + self.name - - self.minLen = min - - if max > 0: - self.maxLen = max - else: - self.maxLen = _MAX_INT - - if exact > 0: - self.maxLen = exact - self.minLen = exact - - def _generateDefaultName(self) -> str: - return "".join(White.whiteStrs[c] for c in self.matchWhite) - - def parseImpl(self, instring, loc, doActions=True): - if instring[loc] not in self.matchWhite: - raise ParseException(instring, loc, self.errmsg, self) - start = loc - loc += 1 - maxloc = start + self.maxLen - maxloc = min(maxloc, len(instring)) - while loc < maxloc and instring[loc] in self.matchWhite: - loc += 1 - - if loc - start < self.minLen: - raise ParseException(instring, loc, self.errmsg, self) - - return loc, instring[start:loc] - - -class PositionToken(Token): - def __init__(self): - super().__init__() - self.mayReturnEmpty = True - self.mayIndexError = False - - -class GoToColumn(PositionToken): - """Token to advance to a specific column of input text; useful for - tabular report scraping. - """ - - def __init__(self, colno: int): - super().__init__() - self.col = colno - - def preParse(self, instring: str, loc: int) -> int: - if col(loc, instring) != self.col: - instrlen = len(instring) - if self.ignoreExprs: - loc = self._skipIgnorables(instring, loc) - while ( - loc < instrlen - and instring[loc].isspace() - and col(loc, instring) != self.col - ): - loc += 1 - return loc - - def parseImpl(self, instring, loc, doActions=True): - thiscol = col(loc, instring) - if thiscol > self.col: - raise ParseException(instring, loc, "Text not in expected column", self) - newloc = loc + self.col - thiscol - ret = instring[loc:newloc] - return newloc, ret - - -class LineStart(PositionToken): - r"""Matches if current position is at the beginning of a line within - the parse string - - Example:: - - test = '''\ - AAA this line - AAA and this line - AAA but not this one - B AAA and definitely not this one - ''' - - for t in (LineStart() + 'AAA' + rest_of_line).search_string(test): - print(t) - - prints:: - - ['AAA', ' this line'] - ['AAA', ' and this line'] - - """ - - def __init__(self): - super().__init__() - self.leave_whitespace() - self.orig_whiteChars = set() | self.whiteChars - self.whiteChars.discard("\n") - self.skipper = Empty().set_whitespace_chars(self.whiteChars) - self.errmsg = "Expected start of line" - - def preParse(self, instring: str, loc: int) -> int: - if loc == 0: - return loc - else: - ret = self.skipper.preParse(instring, loc) - if "\n" in self.orig_whiteChars: - while instring[ret : ret + 1] == "\n": - ret = self.skipper.preParse(instring, ret + 1) - return ret - - def parseImpl(self, instring, loc, doActions=True): - if col(loc, instring) == 1: - return loc, [] - raise ParseException(instring, loc, self.errmsg, self) - - -class LineEnd(PositionToken): - """Matches if current position is at the end of a line within the - parse string - """ - - def __init__(self): - super().__init__() - self.whiteChars.discard("\n") - self.set_whitespace_chars(self.whiteChars, copy_defaults=False) - self.errmsg = "Expected end of line" - - def parseImpl(self, instring, loc, doActions=True): - if loc < len(instring): - if instring[loc] == "\n": - return loc + 1, "\n" - else: - raise ParseException(instring, loc, self.errmsg, self) - elif loc == len(instring): - return loc + 1, [] - else: - raise ParseException(instring, loc, self.errmsg, self) - - -class StringStart(PositionToken): - """Matches if current position is at the beginning of the parse - string - """ - - def __init__(self): - super().__init__() - self.errmsg = "Expected start of text" - - def parseImpl(self, instring, loc, doActions=True): - if loc != 0: - # see if entire string up to here is just whitespace and ignoreables - if loc != self.preParse(instring, 0): - raise ParseException(instring, loc, self.errmsg, self) - return loc, [] - - -class StringEnd(PositionToken): - """ - Matches if current position is at the end of the parse string - """ - - def __init__(self): - super().__init__() - self.errmsg = "Expected end of text" - - def parseImpl(self, instring, loc, doActions=True): - if loc < len(instring): - raise ParseException(instring, loc, self.errmsg, self) - elif loc == len(instring): - return loc + 1, [] - elif loc > len(instring): - return loc, [] - else: - raise ParseException(instring, loc, self.errmsg, self) - - -class WordStart(PositionToken): - """Matches if the current position is at the beginning of a - :class:`Word`, and is not preceded by any character in a given - set of ``word_chars`` (default= ``printables``). To emulate the - ``\b`` behavior of regular expressions, use - ``WordStart(alphanums)``. ``WordStart`` will also match at - the beginning of the string being parsed, or at the beginning of - a line. - """ - - def __init__(self, word_chars: str = printables, *, wordChars: str = printables): - wordChars = word_chars if wordChars == printables else wordChars - super().__init__() - self.wordChars = set(wordChars) - self.errmsg = "Not at the start of a word" - - def parseImpl(self, instring, loc, doActions=True): - if loc != 0: - if ( - instring[loc - 1] in self.wordChars - or instring[loc] not in self.wordChars - ): - raise ParseException(instring, loc, self.errmsg, self) - return loc, [] - - -class WordEnd(PositionToken): - """Matches if the current position is at the end of a :class:`Word`, - and is not followed by any character in a given set of ``word_chars`` - (default= ``printables``). To emulate the ``\b`` behavior of - regular expressions, use ``WordEnd(alphanums)``. ``WordEnd`` - will also match at the end of the string being parsed, or at the end - of a line. - """ - - def __init__(self, word_chars: str = printables, *, wordChars: str = printables): - wordChars = word_chars if wordChars == printables else wordChars - super().__init__() - self.wordChars = set(wordChars) - self.skipWhitespace = False - self.errmsg = "Not at the end of a word" - - def parseImpl(self, instring, loc, doActions=True): - instrlen = len(instring) - if instrlen > 0 and loc < instrlen: - if ( - instring[loc] in self.wordChars - or instring[loc - 1] not in self.wordChars - ): - raise ParseException(instring, loc, self.errmsg, self) - return loc, [] - - -class ParseExpression(ParserElement): - """Abstract subclass of ParserElement, for combining and - post-processing parsed tokens. - """ - - def __init__(self, exprs: typing.Iterable[ParserElement], savelist: bool = False): - super().__init__(savelist) - self.exprs: List[ParserElement] - if isinstance(exprs, _generatorType): - exprs = list(exprs) - - if isinstance(exprs, str_type): - self.exprs = [self._literalStringClass(exprs)] - elif isinstance(exprs, ParserElement): - self.exprs = [exprs] - elif isinstance(exprs, Iterable): - exprs = list(exprs) - # if sequence of strings provided, wrap with Literal - if any(isinstance(expr, str_type) for expr in exprs): - exprs = ( - self._literalStringClass(e) if isinstance(e, str_type) else e - for e in exprs - ) - self.exprs = list(exprs) - else: - try: - self.exprs = list(exprs) - except TypeError: - self.exprs = [exprs] - self.callPreparse = False - - def recurse(self) -> List[ParserElement]: - return self.exprs[:] - - def append(self, other) -> ParserElement: - self.exprs.append(other) - self._defaultName = None - return self - - def leave_whitespace(self, recursive: bool = True) -> ParserElement: - """ - Extends ``leave_whitespace`` defined in base class, and also invokes ``leave_whitespace`` on - all contained expressions. - """ - super().leave_whitespace(recursive) - - if recursive: - self.exprs = [e.copy() for e in self.exprs] - for e in self.exprs: - e.leave_whitespace(recursive) - return self - - def ignore_whitespace(self, recursive: bool = True) -> ParserElement: - """ - Extends ``ignore_whitespace`` defined in base class, and also invokes ``leave_whitespace`` on - all contained expressions. - """ - super().ignore_whitespace(recursive) - if recursive: - self.exprs = [e.copy() for e in self.exprs] - for e in self.exprs: - e.ignore_whitespace(recursive) - return self - - def ignore(self, other) -> ParserElement: - if isinstance(other, Suppress): - if other not in self.ignoreExprs: - super().ignore(other) - for e in self.exprs: - e.ignore(self.ignoreExprs[-1]) - else: - super().ignore(other) - for e in self.exprs: - e.ignore(self.ignoreExprs[-1]) - return self - - def _generateDefaultName(self) -> str: - return f"{self.__class__.__name__}:({str(self.exprs)})" - - def streamline(self) -> ParserElement: - if self.streamlined: - return self - - super().streamline() - - for e in self.exprs: - e.streamline() - - # collapse nested :class:`And`'s of the form ``And(And(And(a, b), c), d)`` to ``And(a, b, c, d)`` - # but only if there are no parse actions or resultsNames on the nested And's - # (likewise for :class:`Or`'s and :class:`MatchFirst`'s) - if len(self.exprs) == 2: - other = self.exprs[0] - if ( - isinstance(other, self.__class__) - and not other.parseAction - and other.resultsName is None - and not other.debug - ): - self.exprs = other.exprs[:] + [self.exprs[1]] - self._defaultName = None - self.mayReturnEmpty |= other.mayReturnEmpty - self.mayIndexError |= other.mayIndexError - - other = self.exprs[-1] - if ( - isinstance(other, self.__class__) - and not other.parseAction - and other.resultsName is None - and not other.debug - ): - self.exprs = self.exprs[:-1] + other.exprs[:] - self._defaultName = None - self.mayReturnEmpty |= other.mayReturnEmpty - self.mayIndexError |= other.mayIndexError - - self.errmsg = "Expected " + str(self) - - return self - - def validate(self, validateTrace=None) -> None: - warnings.warn( - "ParserElement.validate() is deprecated, and should not be used to check for left recursion", - DeprecationWarning, - stacklevel=2, - ) - tmp = (validateTrace if validateTrace is not None else [])[:] + [self] - for e in self.exprs: - e.validate(tmp) - self._checkRecursion([]) - - def copy(self) -> ParserElement: - ret = super().copy() - ret = typing.cast(ParseExpression, ret) - ret.exprs = [e.copy() for e in self.exprs] - return ret - - def _setResultsName(self, name, listAllMatches=False): - if ( - __diag__.warn_ungrouped_named_tokens_in_collection - and Diagnostics.warn_ungrouped_named_tokens_in_collection - not in self.suppress_warnings_ - ): - for e in self.exprs: - if ( - isinstance(e, ParserElement) - and e.resultsName - and Diagnostics.warn_ungrouped_named_tokens_in_collection - not in e.suppress_warnings_ - ): - warnings.warn( - "{}: setting results name {!r} on {} expression " - "collides with {!r} on contained expression".format( - "warn_ungrouped_named_tokens_in_collection", - name, - type(self).__name__, - e.resultsName, - ), - stacklevel=3, - ) - - return super()._setResultsName(name, listAllMatches) - - # Compatibility synonyms - # fmt: off - @replaced_by_pep8(leave_whitespace) - def leaveWhitespace(self): ... - - @replaced_by_pep8(ignore_whitespace) - def ignoreWhitespace(self): ... - # fmt: on - - -class And(ParseExpression): - """ - Requires all given :class:`ParseExpression` s to be found in the given order. - Expressions may be separated by whitespace. - May be constructed using the ``'+'`` operator. - May also be constructed using the ``'-'`` operator, which will - suppress backtracking. - - Example:: - - integer = Word(nums) - name_expr = Word(alphas)[1, ...] - - expr = And([integer("id"), name_expr("name"), integer("age")]) - # more easily written as: - expr = integer("id") + name_expr("name") + integer("age") - """ - - class _ErrorStop(Empty): - def __init__(self, *args, **kwargs): - super().__init__(*args, **kwargs) - self.leave_whitespace() - - def _generateDefaultName(self) -> str: - return "-" - - def __init__( - self, exprs_arg: typing.Iterable[ParserElement], savelist: bool = True - ): - exprs: List[ParserElement] = list(exprs_arg) - if exprs and Ellipsis in exprs: - tmp = [] - for i, expr in enumerate(exprs): - if expr is Ellipsis: - if i < len(exprs) - 1: - skipto_arg: ParserElement = typing.cast( - ParseExpression, (Empty() + exprs[i + 1]) - ).exprs[-1] - tmp.append(SkipTo(skipto_arg)("_skipped*")) - else: - raise Exception( - "cannot construct And with sequence ending in ..." - ) - else: - tmp.append(expr) - exprs[:] = tmp - super().__init__(exprs, savelist) - if self.exprs: - self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) - if not isinstance(self.exprs[0], White): - self.set_whitespace_chars( - self.exprs[0].whiteChars, - copy_defaults=self.exprs[0].copyDefaultWhiteChars, - ) - self.skipWhitespace = self.exprs[0].skipWhitespace - else: - self.skipWhitespace = False - else: - self.mayReturnEmpty = True - self.callPreparse = True - - def streamline(self) -> ParserElement: - # collapse any _PendingSkip's - if self.exprs: - if any( - isinstance(e, ParseExpression) - and e.exprs - and isinstance(e.exprs[-1], _PendingSkip) - for e in self.exprs[:-1] - ): - deleted_expr_marker = NoMatch() - for i, e in enumerate(self.exprs[:-1]): - if e is deleted_expr_marker: - continue - if ( - isinstance(e, ParseExpression) - and e.exprs - and isinstance(e.exprs[-1], _PendingSkip) - ): - e.exprs[-1] = e.exprs[-1] + self.exprs[i + 1] - self.exprs[i + 1] = deleted_expr_marker - self.exprs = [e for e in self.exprs if e is not deleted_expr_marker] - - super().streamline() - - # link any IndentedBlocks to the prior expression - prev: ParserElement - cur: ParserElement - for prev, cur in zip(self.exprs, self.exprs[1:]): - # traverse cur or any first embedded expr of cur looking for an IndentedBlock - # (but watch out for recursive grammar) - seen = set() - while True: - if id(cur) in seen: - break - seen.add(id(cur)) - if isinstance(cur, IndentedBlock): - prev.add_parse_action( - lambda s, l, t, cur_=cur: setattr( - cur_, "parent_anchor", col(l, s) - ) - ) - break - subs = cur.recurse() - next_first = next(iter(subs), None) - if next_first is None: - break - cur = typing.cast(ParserElement, next_first) - - self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) - return self - - def parseImpl(self, instring, loc, doActions=True): - # pass False as callPreParse arg to _parse for first element, since we already - # pre-parsed the string as part of our And pre-parsing - loc, resultlist = self.exprs[0]._parse( - instring, loc, doActions, callPreParse=False - ) - errorStop = False - for e in self.exprs[1:]: - # if isinstance(e, And._ErrorStop): - if type(e) is And._ErrorStop: - errorStop = True - continue - if errorStop: - try: - loc, exprtokens = e._parse(instring, loc, doActions) - except ParseSyntaxException: - raise - except ParseBaseException as pe: - pe.__traceback__ = None - raise ParseSyntaxException._from_exception(pe) - except IndexError: - raise ParseSyntaxException( - instring, len(instring), self.errmsg, self - ) - else: - loc, exprtokens = e._parse(instring, loc, doActions) - resultlist += exprtokens - return loc, resultlist - - def __iadd__(self, other): - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return self.append(other) # And([self, other]) - - def _checkRecursion(self, parseElementList): - subRecCheckList = parseElementList[:] + [self] - for e in self.exprs: - e._checkRecursion(subRecCheckList) - if not e.mayReturnEmpty: - break - - def _generateDefaultName(self) -> str: - inner = " ".join(str(e) for e in self.exprs) - # strip off redundant inner {}'s - while len(inner) > 1 and inner[0 :: len(inner) - 1] == "{}": - inner = inner[1:-1] - return "{" + inner + "}" - - -class Or(ParseExpression): - """Requires that at least one :class:`ParseExpression` is found. If - two expressions match, the expression that matches the longest - string will be used. May be constructed using the ``'^'`` - operator. - - Example:: - - # construct Or using '^' operator - - number = Word(nums) ^ Combine(Word(nums) + '.' + Word(nums)) - print(number.search_string("123 3.1416 789")) - - prints:: - - [['123'], ['3.1416'], ['789']] - """ - - def __init__(self, exprs: typing.Iterable[ParserElement], savelist: bool = False): - super().__init__(exprs, savelist) - if self.exprs: - self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) - self.skipWhitespace = all(e.skipWhitespace for e in self.exprs) - else: - self.mayReturnEmpty = True - - def streamline(self) -> ParserElement: - super().streamline() - if self.exprs: - self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) - self.saveAsList = any(e.saveAsList for e in self.exprs) - self.skipWhitespace = all( - e.skipWhitespace and not isinstance(e, White) for e in self.exprs - ) - else: - self.saveAsList = False - return self - - def parseImpl(self, instring, loc, doActions=True): - maxExcLoc = -1 - maxException = None - matches = [] - fatals = [] - if all(e.callPreparse for e in self.exprs): - loc = self.preParse(instring, loc) - for e in self.exprs: - try: - loc2 = e.try_parse(instring, loc, raise_fatal=True) - except ParseFatalException as pfe: - pfe.__traceback__ = None - pfe.parser_element = e - fatals.append(pfe) - maxException = None - maxExcLoc = -1 - except ParseException as err: - if not fatals: - err.__traceback__ = None - if err.loc > maxExcLoc: - maxException = err - maxExcLoc = err.loc - except IndexError: - if len(instring) > maxExcLoc: - maxException = ParseException( - instring, len(instring), e.errmsg, self - ) - maxExcLoc = len(instring) - else: - # save match among all matches, to retry longest to shortest - matches.append((loc2, e)) - - if matches: - # re-evaluate all matches in descending order of length of match, in case attached actions - # might change whether or how much they match of the input. - matches.sort(key=itemgetter(0), reverse=True) - - if not doActions: - # no further conditions or parse actions to change the selection of - # alternative, so the first match will be the best match - best_expr = matches[0][1] - return best_expr._parse(instring, loc, doActions) - - longest = -1, None - for loc1, expr1 in matches: - if loc1 <= longest[0]: - # already have a longer match than this one will deliver, we are done - return longest - - try: - loc2, toks = expr1._parse(instring, loc, doActions) - except ParseException as err: - err.__traceback__ = None - if err.loc > maxExcLoc: - maxException = err - maxExcLoc = err.loc - else: - if loc2 >= loc1: - return loc2, toks - # didn't match as much as before - elif loc2 > longest[0]: - longest = loc2, toks - - if longest != (-1, None): - return longest - - if fatals: - if len(fatals) > 1: - fatals.sort(key=lambda e: -e.loc) - if fatals[0].loc == fatals[1].loc: - fatals.sort(key=lambda e: (-e.loc, -len(str(e.parser_element)))) - max_fatal = fatals[0] - raise max_fatal - - if maxException is not None: - # infer from this check that all alternatives failed at the current position - # so emit this collective error message instead of any single error message - if maxExcLoc == loc: - maxException.msg = self.errmsg - raise maxException - else: - raise ParseException( - instring, loc, "no defined alternatives to match", self - ) - - def __ixor__(self, other): - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return self.append(other) # Or([self, other]) - - def _generateDefaultName(self) -> str: - return "{" + " ^ ".join(str(e) for e in self.exprs) + "}" - - def _setResultsName(self, name, listAllMatches=False): - if ( - __diag__.warn_multiple_tokens_in_named_alternation - and Diagnostics.warn_multiple_tokens_in_named_alternation - not in self.suppress_warnings_ - ): - if any( - isinstance(e, And) - and Diagnostics.warn_multiple_tokens_in_named_alternation - not in e.suppress_warnings_ - for e in self.exprs - ): - warnings.warn( - "{}: setting results name {!r} on {} expression " - "will return a list of all parsed tokens in an And alternative, " - "in prior versions only the first token was returned; enclose " - "contained argument in Group".format( - "warn_multiple_tokens_in_named_alternation", - name, - type(self).__name__, - ), - stacklevel=3, - ) - - return super()._setResultsName(name, listAllMatches) - - -class MatchFirst(ParseExpression): - """Requires that at least one :class:`ParseExpression` is found. If - more than one expression matches, the first one listed is the one that will - match. May be constructed using the ``'|'`` operator. - - Example:: - - # construct MatchFirst using '|' operator - - # watch the order of expressions to match - number = Word(nums) | Combine(Word(nums) + '.' + Word(nums)) - print(number.search_string("123 3.1416 789")) # Fail! -> [['123'], ['3'], ['1416'], ['789']] - - # put more selective expression first - number = Combine(Word(nums) + '.' + Word(nums)) | Word(nums) - print(number.search_string("123 3.1416 789")) # Better -> [['123'], ['3.1416'], ['789']] - """ - - def __init__(self, exprs: typing.Iterable[ParserElement], savelist: bool = False): - super().__init__(exprs, savelist) - if self.exprs: - self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) - self.skipWhitespace = all(e.skipWhitespace for e in self.exprs) - else: - self.mayReturnEmpty = True - - def streamline(self) -> ParserElement: - if self.streamlined: - return self - - super().streamline() - if self.exprs: - self.saveAsList = any(e.saveAsList for e in self.exprs) - self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) - self.skipWhitespace = all( - e.skipWhitespace and not isinstance(e, White) for e in self.exprs - ) - else: - self.saveAsList = False - self.mayReturnEmpty = True - return self - - def parseImpl(self, instring, loc, doActions=True): - maxExcLoc = -1 - maxException = None - - for e in self.exprs: - try: - return e._parse( - instring, - loc, - doActions, - ) - except ParseFatalException as pfe: - pfe.__traceback__ = None - pfe.parser_element = e - raise - except ParseException as err: - if err.loc > maxExcLoc: - maxException = err - maxExcLoc = err.loc - except IndexError: - if len(instring) > maxExcLoc: - maxException = ParseException( - instring, len(instring), e.errmsg, self - ) - maxExcLoc = len(instring) - - if maxException is not None: - # infer from this check that all alternatives failed at the current position - # so emit this collective error message instead of any individual error message - if maxExcLoc == loc: - maxException.msg = self.errmsg - raise maxException - else: - raise ParseException( - instring, loc, "no defined alternatives to match", self - ) - - def __ior__(self, other): - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return self.append(other) # MatchFirst([self, other]) - - def _generateDefaultName(self) -> str: - return "{" + " | ".join(str(e) for e in self.exprs) + "}" - - def _setResultsName(self, name, listAllMatches=False): - if ( - __diag__.warn_multiple_tokens_in_named_alternation - and Diagnostics.warn_multiple_tokens_in_named_alternation - not in self.suppress_warnings_ - ): - if any( - isinstance(e, And) - and Diagnostics.warn_multiple_tokens_in_named_alternation - not in e.suppress_warnings_ - for e in self.exprs - ): - warnings.warn( - "{}: setting results name {!r} on {} expression " - "will return a list of all parsed tokens in an And alternative, " - "in prior versions only the first token was returned; enclose " - "contained argument in Group".format( - "warn_multiple_tokens_in_named_alternation", - name, - type(self).__name__, - ), - stacklevel=3, - ) - - return super()._setResultsName(name, listAllMatches) - - -class Each(ParseExpression): - """Requires all given :class:`ParseExpression` s to be found, but in - any order. Expressions may be separated by whitespace. - - May be constructed using the ``'&'`` operator. - - Example:: - - color = one_of("RED ORANGE YELLOW GREEN BLUE PURPLE BLACK WHITE BROWN") - shape_type = one_of("SQUARE CIRCLE TRIANGLE STAR HEXAGON OCTAGON") - integer = Word(nums) - shape_attr = "shape:" + shape_type("shape") - posn_attr = "posn:" + Group(integer("x") + ',' + integer("y"))("posn") - color_attr = "color:" + color("color") - size_attr = "size:" + integer("size") - - # use Each (using operator '&') to accept attributes in any order - # (shape and posn are required, color and size are optional) - shape_spec = shape_attr & posn_attr & Opt(color_attr) & Opt(size_attr) - - shape_spec.run_tests(''' - shape: SQUARE color: BLACK posn: 100, 120 - shape: CIRCLE size: 50 color: BLUE posn: 50,80 - color:GREEN size:20 shape:TRIANGLE posn:20,40 - ''' - ) - - prints:: - - shape: SQUARE color: BLACK posn: 100, 120 - ['shape:', 'SQUARE', 'color:', 'BLACK', 'posn:', ['100', ',', '120']] - - color: BLACK - - posn: ['100', ',', '120'] - - x: 100 - - y: 120 - - shape: SQUARE - - - shape: CIRCLE size: 50 color: BLUE posn: 50,80 - ['shape:', 'CIRCLE', 'size:', '50', 'color:', 'BLUE', 'posn:', ['50', ',', '80']] - - color: BLUE - - posn: ['50', ',', '80'] - - x: 50 - - y: 80 - - shape: CIRCLE - - size: 50 - - - color: GREEN size: 20 shape: TRIANGLE posn: 20,40 - ['color:', 'GREEN', 'size:', '20', 'shape:', 'TRIANGLE', 'posn:', ['20', ',', '40']] - - color: GREEN - - posn: ['20', ',', '40'] - - x: 20 - - y: 40 - - shape: TRIANGLE - - size: 20 - """ - - def __init__(self, exprs: typing.Iterable[ParserElement], savelist: bool = True): - super().__init__(exprs, savelist) - if self.exprs: - self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) - else: - self.mayReturnEmpty = True - self.skipWhitespace = True - self.initExprGroups = True - self.saveAsList = True - - def __iand__(self, other): - if isinstance(other, str_type): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - return NotImplemented - return self.append(other) # Each([self, other]) - - def streamline(self) -> ParserElement: - super().streamline() - if self.exprs: - self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) - else: - self.mayReturnEmpty = True - return self - - def parseImpl(self, instring, loc, doActions=True): - if self.initExprGroups: - self.opt1map = dict( - (id(e.expr), e) for e in self.exprs if isinstance(e, Opt) - ) - opt1 = [e.expr for e in self.exprs if isinstance(e, Opt)] - opt2 = [ - e - for e in self.exprs - if e.mayReturnEmpty and not isinstance(e, (Opt, Regex, ZeroOrMore)) - ] - self.optionals = opt1 + opt2 - self.multioptionals = [ - e.expr.set_results_name(e.resultsName, list_all_matches=True) - for e in self.exprs - if isinstance(e, _MultipleMatch) - ] - self.multirequired = [ - e.expr.set_results_name(e.resultsName, list_all_matches=True) - for e in self.exprs - if isinstance(e, OneOrMore) - ] - self.required = [ - e for e in self.exprs if not isinstance(e, (Opt, ZeroOrMore, OneOrMore)) - ] - self.required += self.multirequired - self.initExprGroups = False - - tmpLoc = loc - tmpReqd = self.required[:] - tmpOpt = self.optionals[:] - multis = self.multioptionals[:] - matchOrder = [] - - keepMatching = True - failed = [] - fatals = [] - while keepMatching: - tmpExprs = tmpReqd + tmpOpt + multis - failed.clear() - fatals.clear() - for e in tmpExprs: - try: - tmpLoc = e.try_parse(instring, tmpLoc, raise_fatal=True) - except ParseFatalException as pfe: - pfe.__traceback__ = None - pfe.parser_element = e - fatals.append(pfe) - failed.append(e) - except ParseException: - failed.append(e) - else: - matchOrder.append(self.opt1map.get(id(e), e)) - if e in tmpReqd: - tmpReqd.remove(e) - elif e in tmpOpt: - tmpOpt.remove(e) - if len(failed) == len(tmpExprs): - keepMatching = False - - # look for any ParseFatalExceptions - if fatals: - if len(fatals) > 1: - fatals.sort(key=lambda e: -e.loc) - if fatals[0].loc == fatals[1].loc: - fatals.sort(key=lambda e: (-e.loc, -len(str(e.parser_element)))) - max_fatal = fatals[0] - raise max_fatal - - if tmpReqd: - missing = ", ".join([str(e) for e in tmpReqd]) - raise ParseException( - instring, - loc, - f"Missing one or more required elements ({missing})", - ) - - # add any unmatched Opts, in case they have default values defined - matchOrder += [e for e in self.exprs if isinstance(e, Opt) and e.expr in tmpOpt] - - total_results = ParseResults([]) - for e in matchOrder: - loc, results = e._parse(instring, loc, doActions) - total_results += results - - return loc, total_results - - def _generateDefaultName(self) -> str: - return "{" + " & ".join(str(e) for e in self.exprs) + "}" - - -class ParseElementEnhance(ParserElement): - """Abstract subclass of :class:`ParserElement`, for combining and - post-processing parsed tokens. - """ - - def __init__(self, expr: Union[ParserElement, str], savelist: bool = False): - super().__init__(savelist) - if isinstance(expr, str_type): - expr_str = typing.cast(str, expr) - if issubclass(self._literalStringClass, Token): - expr = self._literalStringClass(expr_str) # type: ignore[call-arg] - elif issubclass(type(self), self._literalStringClass): - expr = Literal(expr_str) - else: - expr = self._literalStringClass(Literal(expr_str)) # type: ignore[assignment, call-arg] - expr = typing.cast(ParserElement, expr) - self.expr = expr - if expr is not None: - self.mayIndexError = expr.mayIndexError - self.mayReturnEmpty = expr.mayReturnEmpty - self.set_whitespace_chars( - expr.whiteChars, copy_defaults=expr.copyDefaultWhiteChars - ) - self.skipWhitespace = expr.skipWhitespace - self.saveAsList = expr.saveAsList - self.callPreparse = expr.callPreparse - self.ignoreExprs.extend(expr.ignoreExprs) - - def recurse(self) -> List[ParserElement]: - return [self.expr] if self.expr is not None else [] - - def parseImpl(self, instring, loc, doActions=True): - if self.expr is not None: - try: - return self.expr._parse(instring, loc, doActions, callPreParse=False) - except ParseBaseException as pbe: - pbe.msg = self.errmsg - raise - else: - raise ParseException(instring, loc, "No expression defined", self) - - def leave_whitespace(self, recursive: bool = True) -> ParserElement: - super().leave_whitespace(recursive) - - if recursive: - if self.expr is not None: - self.expr = self.expr.copy() - self.expr.leave_whitespace(recursive) - return self - - def ignore_whitespace(self, recursive: bool = True) -> ParserElement: - super().ignore_whitespace(recursive) - - if recursive: - if self.expr is not None: - self.expr = self.expr.copy() - self.expr.ignore_whitespace(recursive) - return self - - def ignore(self, other) -> ParserElement: - if isinstance(other, Suppress): - if other not in self.ignoreExprs: - super().ignore(other) - if self.expr is not None: - self.expr.ignore(self.ignoreExprs[-1]) - else: - super().ignore(other) - if self.expr is not None: - self.expr.ignore(self.ignoreExprs[-1]) - return self - - def streamline(self) -> ParserElement: - super().streamline() - if self.expr is not None: - self.expr.streamline() - return self - - def _checkRecursion(self, parseElementList): - if self in parseElementList: - raise RecursiveGrammarException(parseElementList + [self]) - subRecCheckList = parseElementList[:] + [self] - if self.expr is not None: - self.expr._checkRecursion(subRecCheckList) - - def validate(self, validateTrace=None) -> None: - warnings.warn( - "ParserElement.validate() is deprecated, and should not be used to check for left recursion", - DeprecationWarning, - stacklevel=2, - ) - if validateTrace is None: - validateTrace = [] - tmp = validateTrace[:] + [self] - if self.expr is not None: - self.expr.validate(tmp) - self._checkRecursion([]) - - def _generateDefaultName(self) -> str: - return f"{self.__class__.__name__}:({str(self.expr)})" - - # Compatibility synonyms - # fmt: off - @replaced_by_pep8(leave_whitespace) - def leaveWhitespace(self): ... - - @replaced_by_pep8(ignore_whitespace) - def ignoreWhitespace(self): ... - # fmt: on - - -class IndentedBlock(ParseElementEnhance): - """ - Expression to match one or more expressions at a given indentation level. - Useful for parsing text where structure is implied by indentation (like Python source code). - """ - - class _Indent(Empty): - def __init__(self, ref_col: int): - super().__init__() - self.errmsg = f"expected indent at column {ref_col}" - self.add_condition(lambda s, l, t: col(l, s) == ref_col) - - class _IndentGreater(Empty): - def __init__(self, ref_col: int): - super().__init__() - self.errmsg = f"expected indent at column greater than {ref_col}" - self.add_condition(lambda s, l, t: col(l, s) > ref_col) - - def __init__( - self, expr: ParserElement, *, recursive: bool = False, grouped: bool = True - ): - super().__init__(expr, savelist=True) - # if recursive: - # raise NotImplementedError("IndentedBlock with recursive is not implemented") - self._recursive = recursive - self._grouped = grouped - self.parent_anchor = 1 - - def parseImpl(self, instring, loc, doActions=True): - # advance parse position to non-whitespace by using an Empty() - # this should be the column to be used for all subsequent indented lines - anchor_loc = Empty().preParse(instring, loc) - - # see if self.expr matches at the current location - if not it will raise an exception - # and no further work is necessary - self.expr.try_parse(instring, anchor_loc, do_actions=doActions) - - indent_col = col(anchor_loc, instring) - peer_detect_expr = self._Indent(indent_col) - - inner_expr = Empty() + peer_detect_expr + self.expr - if self._recursive: - sub_indent = self._IndentGreater(indent_col) - nested_block = IndentedBlock( - self.expr, recursive=self._recursive, grouped=self._grouped - ) - nested_block.set_debug(self.debug) - nested_block.parent_anchor = indent_col - inner_expr += Opt(sub_indent + nested_block) - - inner_expr.set_name(f"inner {hex(id(inner_expr))[-4:].upper()}@{indent_col}") - block = OneOrMore(inner_expr) - - trailing_undent = self._Indent(self.parent_anchor) | StringEnd() - - if self._grouped: - wrapper = Group - else: - wrapper = lambda expr: expr - return (wrapper(block) + Optional(trailing_undent)).parseImpl( - instring, anchor_loc, doActions - ) - - -class AtStringStart(ParseElementEnhance): - """Matches if expression matches at the beginning of the parse - string:: - - AtStringStart(Word(nums)).parse_string("123") - # prints ["123"] - - AtStringStart(Word(nums)).parse_string(" 123") - # raises ParseException - """ - - def __init__(self, expr: Union[ParserElement, str]): - super().__init__(expr) - self.callPreparse = False - - def parseImpl(self, instring, loc, doActions=True): - if loc != 0: - raise ParseException(instring, loc, "not found at string start") - return super().parseImpl(instring, loc, doActions) - - -class AtLineStart(ParseElementEnhance): - r"""Matches if an expression matches at the beginning of a line within - the parse string - - Example:: - - test = '''\ - AAA this line - AAA and this line - AAA but not this one - B AAA and definitely not this one - ''' - - for t in (AtLineStart('AAA') + rest_of_line).search_string(test): - print(t) - - prints:: - - ['AAA', ' this line'] - ['AAA', ' and this line'] - - """ - - def __init__(self, expr: Union[ParserElement, str]): - super().__init__(expr) - self.callPreparse = False - - def parseImpl(self, instring, loc, doActions=True): - if col(loc, instring) != 1: - raise ParseException(instring, loc, "not found at line start") - return super().parseImpl(instring, loc, doActions) - - -class FollowedBy(ParseElementEnhance): - """Lookahead matching of the given parse expression. - ``FollowedBy`` does *not* advance the parsing position within - the input string, it only verifies that the specified parse - expression matches at the current position. ``FollowedBy`` - always returns a null token list. If any results names are defined - in the lookahead expression, those *will* be returned for access by - name. - - Example:: - - # use FollowedBy to match a label only if it is followed by a ':' - data_word = Word(alphas) - label = data_word + FollowedBy(':') - attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stop_on=label).set_parse_action(' '.join)) - - attr_expr[1, ...].parse_string("shape: SQUARE color: BLACK posn: upper left").pprint() - - prints:: - - [['shape', 'SQUARE'], ['color', 'BLACK'], ['posn', 'upper left']] - """ - - def __init__(self, expr: Union[ParserElement, str]): - super().__init__(expr) - self.mayReturnEmpty = True - - def parseImpl(self, instring, loc, doActions=True): - # by using self._expr.parse and deleting the contents of the returned ParseResults list - # we keep any named results that were defined in the FollowedBy expression - _, ret = self.expr._parse(instring, loc, doActions=doActions) - del ret[:] - - return loc, ret - - -class PrecededBy(ParseElementEnhance): - """Lookbehind matching of the given parse expression. - ``PrecededBy`` does not advance the parsing position within the - input string, it only verifies that the specified parse expression - matches prior to the current position. ``PrecededBy`` always - returns a null token list, but if a results name is defined on the - given expression, it is returned. - - Parameters: - - - ``expr`` - expression that must match prior to the current parse - location - - ``retreat`` - (default= ``None``) - (int) maximum number of characters - to lookbehind prior to the current parse location - - If the lookbehind expression is a string, :class:`Literal`, - :class:`Keyword`, or a :class:`Word` or :class:`CharsNotIn` - with a specified exact or maximum length, then the retreat - parameter is not required. Otherwise, retreat must be specified to - give a maximum number of characters to look back from - the current parse position for a lookbehind match. - - Example:: - - # VB-style variable names with type prefixes - int_var = PrecededBy("#") + pyparsing_common.identifier - str_var = PrecededBy("$") + pyparsing_common.identifier - - """ - - def __init__( - self, expr: Union[ParserElement, str], retreat: typing.Optional[int] = None - ): - super().__init__(expr) - self.expr = self.expr().leave_whitespace() - self.mayReturnEmpty = True - self.mayIndexError = False - self.exact = False - if isinstance(expr, str_type): - expr = typing.cast(str, expr) - retreat = len(expr) - self.exact = True - elif isinstance(expr, (Literal, Keyword)): - retreat = expr.matchLen - self.exact = True - elif isinstance(expr, (Word, CharsNotIn)) and expr.maxLen != _MAX_INT: - retreat = expr.maxLen - self.exact = True - elif isinstance(expr, PositionToken): - retreat = 0 - self.exact = True - self.retreat = retreat - self.errmsg = "not preceded by " + str(expr) - self.skipWhitespace = False - self.parseAction.append(lambda s, l, t: t.__delitem__(slice(None, None))) - - def parseImpl(self, instring, loc=0, doActions=True): - if self.exact: - if loc < self.retreat: - raise ParseException(instring, loc, self.errmsg) - start = loc - self.retreat - _, ret = self.expr._parse(instring, start) - else: - # retreat specified a maximum lookbehind window, iterate - test_expr = self.expr + StringEnd() - instring_slice = instring[max(0, loc - self.retreat) : loc] - last_expr = ParseException(instring, loc, self.errmsg) - for offset in range(1, min(loc, self.retreat + 1) + 1): - try: - # print('trying', offset, instring_slice, repr(instring_slice[loc - offset:])) - _, ret = test_expr._parse( - instring_slice, len(instring_slice) - offset - ) - except ParseBaseException as pbe: - last_expr = pbe - else: - break - else: - raise last_expr - return loc, ret - - -class Located(ParseElementEnhance): - """ - Decorates a returned token with its starting and ending - locations in the input string. - - This helper adds the following results names: - - - ``locn_start`` - location where matched expression begins - - ``locn_end`` - location where matched expression ends - - ``value`` - the actual parsed results - - Be careful if the input text contains ```` characters, you - may want to call :class:`ParserElement.parse_with_tabs` - - Example:: - - wd = Word(alphas) - for match in Located(wd).search_string("ljsdf123lksdjjf123lkkjj1222"): - print(match) - - prints:: - - [0, ['ljsdf'], 5] - [8, ['lksdjjf'], 15] - [18, ['lkkjj'], 23] - - """ - - def parseImpl(self, instring, loc, doActions=True): - start = loc - loc, tokens = self.expr._parse(instring, start, doActions, callPreParse=False) - ret_tokens = ParseResults([start, tokens, loc]) - ret_tokens["locn_start"] = start - ret_tokens["value"] = tokens - ret_tokens["locn_end"] = loc - if self.resultsName: - # must return as a list, so that the name will be attached to the complete group - return loc, [ret_tokens] - else: - return loc, ret_tokens - - -class NotAny(ParseElementEnhance): - """ - Lookahead to disallow matching with the given parse expression. - ``NotAny`` does *not* advance the parsing position within the - input string, it only verifies that the specified parse expression - does *not* match at the current position. Also, ``NotAny`` does - *not* skip over leading whitespace. ``NotAny`` always returns - a null token list. May be constructed using the ``'~'`` operator. - - Example:: - - AND, OR, NOT = map(CaselessKeyword, "AND OR NOT".split()) - - # take care not to mistake keywords for identifiers - ident = ~(AND | OR | NOT) + Word(alphas) - boolean_term = Opt(NOT) + ident - - # very crude boolean expression - to support parenthesis groups and - # operation hierarchy, use infix_notation - boolean_expr = boolean_term + ((AND | OR) + boolean_term)[...] - - # integers that are followed by "." are actually floats - integer = Word(nums) + ~Char(".") - """ - - def __init__(self, expr: Union[ParserElement, str]): - super().__init__(expr) - # do NOT use self.leave_whitespace(), don't want to propagate to exprs - # self.leave_whitespace() - self.skipWhitespace = False - - self.mayReturnEmpty = True - self.errmsg = "Found unwanted token, " + str(self.expr) - - def parseImpl(self, instring, loc, doActions=True): - if self.expr.can_parse_next(instring, loc, do_actions=doActions): - raise ParseException(instring, loc, self.errmsg, self) - return loc, [] - - def _generateDefaultName(self) -> str: - return "~{" + str(self.expr) + "}" - - -class _MultipleMatch(ParseElementEnhance): - def __init__( - self, - expr: Union[str, ParserElement], - stop_on: typing.Optional[Union[ParserElement, str]] = None, - *, - stopOn: typing.Optional[Union[ParserElement, str]] = None, - ): - super().__init__(expr) - stopOn = stopOn or stop_on - self.saveAsList = True - ender = stopOn - if isinstance(ender, str_type): - ender = self._literalStringClass(ender) - self.stopOn(ender) - - def stopOn(self, ender) -> ParserElement: - if isinstance(ender, str_type): - ender = self._literalStringClass(ender) - self.not_ender = ~ender if ender is not None else None - return self - - def parseImpl(self, instring, loc, doActions=True): - self_expr_parse = self.expr._parse - self_skip_ignorables = self._skipIgnorables - check_ender = self.not_ender is not None - if check_ender: - try_not_ender = self.not_ender.try_parse - - # must be at least one (but first see if we are the stopOn sentinel; - # if so, fail) - if check_ender: - try_not_ender(instring, loc) - loc, tokens = self_expr_parse(instring, loc, doActions) - try: - hasIgnoreExprs = not not self.ignoreExprs - while 1: - if check_ender: - try_not_ender(instring, loc) - if hasIgnoreExprs: - preloc = self_skip_ignorables(instring, loc) - else: - preloc = loc - loc, tmptokens = self_expr_parse(instring, preloc, doActions) - tokens += tmptokens - except (ParseException, IndexError): - pass - - return loc, tokens - - def _setResultsName(self, name, listAllMatches=False): - if ( - __diag__.warn_ungrouped_named_tokens_in_collection - and Diagnostics.warn_ungrouped_named_tokens_in_collection - not in self.suppress_warnings_ - ): - for e in [self.expr] + self.expr.recurse(): - if ( - isinstance(e, ParserElement) - and e.resultsName - and Diagnostics.warn_ungrouped_named_tokens_in_collection - not in e.suppress_warnings_ - ): - warnings.warn( - "{}: setting results name {!r} on {} expression " - "collides with {!r} on contained expression".format( - "warn_ungrouped_named_tokens_in_collection", - name, - type(self).__name__, - e.resultsName, - ), - stacklevel=3, - ) - - return super()._setResultsName(name, listAllMatches) - - -class OneOrMore(_MultipleMatch): - """ - Repetition of one or more of the given expression. - - Parameters: - - - ``expr`` - expression that must match one or more times - - ``stop_on`` - (default= ``None``) - expression for a terminating sentinel - (only required if the sentinel would ordinarily match the repetition - expression) - - Example:: - - data_word = Word(alphas) - label = data_word + FollowedBy(':') - attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).set_parse_action(' '.join)) - - text = "shape: SQUARE posn: upper left color: BLACK" - attr_expr[1, ...].parse_string(text).pprint() # Fail! read 'color' as data instead of next label -> [['shape', 'SQUARE color']] - - # use stop_on attribute for OneOrMore to avoid reading label string as part of the data - attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stop_on=label).set_parse_action(' '.join)) - OneOrMore(attr_expr).parse_string(text).pprint() # Better -> [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'BLACK']] - - # could also be written as - (attr_expr * (1,)).parse_string(text).pprint() - """ - - def _generateDefaultName(self) -> str: - return "{" + str(self.expr) + "}..." - - -class ZeroOrMore(_MultipleMatch): - """ - Optional repetition of zero or more of the given expression. - - Parameters: - - - ``expr`` - expression that must match zero or more times - - ``stop_on`` - expression for a terminating sentinel - (only required if the sentinel would ordinarily match the repetition - expression) - (default= ``None``) - - Example: similar to :class:`OneOrMore` - """ - - def __init__( - self, - expr: Union[str, ParserElement], - stop_on: typing.Optional[Union[ParserElement, str]] = None, - *, - stopOn: typing.Optional[Union[ParserElement, str]] = None, - ): - super().__init__(expr, stopOn=stopOn or stop_on) - self.mayReturnEmpty = True - - def parseImpl(self, instring, loc, doActions=True): - try: - return super().parseImpl(instring, loc, doActions) - except (ParseException, IndexError): - return loc, ParseResults([], name=self.resultsName) - - def _generateDefaultName(self) -> str: - return "[" + str(self.expr) + "]..." - - -class DelimitedList(ParseElementEnhance): - def __init__( - self, - expr: Union[str, ParserElement], - delim: Union[str, ParserElement] = ",", - combine: bool = False, - min: typing.Optional[int] = None, - max: typing.Optional[int] = None, - *, - allow_trailing_delim: bool = False, - ): - """Helper to define a delimited list of expressions - the delimiter - defaults to ','. By default, the list elements and delimiters can - have intervening whitespace, and comments, but this can be - overridden by passing ``combine=True`` in the constructor. If - ``combine`` is set to ``True``, the matching tokens are - returned as a single token string, with the delimiters included; - otherwise, the matching tokens are returned as a list of tokens, - with the delimiters suppressed. - - If ``allow_trailing_delim`` is set to True, then the list may end with - a delimiter. - - Example:: - - DelimitedList(Word(alphas)).parse_string("aa,bb,cc") # -> ['aa', 'bb', 'cc'] - DelimitedList(Word(hexnums), delim=':', combine=True).parse_string("AA:BB:CC:DD:EE") # -> ['AA:BB:CC:DD:EE'] - """ - if isinstance(expr, str_type): - expr = ParserElement._literalStringClass(expr) - expr = typing.cast(ParserElement, expr) - - if min is not None: - if min < 1: - raise ValueError("min must be greater than 0") - if max is not None: - if min is not None and max < min: - raise ValueError("max must be greater than, or equal to min") - - self.content = expr - self.raw_delim = str(delim) - self.delim = delim - self.combine = combine - if not combine: - self.delim = Suppress(delim) - self.min = min or 1 - self.max = max - self.allow_trailing_delim = allow_trailing_delim - - delim_list_expr = self.content + (self.delim + self.content) * ( - self.min - 1, - None if self.max is None else self.max - 1, - ) - if self.allow_trailing_delim: - delim_list_expr += Opt(self.delim) - - if self.combine: - delim_list_expr = Combine(delim_list_expr) - - super().__init__(delim_list_expr, savelist=True) - - def _generateDefaultName(self) -> str: - return "{0} [{1} {0}]...".format(self.content.streamline(), self.raw_delim) - - -class _NullToken: - def __bool__(self): - return False - - def __str__(self): - return "" - - -class Opt(ParseElementEnhance): - """ - Optional matching of the given expression. - - Parameters: - - - ``expr`` - expression that must match zero or more times - - ``default`` (optional) - value to be returned if the optional expression is not found. - - Example:: - - # US postal code can be a 5-digit zip, plus optional 4-digit qualifier - zip = Combine(Word(nums, exact=5) + Opt('-' + Word(nums, exact=4))) - zip.run_tests(''' - # traditional ZIP code - 12345 - - # ZIP+4 form - 12101-0001 - - # invalid ZIP - 98765- - ''') - - prints:: - - # traditional ZIP code - 12345 - ['12345'] - - # ZIP+4 form - 12101-0001 - ['12101-0001'] - - # invalid ZIP - 98765- - ^ - FAIL: Expected end of text (at char 5), (line:1, col:6) - """ - - __optionalNotMatched = _NullToken() - - def __init__( - self, expr: Union[ParserElement, str], default: Any = __optionalNotMatched - ): - super().__init__(expr, savelist=False) - self.saveAsList = self.expr.saveAsList - self.defaultValue = default - self.mayReturnEmpty = True - - def parseImpl(self, instring, loc, doActions=True): - self_expr = self.expr - try: - loc, tokens = self_expr._parse(instring, loc, doActions, callPreParse=False) - except (ParseException, IndexError): - default_value = self.defaultValue - if default_value is not self.__optionalNotMatched: - if self_expr.resultsName: - tokens = ParseResults([default_value]) - tokens[self_expr.resultsName] = default_value - else: - tokens = [default_value] - else: - tokens = [] - return loc, tokens - - def _generateDefaultName(self) -> str: - inner = str(self.expr) - # strip off redundant inner {}'s - while len(inner) > 1 and inner[0 :: len(inner) - 1] == "{}": - inner = inner[1:-1] - return "[" + inner + "]" - - -Optional = Opt - - -class SkipTo(ParseElementEnhance): - """ - Token for skipping over all undefined text until the matched - expression is found. - - Parameters: - - - ``expr`` - target expression marking the end of the data to be skipped - - ``include`` - if ``True``, the target expression is also parsed - (the skipped text and target expression are returned as a 2-element - list) (default= ``False``). - - ``ignore`` - (default= ``None``) used to define grammars (typically quoted strings and - comments) that might contain false matches to the target expression - - ``fail_on`` - (default= ``None``) define expressions that are not allowed to be - included in the skipped test; if found before the target expression is found, - the :class:`SkipTo` is not a match - - Example:: - - report = ''' - Outstanding Issues Report - 1 Jan 2000 - - # | Severity | Description | Days Open - -----+----------+-------------------------------------------+----------- - 101 | Critical | Intermittent system crash | 6 - 94 | Cosmetic | Spelling error on Login ('log|n') | 14 - 79 | Minor | System slow when running too many reports | 47 - ''' - integer = Word(nums) - SEP = Suppress('|') - # use SkipTo to simply match everything up until the next SEP - # - ignore quoted strings, so that a '|' character inside a quoted string does not match - # - parse action will call token.strip() for each matched token, i.e., the description body - string_data = SkipTo(SEP, ignore=quoted_string) - string_data.set_parse_action(token_map(str.strip)) - ticket_expr = (integer("issue_num") + SEP - + string_data("sev") + SEP - + string_data("desc") + SEP - + integer("days_open")) - - for tkt in ticket_expr.search_string(report): - print tkt.dump() - - prints:: - - ['101', 'Critical', 'Intermittent system crash', '6'] - - days_open: '6' - - desc: 'Intermittent system crash' - - issue_num: '101' - - sev: 'Critical' - ['94', 'Cosmetic', "Spelling error on Login ('log|n')", '14'] - - days_open: '14' - - desc: "Spelling error on Login ('log|n')" - - issue_num: '94' - - sev: 'Cosmetic' - ['79', 'Minor', 'System slow when running too many reports', '47'] - - days_open: '47' - - desc: 'System slow when running too many reports' - - issue_num: '79' - - sev: 'Minor' - """ - - def __init__( - self, - other: Union[ParserElement, str], - include: bool = False, - ignore: typing.Optional[Union[ParserElement, str]] = None, - fail_on: typing.Optional[Union[ParserElement, str]] = None, - *, - failOn: typing.Optional[Union[ParserElement, str]] = None, - ): - super().__init__(other) - failOn = failOn or fail_on - if ignore is not None: - self.ignore(ignore) - self.mayReturnEmpty = True - self.mayIndexError = False - self.includeMatch = include - self.saveAsList = False - if isinstance(failOn, str_type): - self.failOn = self._literalStringClass(failOn) - else: - self.failOn = failOn - self.errmsg = "No match found for " + str(self.expr) - - def parseImpl(self, instring, loc, doActions=True): - startloc = loc - instrlen = len(instring) - self_expr_parse = self.expr._parse - self_failOn_canParseNext = ( - self.failOn.canParseNext if self.failOn is not None else None - ) - self_preParse = self.preParse if self.callPreparse else None - - tmploc = loc - while tmploc <= instrlen: - if self_failOn_canParseNext is not None: - # break if failOn expression matches - if self_failOn_canParseNext(instring, tmploc): - break - - if self_preParse is not None: - # skip grammar-ignored expressions - tmploc = self_preParse(instring, tmploc) - - try: - self_expr_parse(instring, tmploc, doActions=False, callPreParse=False) - except (ParseException, IndexError): - # no match, advance loc in string - tmploc += 1 - else: - # matched skipto expr, done - break - - else: - # ran off the end of the input string without matching skipto expr, fail - raise ParseException(instring, loc, self.errmsg, self) - - # build up return values - loc = tmploc - skiptext = instring[startloc:loc] - skipresult = ParseResults(skiptext) - - if self.includeMatch: - loc, mat = self_expr_parse(instring, loc, doActions, callPreParse=False) - skipresult += mat - - return loc, skipresult - - -class Forward(ParseElementEnhance): - """ - Forward declaration of an expression to be defined later - - used for recursive grammars, such as algebraic infix notation. - When the expression is known, it is assigned to the ``Forward`` - variable using the ``'<<'`` operator. - - Note: take care when assigning to ``Forward`` not to overlook - precedence of operators. - - Specifically, ``'|'`` has a lower precedence than ``'<<'``, so that:: - - fwd_expr << a | b | c - - will actually be evaluated as:: - - (fwd_expr << a) | b | c - - thereby leaving b and c out as parseable alternatives. It is recommended that you - explicitly group the values inserted into the ``Forward``:: - - fwd_expr << (a | b | c) - - Converting to use the ``'<<='`` operator instead will avoid this problem. - - See :class:`ParseResults.pprint` for an example of a recursive - parser created using ``Forward``. - """ - - def __init__(self, other: typing.Optional[Union[ParserElement, str]] = None): - self.caller_frame = traceback.extract_stack(limit=2)[0] - super().__init__(other, savelist=False) # type: ignore[arg-type] - self.lshift_line = None - - def __lshift__(self, other) -> "Forward": - if hasattr(self, "caller_frame"): - del self.caller_frame - if isinstance(other, str_type): - other = self._literalStringClass(other) - - if not isinstance(other, ParserElement): - return NotImplemented - - self.expr = other - self.streamlined = other.streamlined - self.mayIndexError = self.expr.mayIndexError - self.mayReturnEmpty = self.expr.mayReturnEmpty - self.set_whitespace_chars( - self.expr.whiteChars, copy_defaults=self.expr.copyDefaultWhiteChars - ) - self.skipWhitespace = self.expr.skipWhitespace - self.saveAsList = self.expr.saveAsList - self.ignoreExprs.extend(self.expr.ignoreExprs) - self.lshift_line = traceback.extract_stack(limit=2)[-2] # type: ignore[assignment] - return self - - def __ilshift__(self, other) -> "Forward": - if not isinstance(other, ParserElement): - return NotImplemented - - return self << other - - def __or__(self, other) -> "ParserElement": - caller_line = traceback.extract_stack(limit=2)[-2] - if ( - __diag__.warn_on_match_first_with_lshift_operator - and caller_line == self.lshift_line - and Diagnostics.warn_on_match_first_with_lshift_operator - not in self.suppress_warnings_ - ): - warnings.warn( - "using '<<' operator with '|' is probably an error, use '<<='", - stacklevel=2, - ) - ret = super().__or__(other) - return ret - - def __del__(self): - # see if we are getting dropped because of '=' reassignment of var instead of '<<=' or '<<' - if ( - self.expr is None - and __diag__.warn_on_assignment_to_Forward - and Diagnostics.warn_on_assignment_to_Forward not in self.suppress_warnings_ - ): - warnings.warn_explicit( - "Forward defined here but no expression attached later using '<<=' or '<<'", - UserWarning, - filename=self.caller_frame.filename, - lineno=self.caller_frame.lineno, - ) - - def parseImpl(self, instring, loc, doActions=True): - if ( - self.expr is None - and __diag__.warn_on_parse_using_empty_Forward - and Diagnostics.warn_on_parse_using_empty_Forward - not in self.suppress_warnings_ - ): - # walk stack until parse_string, scan_string, search_string, or transform_string is found - parse_fns = ( - "parse_string", - "scan_string", - "search_string", - "transform_string", - ) - tb = traceback.extract_stack(limit=200) - for i, frm in enumerate(reversed(tb), start=1): - if frm.name in parse_fns: - stacklevel = i + 1 - break - else: - stacklevel = 2 - warnings.warn( - "Forward expression was never assigned a value, will not parse any input", - stacklevel=stacklevel, - ) - if not ParserElement._left_recursion_enabled: - return super().parseImpl(instring, loc, doActions) - # ## Bounded Recursion algorithm ## - # Recursion only needs to be processed at ``Forward`` elements, since they are - # the only ones that can actually refer to themselves. The general idea is - # to handle recursion stepwise: We start at no recursion, then recurse once, - # recurse twice, ..., until more recursion offers no benefit (we hit the bound). - # - # The "trick" here is that each ``Forward`` gets evaluated in two contexts - # - to *match* a specific recursion level, and - # - to *search* the bounded recursion level - # and the two run concurrently. The *search* must *match* each recursion level - # to find the best possible match. This is handled by a memo table, which - # provides the previous match to the next level match attempt. - # - # See also "Left Recursion in Parsing Expression Grammars", Medeiros et al. - # - # There is a complication since we not only *parse* but also *transform* via - # actions: We do not want to run the actions too often while expanding. Thus, - # we expand using `doActions=False` and only run `doActions=True` if the next - # recursion level is acceptable. - with ParserElement.recursion_lock: - memo = ParserElement.recursion_memos - try: - # we are parsing at a specific recursion expansion - use it as-is - prev_loc, prev_result = memo[loc, self, doActions] - if isinstance(prev_result, Exception): - raise prev_result - return prev_loc, prev_result.copy() - except KeyError: - act_key = (loc, self, True) - peek_key = (loc, self, False) - # we are searching for the best recursion expansion - keep on improving - # both `doActions` cases must be tracked separately here! - prev_loc, prev_peek = memo[peek_key] = ( - loc - 1, - ParseException( - instring, loc, "Forward recursion without base case", self - ), - ) - if doActions: - memo[act_key] = memo[peek_key] - while True: - try: - new_loc, new_peek = super().parseImpl(instring, loc, False) - except ParseException: - # we failed before getting any match – do not hide the error - if isinstance(prev_peek, Exception): - raise - new_loc, new_peek = prev_loc, prev_peek - # the match did not get better: we are done - if new_loc <= prev_loc: - if doActions: - # replace the match for doActions=False as well, - # in case the action did backtrack - prev_loc, prev_result = memo[peek_key] = memo[act_key] - del memo[peek_key], memo[act_key] - return prev_loc, prev_result.copy() - del memo[peek_key] - return prev_loc, prev_peek.copy() - # the match did get better: see if we can improve further - else: - if doActions: - try: - memo[act_key] = super().parseImpl(instring, loc, True) - except ParseException as e: - memo[peek_key] = memo[act_key] = (new_loc, e) - raise - prev_loc, prev_peek = memo[peek_key] = new_loc, new_peek - - def leave_whitespace(self, recursive: bool = True) -> ParserElement: - self.skipWhitespace = False - return self - - def ignore_whitespace(self, recursive: bool = True) -> ParserElement: - self.skipWhitespace = True - return self - - def streamline(self) -> ParserElement: - if not self.streamlined: - self.streamlined = True - if self.expr is not None: - self.expr.streamline() - return self - - def validate(self, validateTrace=None) -> None: - warnings.warn( - "ParserElement.validate() is deprecated, and should not be used to check for left recursion", - DeprecationWarning, - stacklevel=2, - ) - if validateTrace is None: - validateTrace = [] - - if self not in validateTrace: - tmp = validateTrace[:] + [self] - if self.expr is not None: - self.expr.validate(tmp) - self._checkRecursion([]) - - def _generateDefaultName(self) -> str: - # Avoid infinite recursion by setting a temporary _defaultName - self._defaultName = ": ..." - - # Use the string representation of main expression. - retString = "..." - try: - if self.expr is not None: - retString = str(self.expr)[:1000] - else: - retString = "None" - finally: - return self.__class__.__name__ + ": " + retString - - def copy(self) -> ParserElement: - if self.expr is not None: - return super().copy() - else: - ret = Forward() - ret <<= self - return ret - - def _setResultsName(self, name, list_all_matches=False): - if ( - __diag__.warn_name_set_on_empty_Forward - and Diagnostics.warn_name_set_on_empty_Forward - not in self.suppress_warnings_ - ): - if self.expr is None: - warnings.warn( - "{}: setting results name {!r} on {} expression " - "that has no contained expression".format( - "warn_name_set_on_empty_Forward", name, type(self).__name__ - ), - stacklevel=3, - ) - - return super()._setResultsName(name, list_all_matches) - - # Compatibility synonyms - # fmt: off - @replaced_by_pep8(leave_whitespace) - def leaveWhitespace(self): ... - - @replaced_by_pep8(ignore_whitespace) - def ignoreWhitespace(self): ... - # fmt: on - - -class TokenConverter(ParseElementEnhance): - """ - Abstract subclass of :class:`ParseExpression`, for converting parsed results. - """ - - def __init__(self, expr: Union[ParserElement, str], savelist=False): - super().__init__(expr) # , savelist) - self.saveAsList = False - - -class Combine(TokenConverter): - """Converter to concatenate all matching tokens to a single string. - By default, the matching patterns must also be contiguous in the - input string; this can be disabled by specifying - ``'adjacent=False'`` in the constructor. - - Example:: - - real = Word(nums) + '.' + Word(nums) - print(real.parse_string('3.1416')) # -> ['3', '.', '1416'] - # will also erroneously match the following - print(real.parse_string('3. 1416')) # -> ['3', '.', '1416'] - - real = Combine(Word(nums) + '.' + Word(nums)) - print(real.parse_string('3.1416')) # -> ['3.1416'] - # no match when there are internal spaces - print(real.parse_string('3. 1416')) # -> Exception: Expected W:(0123...) - """ - - def __init__( - self, - expr: ParserElement, - join_string: str = "", - adjacent: bool = True, - *, - joinString: typing.Optional[str] = None, - ): - super().__init__(expr) - joinString = joinString if joinString is not None else join_string - # suppress whitespace-stripping in contained parse expressions, but re-enable it on the Combine itself - if adjacent: - self.leave_whitespace() - self.adjacent = adjacent - self.skipWhitespace = True - self.joinString = joinString - self.callPreparse = True - - def ignore(self, other) -> ParserElement: - if self.adjacent: - ParserElement.ignore(self, other) - else: - super().ignore(other) - return self - - def postParse(self, instring, loc, tokenlist): - retToks = tokenlist.copy() - del retToks[:] - retToks += ParseResults( - ["".join(tokenlist._asStringList(self.joinString))], modal=self.modalResults - ) - - if self.resultsName and retToks.haskeys(): - return [retToks] - else: - return retToks - - -class Group(TokenConverter): - """Converter to return the matched tokens as a list - useful for - returning tokens of :class:`ZeroOrMore` and :class:`OneOrMore` expressions. - - The optional ``aslist`` argument when set to True will return the - parsed tokens as a Python list instead of a pyparsing ParseResults. - - Example:: - - ident = Word(alphas) - num = Word(nums) - term = ident | num - func = ident + Opt(DelimitedList(term)) - print(func.parse_string("fn a, b, 100")) - # -> ['fn', 'a', 'b', '100'] - - func = ident + Group(Opt(DelimitedList(term))) - print(func.parse_string("fn a, b, 100")) - # -> ['fn', ['a', 'b', '100']] - """ - - def __init__(self, expr: ParserElement, aslist: bool = False): - super().__init__(expr) - self.saveAsList = True - self._asPythonList = aslist - - def postParse(self, instring, loc, tokenlist): - if self._asPythonList: - return ParseResults.List( - tokenlist.asList() - if isinstance(tokenlist, ParseResults) - else list(tokenlist) - ) - else: - return [tokenlist] - - -class Dict(TokenConverter): - """Converter to return a repetitive expression as a list, but also - as a dictionary. Each element can also be referenced using the first - token in the expression as its key. Useful for tabular report - scraping when the first column can be used as a item key. - - The optional ``asdict`` argument when set to True will return the - parsed tokens as a Python dict instead of a pyparsing ParseResults. - - Example:: - - data_word = Word(alphas) - label = data_word + FollowedBy(':') - - text = "shape: SQUARE posn: upper left color: light blue texture: burlap" - attr_expr = (label + Suppress(':') + OneOrMore(data_word, stop_on=label).set_parse_action(' '.join)) - - # print attributes as plain groups - print(attr_expr[1, ...].parse_string(text).dump()) - - # instead of OneOrMore(expr), parse using Dict(Group(expr)[1, ...]) - Dict will auto-assign names - result = Dict(Group(attr_expr)[1, ...]).parse_string(text) - print(result.dump()) - - # access named fields as dict entries, or output as dict - print(result['shape']) - print(result.as_dict()) - - prints:: - - ['shape', 'SQUARE', 'posn', 'upper left', 'color', 'light blue', 'texture', 'burlap'] - [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']] - - color: 'light blue' - - posn: 'upper left' - - shape: 'SQUARE' - - texture: 'burlap' - SQUARE - {'color': 'light blue', 'posn': 'upper left', 'texture': 'burlap', 'shape': 'SQUARE'} - - See more examples at :class:`ParseResults` of accessing fields by results name. - """ - - def __init__(self, expr: ParserElement, asdict: bool = False): - super().__init__(expr) - self.saveAsList = True - self._asPythonDict = asdict - - def postParse(self, instring, loc, tokenlist): - for i, tok in enumerate(tokenlist): - if len(tok) == 0: - continue - - ikey = tok[0] - if isinstance(ikey, int): - ikey = str(ikey).strip() - - if len(tok) == 1: - tokenlist[ikey] = _ParseResultsWithOffset("", i) - - elif len(tok) == 2 and not isinstance(tok[1], ParseResults): - tokenlist[ikey] = _ParseResultsWithOffset(tok[1], i) - - else: - try: - dictvalue = tok.copy() # ParseResults(i) - except Exception: - exc = TypeError( - "could not extract dict values from parsed results" - " - Dict expression must contain Grouped expressions" - ) - raise exc from None - - del dictvalue[0] - - if len(dictvalue) != 1 or ( - isinstance(dictvalue, ParseResults) and dictvalue.haskeys() - ): - tokenlist[ikey] = _ParseResultsWithOffset(dictvalue, i) - else: - tokenlist[ikey] = _ParseResultsWithOffset(dictvalue[0], i) - - if self._asPythonDict: - return [tokenlist.as_dict()] if self.resultsName else tokenlist.as_dict() - else: - return [tokenlist] if self.resultsName else tokenlist - - -class Suppress(TokenConverter): - """Converter for ignoring the results of a parsed expression. - - Example:: - - source = "a, b, c,d" - wd = Word(alphas) - wd_list1 = wd + (',' + wd)[...] - print(wd_list1.parse_string(source)) - - # often, delimiters that are useful during parsing are just in the - # way afterward - use Suppress to keep them out of the parsed output - wd_list2 = wd + (Suppress(',') + wd)[...] - print(wd_list2.parse_string(source)) - - # Skipped text (using '...') can be suppressed as well - source = "lead in START relevant text END trailing text" - start_marker = Keyword("START") - end_marker = Keyword("END") - find_body = Suppress(...) + start_marker + ... + end_marker - print(find_body.parse_string(source) - - prints:: - - ['a', ',', 'b', ',', 'c', ',', 'd'] - ['a', 'b', 'c', 'd'] - ['START', 'relevant text ', 'END'] - - (See also :class:`DelimitedList`.) - """ - - def __init__(self, expr: Union[ParserElement, str], savelist: bool = False): - if expr is ...: - expr = _PendingSkip(NoMatch()) - super().__init__(expr) - - def __add__(self, other) -> "ParserElement": - if isinstance(self.expr, _PendingSkip): - return Suppress(SkipTo(other)) + other - else: - return super().__add__(other) - - def __sub__(self, other) -> "ParserElement": - if isinstance(self.expr, _PendingSkip): - return Suppress(SkipTo(other)) - other - else: - return super().__sub__(other) - - def postParse(self, instring, loc, tokenlist): - return [] - - def suppress(self) -> ParserElement: - return self - - -def trace_parse_action(f: ParseAction) -> ParseAction: - """Decorator for debugging parse actions. - - When the parse action is called, this decorator will print - ``">> entering method-name(line:, , )"``. - When the parse action completes, the decorator will print - ``"<<"`` followed by the returned value, or any exception that the parse action raised. - - Example:: - - wd = Word(alphas) - - @trace_parse_action - def remove_duplicate_chars(tokens): - return ''.join(sorted(set(''.join(tokens)))) - - wds = wd[1, ...].set_parse_action(remove_duplicate_chars) - print(wds.parse_string("slkdjs sld sldd sdlf sdljf")) - - prints:: - - >>entering remove_duplicate_chars(line: 'slkdjs sld sldd sdlf sdljf', 0, (['slkdjs', 'sld', 'sldd', 'sdlf', 'sdljf'], {})) - < 3: - thisFunc = paArgs[0].__class__.__name__ + "." + thisFunc - sys.stderr.write(f">>entering {thisFunc}(line: {line(l, s)!r}, {l}, {t!r})\n") - try: - ret = f(*paArgs) - except Exception as exc: - sys.stderr.write(f"< str: - r"""Helper to easily define string ranges for use in :class:`Word` - construction. Borrows syntax from regexp ``'[]'`` string range - definitions:: - - srange("[0-9]") -> "0123456789" - srange("[a-z]") -> "abcdefghijklmnopqrstuvwxyz" - srange("[a-z$_]") -> "abcdefghijklmnopqrstuvwxyz$_" - - The input string must be enclosed in []'s, and the returned string - is the expanded character set joined into a single string. The - values enclosed in the []'s may be: - - - a single character - - an escaped character with a leading backslash (such as ``\-`` - or ``\]``) - - an escaped hex character with a leading ``'\x'`` - (``\x21``, which is a ``'!'`` character) (``\0x##`` - is also supported for backwards compatibility) - - an escaped octal character with a leading ``'\0'`` - (``\041``, which is a ``'!'`` character) - - a range of any of the above, separated by a dash (``'a-z'``, - etc.) - - any combination of the above (``'aeiouy'``, - ``'a-zA-Z0-9_$'``, etc.) - """ - _expanded = ( - lambda p: p - if not isinstance(p, ParseResults) - else "".join(chr(c) for c in range(ord(p[0]), ord(p[1]) + 1)) - ) - try: - return "".join(_expanded(part) for part in _reBracketExpr.parse_string(s).body) - except Exception as e: - return "" - - -def token_map(func, *args) -> ParseAction: - """Helper to define a parse action by mapping a function to all - elements of a :class:`ParseResults` list. If any additional args are passed, - they are forwarded to the given function as additional arguments - after the token, as in - ``hex_integer = Word(hexnums).set_parse_action(token_map(int, 16))``, - which will convert the parsed data to an integer using base 16. - - Example (compare the last to example in :class:`ParserElement.transform_string`:: - - hex_ints = Word(hexnums)[1, ...].set_parse_action(token_map(int, 16)) - hex_ints.run_tests(''' - 00 11 22 aa FF 0a 0d 1a - ''') - - upperword = Word(alphas).set_parse_action(token_map(str.upper)) - upperword[1, ...].run_tests(''' - my kingdom for a horse - ''') - - wd = Word(alphas).set_parse_action(token_map(str.title)) - wd[1, ...].set_parse_action(' '.join).run_tests(''' - now is the winter of our discontent made glorious summer by this sun of york - ''') - - prints:: - - 00 11 22 aa FF 0a 0d 1a - [0, 17, 34, 170, 255, 10, 13, 26] - - my kingdom for a horse - ['MY', 'KINGDOM', 'FOR', 'A', 'HORSE'] - - now is the winter of our discontent made glorious summer by this sun of york - ['Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York'] - """ - - def pa(s, l, t): - return [func(tokn, *args) for tokn in t] - - func_name = getattr(func, "__name__", getattr(func, "__class__").__name__) - pa.__name__ = func_name - - return pa - - -def autoname_elements() -> None: - """ - Utility to simplify mass-naming of parser elements, for - generating railroad diagram with named subdiagrams. - """ - calling_frame = sys._getframe().f_back - if calling_frame is None: - return - calling_frame = typing.cast(types.FrameType, calling_frame) - for name, var in calling_frame.f_locals.items(): - if isinstance(var, ParserElement) and not var.customName: - var.set_name(name) - - -dbl_quoted_string = Combine( - Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*') + '"' -).set_name("string enclosed in double quotes") - -sgl_quoted_string = Combine( - Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*") + "'" -).set_name("string enclosed in single quotes") - -quoted_string = Combine( - (Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*') + '"').set_name( - "double quoted string" - ) - | (Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*") + "'").set_name( - "single quoted string" - ) -).set_name("quoted string using single or double quotes") - -python_quoted_string = Combine( - (Regex(r'"""(?:[^"\\]|""(?!")|"(?!"")|\\.)*', flags=re.MULTILINE) + '"""').set_name( - "multiline double quoted string" - ) - ^ ( - Regex(r"'''(?:[^'\\]|''(?!')|'(?!'')|\\.)*", flags=re.MULTILINE) + "'''" - ).set_name("multiline single quoted string") - ^ (Regex(r'"(?:[^"\n\r\\]|(?:\\")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*') + '"').set_name( - "double quoted string" - ) - ^ (Regex(r"'(?:[^'\n\r\\]|(?:\\')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*") + "'").set_name( - "single quoted string" - ) -).set_name("Python quoted string") - -unicode_string = Combine("u" + quoted_string.copy()).set_name("unicode string literal") - - -alphas8bit = srange(r"[\0xc0-\0xd6\0xd8-\0xf6\0xf8-\0xff]") -punc8bit = srange(r"[\0xa1-\0xbf\0xd7\0xf7]") - -# build list of built-in expressions, for future reference if a global default value -# gets updated -_builtin_exprs: List[ParserElement] = [ - v for v in vars().values() if isinstance(v, ParserElement) -] - -# backward compatibility names -# fmt: off -sglQuotedString = sgl_quoted_string -dblQuotedString = dbl_quoted_string -quotedString = quoted_string -unicodeString = unicode_string -lineStart = line_start -lineEnd = line_end -stringStart = string_start -stringEnd = string_end - -@replaced_by_pep8(null_debug_action) -def nullDebugAction(): ... - -@replaced_by_pep8(trace_parse_action) -def traceParseAction(): ... - -@replaced_by_pep8(condition_as_parse_action) -def conditionAsParseAction(): ... - -@replaced_by_pep8(token_map) -def tokenMap(): ... -# fmt: on diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__init__.py b/myenv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__init__.py deleted file mode 100644 index 83f9018..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__init__.py +++ /dev/null @@ -1,656 +0,0 @@ -# mypy: ignore-errors -import railroad -from pip._vendor import pyparsing -import typing -from typing import ( - List, - NamedTuple, - Generic, - TypeVar, - Dict, - Callable, - Set, - Iterable, -) -from jinja2 import Template -from io import StringIO -import inspect - - -jinja2_template_source = """\ -{% if not embed %} - - - -{% endif %} - {% if not head %} - - {% else %} - {{ head | safe }} - {% endif %} -{% if not embed %} - - -{% endif %} -{{ body | safe }} -{% for diagram in diagrams %} -
-

{{ diagram.title }}

-
{{ diagram.text }}
-
- {{ diagram.svg }} -
-
-{% endfor %} -{% if not embed %} - - -{% endif %} -""" - -template = Template(jinja2_template_source) - -# Note: ideally this would be a dataclass, but we're supporting Python 3.5+ so we can't do this yet -NamedDiagram = NamedTuple( - "NamedDiagram", - [("name", str), ("diagram", typing.Optional[railroad.DiagramItem]), ("index", int)], -) -""" -A simple structure for associating a name with a railroad diagram -""" - -T = TypeVar("T") - - -class EachItem(railroad.Group): - """ - Custom railroad item to compose a: - - Group containing a - - OneOrMore containing a - - Choice of the elements in the Each - with the group label indicating that all must be matched - """ - - all_label = "[ALL]" - - def __init__(self, *items): - choice_item = railroad.Choice(len(items) - 1, *items) - one_or_more_item = railroad.OneOrMore(item=choice_item) - super().__init__(one_or_more_item, label=self.all_label) - - -class AnnotatedItem(railroad.Group): - """ - Simple subclass of Group that creates an annotation label - """ - - def __init__(self, label: str, item): - super().__init__(item=item, label="[{}]".format(label) if label else label) - - -class EditablePartial(Generic[T]): - """ - Acts like a functools.partial, but can be edited. In other words, it represents a type that hasn't yet been - constructed. - """ - - # We need this here because the railroad constructors actually transform the data, so can't be called until the - # entire tree is assembled - - def __init__(self, func: Callable[..., T], args: list, kwargs: dict): - self.func = func - self.args = args - self.kwargs = kwargs - - @classmethod - def from_call(cls, func: Callable[..., T], *args, **kwargs) -> "EditablePartial[T]": - """ - If you call this function in the same way that you would call the constructor, it will store the arguments - as you expect. For example EditablePartial.from_call(Fraction, 1, 3)() == Fraction(1, 3) - """ - return EditablePartial(func=func, args=list(args), kwargs=kwargs) - - @property - def name(self): - return self.kwargs["name"] - - def __call__(self) -> T: - """ - Evaluate the partial and return the result - """ - args = self.args.copy() - kwargs = self.kwargs.copy() - - # This is a helpful hack to allow you to specify varargs parameters (e.g. *args) as keyword args (e.g. - # args=['list', 'of', 'things']) - arg_spec = inspect.getfullargspec(self.func) - if arg_spec.varargs in self.kwargs: - args += kwargs.pop(arg_spec.varargs) - - return self.func(*args, **kwargs) - - -def railroad_to_html(diagrams: List[NamedDiagram], embed=False, **kwargs) -> str: - """ - Given a list of NamedDiagram, produce a single HTML string that visualises those diagrams - :params kwargs: kwargs to be passed in to the template - """ - data = [] - for diagram in diagrams: - if diagram.diagram is None: - continue - io = StringIO() - try: - css = kwargs.get('css') - diagram.diagram.writeStandalone(io.write, css=css) - except AttributeError: - diagram.diagram.writeSvg(io.write) - title = diagram.name - if diagram.index == 0: - title += " (root)" - data.append({"title": title, "text": "", "svg": io.getvalue()}) - - return template.render(diagrams=data, embed=embed, **kwargs) - - -def resolve_partial(partial: "EditablePartial[T]") -> T: - """ - Recursively resolves a collection of Partials into whatever type they are - """ - if isinstance(partial, EditablePartial): - partial.args = resolve_partial(partial.args) - partial.kwargs = resolve_partial(partial.kwargs) - return partial() - elif isinstance(partial, list): - return [resolve_partial(x) for x in partial] - elif isinstance(partial, dict): - return {key: resolve_partial(x) for key, x in partial.items()} - else: - return partial - - -def to_railroad( - element: pyparsing.ParserElement, - diagram_kwargs: typing.Optional[dict] = None, - vertical: int = 3, - show_results_names: bool = False, - show_groups: bool = False, -) -> List[NamedDiagram]: - """ - Convert a pyparsing element tree into a list of diagrams. This is the recommended entrypoint to diagram - creation if you want to access the Railroad tree before it is converted to HTML - :param element: base element of the parser being diagrammed - :param diagram_kwargs: kwargs to pass to the Diagram() constructor - :param vertical: (optional) - int - limit at which number of alternatives should be - shown vertically instead of horizontally - :param show_results_names - bool to indicate whether results name annotations should be - included in the diagram - :param show_groups - bool to indicate whether groups should be highlighted with an unlabeled - surrounding box - """ - # Convert the whole tree underneath the root - lookup = ConverterState(diagram_kwargs=diagram_kwargs or {}) - _to_diagram_element( - element, - lookup=lookup, - parent=None, - vertical=vertical, - show_results_names=show_results_names, - show_groups=show_groups, - ) - - root_id = id(element) - # Convert the root if it hasn't been already - if root_id in lookup: - if not element.customName: - lookup[root_id].name = "" - lookup[root_id].mark_for_extraction(root_id, lookup, force=True) - - # Now that we're finished, we can convert from intermediate structures into Railroad elements - diags = list(lookup.diagrams.values()) - if len(diags) > 1: - # collapse out duplicate diags with the same name - seen = set() - deduped_diags = [] - for d in diags: - # don't extract SkipTo elements, they are uninformative as subdiagrams - if d.name == "...": - continue - if d.name is not None and d.name not in seen: - seen.add(d.name) - deduped_diags.append(d) - resolved = [resolve_partial(partial) for partial in deduped_diags] - else: - # special case - if just one diagram, always display it, even if - # it has no name - resolved = [resolve_partial(partial) for partial in diags] - return sorted(resolved, key=lambda diag: diag.index) - - -def _should_vertical( - specification: int, exprs: Iterable[pyparsing.ParserElement] -) -> bool: - """ - Returns true if we should return a vertical list of elements - """ - if specification is None: - return False - else: - return len(_visible_exprs(exprs)) >= specification - - -class ElementState: - """ - State recorded for an individual pyparsing Element - """ - - # Note: this should be a dataclass, but we have to support Python 3.5 - def __init__( - self, - element: pyparsing.ParserElement, - converted: EditablePartial, - parent: EditablePartial, - number: int, - name: str = None, - parent_index: typing.Optional[int] = None, - ): - #: The pyparsing element that this represents - self.element: pyparsing.ParserElement = element - #: The name of the element - self.name: typing.Optional[str] = name - #: The output Railroad element in an unconverted state - self.converted: EditablePartial = converted - #: The parent Railroad element, which we store so that we can extract this if it's duplicated - self.parent: EditablePartial = parent - #: The order in which we found this element, used for sorting diagrams if this is extracted into a diagram - self.number: int = number - #: The index of this inside its parent - self.parent_index: typing.Optional[int] = parent_index - #: If true, we should extract this out into a subdiagram - self.extract: bool = False - #: If true, all of this element's children have been filled out - self.complete: bool = False - - def mark_for_extraction( - self, el_id: int, state: "ConverterState", name: str = None, force: bool = False - ): - """ - Called when this instance has been seen twice, and thus should eventually be extracted into a sub-diagram - :param el_id: id of the element - :param state: element/diagram state tracker - :param name: name to use for this element's text - :param force: If true, force extraction now, regardless of the state of this. Only useful for extracting the - root element when we know we're finished - """ - self.extract = True - - # Set the name - if not self.name: - if name: - # Allow forcing a custom name - self.name = name - elif self.element.customName: - self.name = self.element.customName - else: - self.name = "" - - # Just because this is marked for extraction doesn't mean we can do it yet. We may have to wait for children - # to be added - # Also, if this is just a string literal etc, don't bother extracting it - if force or (self.complete and _worth_extracting(self.element)): - state.extract_into_diagram(el_id) - - -class ConverterState: - """ - Stores some state that persists between recursions into the element tree - """ - - def __init__(self, diagram_kwargs: typing.Optional[dict] = None): - #: A dictionary mapping ParserElements to state relating to them - self._element_diagram_states: Dict[int, ElementState] = {} - #: A dictionary mapping ParserElement IDs to subdiagrams generated from them - self.diagrams: Dict[int, EditablePartial[NamedDiagram]] = {} - #: The index of the next unnamed element - self.unnamed_index: int = 1 - #: The index of the next element. This is used for sorting - self.index: int = 0 - #: Shared kwargs that are used to customize the construction of diagrams - self.diagram_kwargs: dict = diagram_kwargs or {} - self.extracted_diagram_names: Set[str] = set() - - def __setitem__(self, key: int, value: ElementState): - self._element_diagram_states[key] = value - - def __getitem__(self, key: int) -> ElementState: - return self._element_diagram_states[key] - - def __delitem__(self, key: int): - del self._element_diagram_states[key] - - def __contains__(self, key: int): - return key in self._element_diagram_states - - def generate_unnamed(self) -> int: - """ - Generate a number used in the name of an otherwise unnamed diagram - """ - self.unnamed_index += 1 - return self.unnamed_index - - def generate_index(self) -> int: - """ - Generate a number used to index a diagram - """ - self.index += 1 - return self.index - - def extract_into_diagram(self, el_id: int): - """ - Used when we encounter the same token twice in the same tree. When this - happens, we replace all instances of that token with a terminal, and - create a new subdiagram for the token - """ - position = self[el_id] - - # Replace the original definition of this element with a regular block - if position.parent: - ret = EditablePartial.from_call(railroad.NonTerminal, text=position.name) - if "item" in position.parent.kwargs: - position.parent.kwargs["item"] = ret - elif "items" in position.parent.kwargs: - position.parent.kwargs["items"][position.parent_index] = ret - - # If the element we're extracting is a group, skip to its content but keep the title - if position.converted.func == railroad.Group: - content = position.converted.kwargs["item"] - else: - content = position.converted - - self.diagrams[el_id] = EditablePartial.from_call( - NamedDiagram, - name=position.name, - diagram=EditablePartial.from_call( - railroad.Diagram, content, **self.diagram_kwargs - ), - index=position.number, - ) - - del self[el_id] - - -def _worth_extracting(element: pyparsing.ParserElement) -> bool: - """ - Returns true if this element is worth having its own sub-diagram. Simply, if any of its children - themselves have children, then its complex enough to extract - """ - children = element.recurse() - return any(child.recurse() for child in children) - - -def _apply_diagram_item_enhancements(fn): - """ - decorator to ensure enhancements to a diagram item (such as results name annotations) - get applied on return from _to_diagram_element (we do this since there are several - returns in _to_diagram_element) - """ - - def _inner( - element: pyparsing.ParserElement, - parent: typing.Optional[EditablePartial], - lookup: ConverterState = None, - vertical: int = None, - index: int = 0, - name_hint: str = None, - show_results_names: bool = False, - show_groups: bool = False, - ) -> typing.Optional[EditablePartial]: - ret = fn( - element, - parent, - lookup, - vertical, - index, - name_hint, - show_results_names, - show_groups, - ) - - # apply annotation for results name, if present - if show_results_names and ret is not None: - element_results_name = element.resultsName - if element_results_name: - # add "*" to indicate if this is a "list all results" name - element_results_name += "" if element.modalResults else "*" - ret = EditablePartial.from_call( - railroad.Group, item=ret, label=element_results_name - ) - - return ret - - return _inner - - -def _visible_exprs(exprs: Iterable[pyparsing.ParserElement]): - non_diagramming_exprs = ( - pyparsing.ParseElementEnhance, - pyparsing.PositionToken, - pyparsing.And._ErrorStop, - ) - return [ - e - for e in exprs - if not (e.customName or e.resultsName or isinstance(e, non_diagramming_exprs)) - ] - - -@_apply_diagram_item_enhancements -def _to_diagram_element( - element: pyparsing.ParserElement, - parent: typing.Optional[EditablePartial], - lookup: ConverterState = None, - vertical: int = None, - index: int = 0, - name_hint: str = None, - show_results_names: bool = False, - show_groups: bool = False, -) -> typing.Optional[EditablePartial]: - """ - Recursively converts a PyParsing Element to a railroad Element - :param lookup: The shared converter state that keeps track of useful things - :param index: The index of this element within the parent - :param parent: The parent of this element in the output tree - :param vertical: Controls at what point we make a list of elements vertical. If this is an integer (the default), - it sets the threshold of the number of items before we go vertical. If True, always go vertical, if False, never - do so - :param name_hint: If provided, this will override the generated name - :param show_results_names: bool flag indicating whether to add annotations for results names - :returns: The converted version of the input element, but as a Partial that hasn't yet been constructed - :param show_groups: bool flag indicating whether to show groups using bounding box - """ - exprs = element.recurse() - name = name_hint or element.customName or element.__class__.__name__ - - # Python's id() is used to provide a unique identifier for elements - el_id = id(element) - - element_results_name = element.resultsName - - # Here we basically bypass processing certain wrapper elements if they contribute nothing to the diagram - if not element.customName: - if isinstance( - element, - ( - # pyparsing.TokenConverter, - # pyparsing.Forward, - pyparsing.Located, - ), - ): - # However, if this element has a useful custom name, and its child does not, we can pass it on to the child - if exprs: - if not exprs[0].customName: - propagated_name = name - else: - propagated_name = None - - return _to_diagram_element( - element.expr, - parent=parent, - lookup=lookup, - vertical=vertical, - index=index, - name_hint=propagated_name, - show_results_names=show_results_names, - show_groups=show_groups, - ) - - # If the element isn't worth extracting, we always treat it as the first time we say it - if _worth_extracting(element): - if el_id in lookup: - # If we've seen this element exactly once before, we are only just now finding out that it's a duplicate, - # so we have to extract it into a new diagram. - looked_up = lookup[el_id] - looked_up.mark_for_extraction(el_id, lookup, name=name_hint) - ret = EditablePartial.from_call(railroad.NonTerminal, text=looked_up.name) - return ret - - elif el_id in lookup.diagrams: - # If we have seen the element at least twice before, and have already extracted it into a subdiagram, we - # just put in a marker element that refers to the sub-diagram - ret = EditablePartial.from_call( - railroad.NonTerminal, text=lookup.diagrams[el_id].kwargs["name"] - ) - return ret - - # Recursively convert child elements - # Here we find the most relevant Railroad element for matching pyparsing Element - # We use ``items=[]`` here to hold the place for where the child elements will go once created - if isinstance(element, pyparsing.And): - # detect And's created with ``expr*N`` notation - for these use a OneOrMore with a repeat - # (all will have the same name, and resultsName) - if not exprs: - return None - if len(set((e.name, e.resultsName) for e in exprs)) == 1: - ret = EditablePartial.from_call( - railroad.OneOrMore, item="", repeat=str(len(exprs)) - ) - elif _should_vertical(vertical, exprs): - ret = EditablePartial.from_call(railroad.Stack, items=[]) - else: - ret = EditablePartial.from_call(railroad.Sequence, items=[]) - elif isinstance(element, (pyparsing.Or, pyparsing.MatchFirst)): - if not exprs: - return None - if _should_vertical(vertical, exprs): - ret = EditablePartial.from_call(railroad.Choice, 0, items=[]) - else: - ret = EditablePartial.from_call(railroad.HorizontalChoice, items=[]) - elif isinstance(element, pyparsing.Each): - if not exprs: - return None - ret = EditablePartial.from_call(EachItem, items=[]) - elif isinstance(element, pyparsing.NotAny): - ret = EditablePartial.from_call(AnnotatedItem, label="NOT", item="") - elif isinstance(element, pyparsing.FollowedBy): - ret = EditablePartial.from_call(AnnotatedItem, label="LOOKAHEAD", item="") - elif isinstance(element, pyparsing.PrecededBy): - ret = EditablePartial.from_call(AnnotatedItem, label="LOOKBEHIND", item="") - elif isinstance(element, pyparsing.Group): - if show_groups: - ret = EditablePartial.from_call(AnnotatedItem, label="", item="") - else: - ret = EditablePartial.from_call(railroad.Group, label="", item="") - elif isinstance(element, pyparsing.TokenConverter): - label = type(element).__name__.lower() - if label == "tokenconverter": - ret = EditablePartial.from_call(railroad.Sequence, items=[]) - else: - ret = EditablePartial.from_call(AnnotatedItem, label=label, item="") - elif isinstance(element, pyparsing.Opt): - ret = EditablePartial.from_call(railroad.Optional, item="") - elif isinstance(element, pyparsing.OneOrMore): - ret = EditablePartial.from_call(railroad.OneOrMore, item="") - elif isinstance(element, pyparsing.ZeroOrMore): - ret = EditablePartial.from_call(railroad.ZeroOrMore, item="") - elif isinstance(element, pyparsing.Group): - ret = EditablePartial.from_call( - railroad.Group, item=None, label=element_results_name - ) - elif isinstance(element, pyparsing.Empty) and not element.customName: - # Skip unnamed "Empty" elements - ret = None - elif isinstance(element, pyparsing.ParseElementEnhance): - ret = EditablePartial.from_call(railroad.Sequence, items=[]) - elif len(exprs) > 0 and not element_results_name: - ret = EditablePartial.from_call(railroad.Group, item="", label=name) - elif len(exprs) > 0: - ret = EditablePartial.from_call(railroad.Sequence, items=[]) - else: - terminal = EditablePartial.from_call(railroad.Terminal, element.defaultName) - ret = terminal - - if ret is None: - return - - # Indicate this element's position in the tree so we can extract it if necessary - lookup[el_id] = ElementState( - element=element, - converted=ret, - parent=parent, - parent_index=index, - number=lookup.generate_index(), - ) - if element.customName: - lookup[el_id].mark_for_extraction(el_id, lookup, element.customName) - - i = 0 - for expr in exprs: - # Add a placeholder index in case we have to extract the child before we even add it to the parent - if "items" in ret.kwargs: - ret.kwargs["items"].insert(i, None) - - item = _to_diagram_element( - expr, - parent=ret, - lookup=lookup, - vertical=vertical, - index=i, - show_results_names=show_results_names, - show_groups=show_groups, - ) - - # Some elements don't need to be shown in the diagram - if item is not None: - if "item" in ret.kwargs: - ret.kwargs["item"] = item - elif "items" in ret.kwargs: - # If we've already extracted the child, don't touch this index, since it's occupied by a nonterminal - ret.kwargs["items"][i] = item - i += 1 - elif "items" in ret.kwargs: - # If we're supposed to skip this element, remove it from the parent - del ret.kwargs["items"][i] - - # If all this items children are none, skip this item - if ret and ( - ("items" in ret.kwargs and len(ret.kwargs["items"]) == 0) - or ("item" in ret.kwargs and ret.kwargs["item"] is None) - ): - ret = EditablePartial.from_call(railroad.Terminal, name) - - # Mark this element as "complete", ie it has all of its children - if el_id in lookup: - lookup[el_id].complete = True - - if el_id in lookup and lookup[el_id].extract and lookup[el_id].complete: - lookup.extract_into_diagram(el_id) - if ret is not None: - ret = EditablePartial.from_call( - railroad.NonTerminal, text=lookup.diagrams[el_id].kwargs["name"] - ) - - return ret diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__pycache__/__init__.cpython-311.pyc deleted file mode 100644 index c8631bbd1e27a402751363983e0e987d044aff20..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 28802 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 D0hCJ% diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/exceptions.py b/myenv/Lib/site-packages/pip/_vendor/pyparsing/exceptions.py deleted file mode 100644 index 12219f1..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/pyparsing/exceptions.py +++ /dev/null @@ -1,299 +0,0 @@ -# exceptions.py - -import re -import sys -import typing - -from .util import ( - col, - line, - lineno, - _collapse_string_to_ranges, - replaced_by_pep8, -) -from .unicode import pyparsing_unicode as ppu - - -class ExceptionWordUnicode(ppu.Latin1, ppu.LatinA, ppu.LatinB, ppu.Greek, ppu.Cyrillic): - pass - - -_extract_alphanums = _collapse_string_to_ranges(ExceptionWordUnicode.alphanums) -_exception_word_extractor = re.compile("([" + _extract_alphanums + "]{1,16})|.") - - -class ParseBaseException(Exception): - """base exception class for all parsing runtime exceptions""" - - loc: int - msg: str - pstr: str - parser_element: typing.Any # "ParserElement" - args: typing.Tuple[str, int, typing.Optional[str]] - - __slots__ = ( - "loc", - "msg", - "pstr", - "parser_element", - "args", - ) - - # Performance tuning: we construct a *lot* of these, so keep this - # constructor as small and fast as possible - def __init__( - self, - pstr: str, - loc: int = 0, - msg: typing.Optional[str] = None, - elem=None, - ): - self.loc = loc - if msg is None: - self.msg = pstr - self.pstr = "" - else: - self.msg = msg - self.pstr = pstr - self.parser_element = elem - self.args = (pstr, loc, msg) - - @staticmethod - def explain_exception(exc, depth=16): - """ - Method to take an exception and translate the Python internal traceback into a list - of the pyparsing expressions that caused the exception to be raised. - - Parameters: - - - exc - exception raised during parsing (need not be a ParseException, in support - of Python exceptions that might be raised in a parse action) - - depth (default=16) - number of levels back in the stack trace to list expression - and function names; if None, the full stack trace names will be listed; if 0, only - the failing input line, marker, and exception string will be shown - - Returns a multi-line string listing the ParserElements and/or function names in the - exception's stack trace. - """ - import inspect - from .core import ParserElement - - if depth is None: - depth = sys.getrecursionlimit() - ret = [] - if isinstance(exc, ParseBaseException): - ret.append(exc.line) - ret.append(" " * (exc.column - 1) + "^") - ret.append(f"{type(exc).__name__}: {exc}") - - if depth > 0: - callers = inspect.getinnerframes(exc.__traceback__, context=depth) - seen = set() - for i, ff in enumerate(callers[-depth:]): - frm = ff[0] - - f_self = frm.f_locals.get("self", None) - if isinstance(f_self, ParserElement): - if not frm.f_code.co_name.startswith( - ("parseImpl", "_parseNoCache") - ): - continue - if id(f_self) in seen: - continue - seen.add(id(f_self)) - - self_type = type(f_self) - ret.append( - f"{self_type.__module__}.{self_type.__name__} - {f_self}" - ) - - elif f_self is not None: - self_type = type(f_self) - ret.append(f"{self_type.__module__}.{self_type.__name__}") - - else: - code = frm.f_code - if code.co_name in ("wrapper", ""): - continue - - ret.append(code.co_name) - - depth -= 1 - if not depth: - break - - return "\n".join(ret) - - @classmethod - def _from_exception(cls, pe): - """ - internal factory method to simplify creating one type of ParseException - from another - avoids having __init__ signature conflicts among subclasses - """ - return cls(pe.pstr, pe.loc, pe.msg, pe.parser_element) - - @property - def line(self) -> str: - """ - Return the line of text where the exception occurred. - """ - return line(self.loc, self.pstr) - - @property - def lineno(self) -> int: - """ - Return the 1-based line number of text where the exception occurred. - """ - return lineno(self.loc, self.pstr) - - @property - def col(self) -> int: - """ - Return the 1-based column on the line of text where the exception occurred. - """ - return col(self.loc, self.pstr) - - @property - def column(self) -> int: - """ - Return the 1-based column on the line of text where the exception occurred. - """ - return col(self.loc, self.pstr) - - # pre-PEP8 compatibility - @property - def parserElement(self): - return self.parser_element - - @parserElement.setter - def parserElement(self, elem): - self.parser_element = elem - - def __str__(self) -> str: - if self.pstr: - if self.loc >= len(self.pstr): - foundstr = ", found end of text" - else: - # pull out next word at error location - found_match = _exception_word_extractor.match(self.pstr, self.loc) - if found_match is not None: - found = found_match.group(0) - else: - found = self.pstr[self.loc : self.loc + 1] - foundstr = (", found %r" % found).replace(r"\\", "\\") - else: - foundstr = "" - return f"{self.msg}{foundstr} (at char {self.loc}), (line:{self.lineno}, col:{self.column})" - - def __repr__(self): - return str(self) - - def mark_input_line( - self, marker_string: typing.Optional[str] = None, *, markerString: str = ">!<" - ) -> str: - """ - Extracts the exception line from the input string, and marks - the location of the exception with a special symbol. - """ - markerString = marker_string if marker_string is not None else markerString - line_str = self.line - line_column = self.column - 1 - if markerString: - line_str = "".join( - (line_str[:line_column], markerString, line_str[line_column:]) - ) - return line_str.strip() - - def explain(self, depth=16) -> str: - """ - Method to translate the Python internal traceback into a list - of the pyparsing expressions that caused the exception to be raised. - - Parameters: - - - depth (default=16) - number of levels back in the stack trace to list expression - and function names; if None, the full stack trace names will be listed; if 0, only - the failing input line, marker, and exception string will be shown - - Returns a multi-line string listing the ParserElements and/or function names in the - exception's stack trace. - - Example:: - - expr = pp.Word(pp.nums) * 3 - try: - expr.parse_string("123 456 A789") - except pp.ParseException as pe: - print(pe.explain(depth=0)) - - prints:: - - 123 456 A789 - ^ - ParseException: Expected W:(0-9), found 'A' (at char 8), (line:1, col:9) - - Note: the diagnostic output will include string representations of the expressions - that failed to parse. These representations will be more helpful if you use `set_name` to - give identifiable names to your expressions. Otherwise they will use the default string - forms, which may be cryptic to read. - - Note: pyparsing's default truncation of exception tracebacks may also truncate the - stack of expressions that are displayed in the ``explain`` output. To get the full listing - of parser expressions, you may have to set ``ParserElement.verbose_stacktrace = True`` - """ - return self.explain_exception(self, depth) - - # fmt: off - @replaced_by_pep8(mark_input_line) - def markInputline(self): ... - # fmt: on - - -class ParseException(ParseBaseException): - """ - Exception thrown when a parse expression doesn't match the input string - - Example:: - - try: - Word(nums).set_name("integer").parse_string("ABC") - except ParseException as pe: - print(pe) - print("column: {}".format(pe.column)) - - prints:: - - Expected integer (at char 0), (line:1, col:1) - column: 1 - - """ - - -class ParseFatalException(ParseBaseException): - """ - User-throwable exception thrown when inconsistent parse content - is found; stops all parsing immediately - """ - - -class ParseSyntaxException(ParseFatalException): - """ - Just like :class:`ParseFatalException`, but thrown internally - when an :class:`ErrorStop` ('-' operator) indicates - that parsing is to stop immediately because an unbacktrackable - syntax error has been found. - """ - - -class RecursiveGrammarException(Exception): - """ - Exception thrown by :class:`ParserElement.validate` if the - grammar could be left-recursive; parser may need to enable - left recursion using :class:`ParserElement.enable_left_recursion` - """ - - def __init__(self, parseElementList): - self.parseElementTrace = parseElementList - - def __str__(self) -> str: - return f"RecursiveGrammarException: {self.parseElementTrace}" diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/helpers.py b/myenv/Lib/site-packages/pip/_vendor/pyparsing/helpers.py deleted file mode 100644 index 018f0d6..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/pyparsing/helpers.py +++ /dev/null @@ -1,1100 +0,0 @@ -# helpers.py -import html.entities -import re -import sys -import typing - -from . import __diag__ -from .core import * -from .util import ( - _bslash, - _flatten, - _escape_regex_range_chars, - replaced_by_pep8, -) - - -# -# global helpers -# -def counted_array( - expr: ParserElement, - int_expr: typing.Optional[ParserElement] = None, - *, - intExpr: typing.Optional[ParserElement] = None, -) -> ParserElement: - """Helper to define a counted list of expressions. - - This helper defines a pattern of the form:: - - integer expr expr expr... - - where the leading integer tells how many expr expressions follow. - The matched tokens returns the array of expr tokens as a list - the - leading count token is suppressed. - - If ``int_expr`` is specified, it should be a pyparsing expression - that produces an integer value. - - Example:: - - counted_array(Word(alphas)).parse_string('2 ab cd ef') # -> ['ab', 'cd'] - - # in this parser, the leading integer value is given in binary, - # '10' indicating that 2 values are in the array - binary_constant = Word('01').set_parse_action(lambda t: int(t[0], 2)) - counted_array(Word(alphas), int_expr=binary_constant).parse_string('10 ab cd ef') # -> ['ab', 'cd'] - - # if other fields must be parsed after the count but before the - # list items, give the fields results names and they will - # be preserved in the returned ParseResults: - count_with_metadata = integer + Word(alphas)("type") - typed_array = counted_array(Word(alphanums), int_expr=count_with_metadata)("items") - result = typed_array.parse_string("3 bool True True False") - print(result.dump()) - - # prints - # ['True', 'True', 'False'] - # - items: ['True', 'True', 'False'] - # - type: 'bool' - """ - intExpr = intExpr or int_expr - array_expr = Forward() - - def count_field_parse_action(s, l, t): - nonlocal array_expr - n = t[0] - array_expr <<= (expr * n) if n else Empty() - # clear list contents, but keep any named results - del t[:] - - if intExpr is None: - intExpr = Word(nums).set_parse_action(lambda t: int(t[0])) - else: - intExpr = intExpr.copy() - intExpr.set_name("arrayLen") - intExpr.add_parse_action(count_field_parse_action, call_during_try=True) - return (intExpr + array_expr).set_name("(len) " + str(expr) + "...") - - -def match_previous_literal(expr: ParserElement) -> ParserElement: - """Helper to define an expression that is indirectly defined from - the tokens matched in a previous expression, that is, it looks for - a 'repeat' of a previous expression. For example:: - - first = Word(nums) - second = match_previous_literal(first) - match_expr = first + ":" + second - - will match ``"1:1"``, but not ``"1:2"``. Because this - matches a previous literal, will also match the leading - ``"1:1"`` in ``"1:10"``. If this is not desired, use - :class:`match_previous_expr`. Do *not* use with packrat parsing - enabled. - """ - rep = Forward() - - def copy_token_to_repeater(s, l, t): - if t: - if len(t) == 1: - rep << t[0] - else: - # flatten t tokens - tflat = _flatten(t.as_list()) - rep << And(Literal(tt) for tt in tflat) - else: - rep << Empty() - - expr.add_parse_action(copy_token_to_repeater, callDuringTry=True) - rep.set_name("(prev) " + str(expr)) - return rep - - -def match_previous_expr(expr: ParserElement) -> ParserElement: - """Helper to define an expression that is indirectly defined from - the tokens matched in a previous expression, that is, it looks for - a 'repeat' of a previous expression. For example:: - - first = Word(nums) - second = match_previous_expr(first) - match_expr = first + ":" + second - - will match ``"1:1"``, but not ``"1:2"``. Because this - matches by expressions, will *not* match the leading ``"1:1"`` - in ``"1:10"``; the expressions are evaluated first, and then - compared, so ``"1"`` is compared with ``"10"``. Do *not* use - with packrat parsing enabled. - """ - rep = Forward() - e2 = expr.copy() - rep <<= e2 - - def copy_token_to_repeater(s, l, t): - matchTokens = _flatten(t.as_list()) - - def must_match_these_tokens(s, l, t): - theseTokens = _flatten(t.as_list()) - if theseTokens != matchTokens: - raise ParseException( - s, l, f"Expected {matchTokens}, found{theseTokens}" - ) - - rep.set_parse_action(must_match_these_tokens, callDuringTry=True) - - expr.add_parse_action(copy_token_to_repeater, callDuringTry=True) - rep.set_name("(prev) " + str(expr)) - return rep - - -def one_of( - strs: Union[typing.Iterable[str], str], - caseless: bool = False, - use_regex: bool = True, - as_keyword: bool = False, - *, - useRegex: bool = True, - asKeyword: bool = False, -) -> ParserElement: - """Helper to quickly define a set of alternative :class:`Literal` s, - and makes sure to do longest-first testing when there is a conflict, - regardless of the input order, but returns - a :class:`MatchFirst` for best performance. - - Parameters: - - - ``strs`` - a string of space-delimited literals, or a collection of - string literals - - ``caseless`` - treat all literals as caseless - (default= ``False``) - - ``use_regex`` - as an optimization, will - generate a :class:`Regex` object; otherwise, will generate - a :class:`MatchFirst` object (if ``caseless=True`` or ``as_keyword=True``, or if - creating a :class:`Regex` raises an exception) - (default= ``True``) - - ``as_keyword`` - enforce :class:`Keyword`-style matching on the - generated expressions - (default= ``False``) - - ``asKeyword`` and ``useRegex`` are retained for pre-PEP8 compatibility, - but will be removed in a future release - - Example:: - - comp_oper = one_of("< = > <= >= !=") - var = Word(alphas) - number = Word(nums) - term = var | number - comparison_expr = term + comp_oper + term - print(comparison_expr.search_string("B = 12 AA=23 B<=AA AA>12")) - - prints:: - - [['B', '=', '12'], ['AA', '=', '23'], ['B', '<=', 'AA'], ['AA', '>', '12']] - """ - asKeyword = asKeyword or as_keyword - useRegex = useRegex and use_regex - - if ( - isinstance(caseless, str_type) - and __diag__.warn_on_multiple_string_args_to_oneof - ): - warnings.warn( - "More than one string argument passed to one_of, pass" - " choices as a list or space-delimited string", - stacklevel=2, - ) - - if caseless: - isequal = lambda a, b: a.upper() == b.upper() - masks = lambda a, b: b.upper().startswith(a.upper()) - parseElementClass = CaselessKeyword if asKeyword else CaselessLiteral - else: - isequal = lambda a, b: a == b - masks = lambda a, b: b.startswith(a) - parseElementClass = Keyword if asKeyword else Literal - - symbols: List[str] = [] - if isinstance(strs, str_type): - strs = typing.cast(str, strs) - symbols = strs.split() - elif isinstance(strs, Iterable): - symbols = list(strs) - else: - raise TypeError("Invalid argument to one_of, expected string or iterable") - if not symbols: - return NoMatch() - - # reorder given symbols to take care to avoid masking longer choices with shorter ones - # (but only if the given symbols are not just single characters) - if any(len(sym) > 1 for sym in symbols): - i = 0 - while i < len(symbols) - 1: - cur = symbols[i] - for j, other in enumerate(symbols[i + 1 :]): - if isequal(other, cur): - del symbols[i + j + 1] - break - elif masks(cur, other): - del symbols[i + j + 1] - symbols.insert(i, other) - break - else: - i += 1 - - if useRegex: - re_flags: int = re.IGNORECASE if caseless else 0 - - try: - if all(len(sym) == 1 for sym in symbols): - # symbols are just single characters, create range regex pattern - patt = f"[{''.join(_escape_regex_range_chars(sym) for sym in symbols)}]" - else: - patt = "|".join(re.escape(sym) for sym in symbols) - - # wrap with \b word break markers if defining as keywords - if asKeyword: - patt = rf"\b(?:{patt})\b" - - ret = Regex(patt, flags=re_flags).set_name(" | ".join(symbols)) - - if caseless: - # add parse action to return symbols as specified, not in random - # casing as found in input string - symbol_map = {sym.lower(): sym for sym in symbols} - ret.add_parse_action(lambda s, l, t: symbol_map[t[0].lower()]) - - return ret - - except re.error: - warnings.warn( - "Exception creating Regex for one_of, building MatchFirst", stacklevel=2 - ) - - # last resort, just use MatchFirst - return MatchFirst(parseElementClass(sym) for sym in symbols).set_name( - " | ".join(symbols) - ) - - -def dict_of(key: ParserElement, value: ParserElement) -> ParserElement: - """Helper to easily and clearly define a dictionary by specifying - the respective patterns for the key and value. Takes care of - defining the :class:`Dict`, :class:`ZeroOrMore`, and - :class:`Group` tokens in the proper order. The key pattern - can include delimiting markers or punctuation, as long as they are - suppressed, thereby leaving the significant key text. The value - pattern can include named results, so that the :class:`Dict` results - can include named token fields. - - Example:: - - text = "shape: SQUARE posn: upper left color: light blue texture: burlap" - attr_expr = (label + Suppress(':') + OneOrMore(data_word, stop_on=label).set_parse_action(' '.join)) - print(attr_expr[1, ...].parse_string(text).dump()) - - attr_label = label - attr_value = Suppress(':') + OneOrMore(data_word, stop_on=label).set_parse_action(' '.join) - - # similar to Dict, but simpler call format - result = dict_of(attr_label, attr_value).parse_string(text) - print(result.dump()) - print(result['shape']) - print(result.shape) # object attribute access works too - print(result.as_dict()) - - prints:: - - [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']] - - color: 'light blue' - - posn: 'upper left' - - shape: 'SQUARE' - - texture: 'burlap' - SQUARE - SQUARE - {'color': 'light blue', 'shape': 'SQUARE', 'posn': 'upper left', 'texture': 'burlap'} - """ - return Dict(OneOrMore(Group(key + value))) - - -def original_text_for( - expr: ParserElement, as_string: bool = True, *, asString: bool = True -) -> ParserElement: - """Helper to return the original, untokenized text for a given - expression. Useful to restore the parsed fields of an HTML start - tag into the raw tag text itself, or to revert separate tokens with - intervening whitespace back to the original matching input text. By - default, returns a string containing the original parsed text. - - If the optional ``as_string`` argument is passed as - ``False``, then the return value is - a :class:`ParseResults` containing any results names that - were originally matched, and a single token containing the original - matched text from the input string. So if the expression passed to - :class:`original_text_for` contains expressions with defined - results names, you must set ``as_string`` to ``False`` if you - want to preserve those results name values. - - The ``asString`` pre-PEP8 argument is retained for compatibility, - but will be removed in a future release. - - Example:: - - src = "this is test bold text normal text " - for tag in ("b", "i"): - opener, closer = make_html_tags(tag) - patt = original_text_for(opener + ... + closer) - print(patt.search_string(src)[0]) - - prints:: - - [' bold text '] - ['text'] - """ - asString = asString and as_string - - locMarker = Empty().set_parse_action(lambda s, loc, t: loc) - endlocMarker = locMarker.copy() - endlocMarker.callPreparse = False - matchExpr = locMarker("_original_start") + expr + endlocMarker("_original_end") - if asString: - extractText = lambda s, l, t: s[t._original_start : t._original_end] - else: - - def extractText(s, l, t): - t[:] = [s[t.pop("_original_start") : t.pop("_original_end")]] - - matchExpr.set_parse_action(extractText) - matchExpr.ignoreExprs = expr.ignoreExprs - matchExpr.suppress_warning(Diagnostics.warn_ungrouped_named_tokens_in_collection) - return matchExpr - - -def ungroup(expr: ParserElement) -> ParserElement: - """Helper to undo pyparsing's default grouping of And expressions, - even if all but one are non-empty. - """ - return TokenConverter(expr).add_parse_action(lambda t: t[0]) - - -def locatedExpr(expr: ParserElement) -> ParserElement: - """ - (DEPRECATED - future code should use the :class:`Located` class) - Helper to decorate a returned token with its starting and ending - locations in the input string. - - This helper adds the following results names: - - - ``locn_start`` - location where matched expression begins - - ``locn_end`` - location where matched expression ends - - ``value`` - the actual parsed results - - Be careful if the input text contains ```` characters, you - may want to call :class:`ParserElement.parse_with_tabs` - - Example:: - - wd = Word(alphas) - for match in locatedExpr(wd).search_string("ljsdf123lksdjjf123lkkjj1222"): - print(match) - - prints:: - - [[0, 'ljsdf', 5]] - [[8, 'lksdjjf', 15]] - [[18, 'lkkjj', 23]] - """ - locator = Empty().set_parse_action(lambda ss, ll, tt: ll) - return Group( - locator("locn_start") - + expr("value") - + locator.copy().leaveWhitespace()("locn_end") - ) - - -def nested_expr( - opener: Union[str, ParserElement] = "(", - closer: Union[str, ParserElement] = ")", - content: typing.Optional[ParserElement] = None, - ignore_expr: ParserElement = quoted_string(), - *, - ignoreExpr: ParserElement = quoted_string(), -) -> ParserElement: - """Helper method for defining nested lists enclosed in opening and - closing delimiters (``"("`` and ``")"`` are the default). - - Parameters: - - - ``opener`` - opening character for a nested list - (default= ``"("``); can also be a pyparsing expression - - ``closer`` - closing character for a nested list - (default= ``")"``); can also be a pyparsing expression - - ``content`` - expression for items within the nested lists - (default= ``None``) - - ``ignore_expr`` - expression for ignoring opening and closing delimiters - (default= :class:`quoted_string`) - - ``ignoreExpr`` - this pre-PEP8 argument is retained for compatibility - but will be removed in a future release - - If an expression is not provided for the content argument, the - nested expression will capture all whitespace-delimited content - between delimiters as a list of separate values. - - Use the ``ignore_expr`` argument to define expressions that may - contain opening or closing characters that should not be treated as - opening or closing characters for nesting, such as quoted_string or - a comment expression. Specify multiple expressions using an - :class:`Or` or :class:`MatchFirst`. The default is - :class:`quoted_string`, but if no expressions are to be ignored, then - pass ``None`` for this argument. - - Example:: - - data_type = one_of("void int short long char float double") - decl_data_type = Combine(data_type + Opt(Word('*'))) - ident = Word(alphas+'_', alphanums+'_') - number = pyparsing_common.number - arg = Group(decl_data_type + ident) - LPAR, RPAR = map(Suppress, "()") - - code_body = nested_expr('{', '}', ignore_expr=(quoted_string | c_style_comment)) - - c_function = (decl_data_type("type") - + ident("name") - + LPAR + Opt(DelimitedList(arg), [])("args") + RPAR - + code_body("body")) - c_function.ignore(c_style_comment) - - source_code = ''' - int is_odd(int x) { - return (x%2); - } - - int dec_to_hex(char hchar) { - if (hchar >= '0' && hchar <= '9') { - return (ord(hchar)-ord('0')); - } else { - return (10+ord(hchar)-ord('A')); - } - } - ''' - for func in c_function.search_string(source_code): - print("%(name)s (%(type)s) args: %(args)s" % func) - - - prints:: - - is_odd (int) args: [['int', 'x']] - dec_to_hex (int) args: [['char', 'hchar']] - """ - if ignoreExpr != ignore_expr: - ignoreExpr = ignore_expr if ignoreExpr == quoted_string() else ignoreExpr - if opener == closer: - raise ValueError("opening and closing strings cannot be the same") - if content is None: - if isinstance(opener, str_type) and isinstance(closer, str_type): - opener = typing.cast(str, opener) - closer = typing.cast(str, closer) - if len(opener) == 1 and len(closer) == 1: - if ignoreExpr is not None: - content = Combine( - OneOrMore( - ~ignoreExpr - + CharsNotIn( - opener + closer + ParserElement.DEFAULT_WHITE_CHARS, - exact=1, - ) - ) - ).set_parse_action(lambda t: t[0].strip()) - else: - content = empty.copy() + CharsNotIn( - opener + closer + ParserElement.DEFAULT_WHITE_CHARS - ).set_parse_action(lambda t: t[0].strip()) - else: - if ignoreExpr is not None: - content = Combine( - OneOrMore( - ~ignoreExpr - + ~Literal(opener) - + ~Literal(closer) - + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS, exact=1) - ) - ).set_parse_action(lambda t: t[0].strip()) - else: - content = Combine( - OneOrMore( - ~Literal(opener) - + ~Literal(closer) - + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS, exact=1) - ) - ).set_parse_action(lambda t: t[0].strip()) - else: - raise ValueError( - "opening and closing arguments must be strings if no content expression is given" - ) - ret = Forward() - if ignoreExpr is not None: - ret <<= Group( - Suppress(opener) + ZeroOrMore(ignoreExpr | ret | content) + Suppress(closer) - ) - else: - ret <<= Group(Suppress(opener) + ZeroOrMore(ret | content) + Suppress(closer)) - ret.set_name("nested %s%s expression" % (opener, closer)) - return ret - - -def _makeTags(tagStr, xml, suppress_LT=Suppress("<"), suppress_GT=Suppress(">")): - """Internal helper to construct opening and closing tag expressions, given a tag name""" - if isinstance(tagStr, str_type): - resname = tagStr - tagStr = Keyword(tagStr, caseless=not xml) - else: - resname = tagStr.name - - tagAttrName = Word(alphas, alphanums + "_-:") - if xml: - tagAttrValue = dbl_quoted_string.copy().set_parse_action(remove_quotes) - openTag = ( - suppress_LT - + tagStr("tag") - + Dict(ZeroOrMore(Group(tagAttrName + Suppress("=") + tagAttrValue))) - + Opt("/", default=[False])("empty").set_parse_action( - lambda s, l, t: t[0] == "/" - ) - + suppress_GT - ) - else: - tagAttrValue = quoted_string.copy().set_parse_action(remove_quotes) | Word( - printables, exclude_chars=">" - ) - openTag = ( - suppress_LT - + tagStr("tag") - + Dict( - ZeroOrMore( - Group( - tagAttrName.set_parse_action(lambda t: t[0].lower()) - + Opt(Suppress("=") + tagAttrValue) - ) - ) - ) - + Opt("/", default=[False])("empty").set_parse_action( - lambda s, l, t: t[0] == "/" - ) - + suppress_GT - ) - closeTag = Combine(Literal("", adjacent=False) - - openTag.set_name("<%s>" % resname) - # add start results name in parse action now that ungrouped names are not reported at two levels - openTag.add_parse_action( - lambda t: t.__setitem__( - "start" + "".join(resname.replace(":", " ").title().split()), t.copy() - ) - ) - closeTag = closeTag( - "end" + "".join(resname.replace(":", " ").title().split()) - ).set_name("" % resname) - openTag.tag = resname - closeTag.tag = resname - openTag.tag_body = SkipTo(closeTag()) - return openTag, closeTag - - -def make_html_tags( - tag_str: Union[str, ParserElement] -) -> Tuple[ParserElement, ParserElement]: - """Helper to construct opening and closing tag expressions for HTML, - given a tag name. Matches tags in either upper or lower case, - attributes with namespaces and with quoted or unquoted values. - - Example:: - - text = 'More info at the pyparsing wiki page' - # make_html_tags returns pyparsing expressions for the opening and - # closing tags as a 2-tuple - a, a_end = make_html_tags("A") - link_expr = a + SkipTo(a_end)("link_text") + a_end - - for link in link_expr.search_string(text): - # attributes in the tag (like "href" shown here) are - # also accessible as named results - print(link.link_text, '->', link.href) - - prints:: - - pyparsing -> https://github.com/pyparsing/pyparsing/wiki - """ - return _makeTags(tag_str, False) - - -def make_xml_tags( - tag_str: Union[str, ParserElement] -) -> Tuple[ParserElement, ParserElement]: - """Helper to construct opening and closing tag expressions for XML, - given a tag name. Matches tags only in the given upper/lower case. - - Example: similar to :class:`make_html_tags` - """ - return _makeTags(tag_str, True) - - -any_open_tag: ParserElement -any_close_tag: ParserElement -any_open_tag, any_close_tag = make_html_tags( - Word(alphas, alphanums + "_:").set_name("any tag") -) - -_htmlEntityMap = {k.rstrip(";"): v for k, v in html.entities.html5.items()} -common_html_entity = Regex("&(?P" + "|".join(_htmlEntityMap) + ");").set_name( - "common HTML entity" -) - - -def replace_html_entity(s, l, t): - """Helper parser action to replace common HTML entities with their special characters""" - return _htmlEntityMap.get(t.entity) - - -class OpAssoc(Enum): - """Enumeration of operator associativity - - used in constructing InfixNotationOperatorSpec for :class:`infix_notation`""" - - LEFT = 1 - RIGHT = 2 - - -InfixNotationOperatorArgType = Union[ - ParserElement, str, Tuple[Union[ParserElement, str], Union[ParserElement, str]] -] -InfixNotationOperatorSpec = Union[ - Tuple[ - InfixNotationOperatorArgType, - int, - OpAssoc, - typing.Optional[ParseAction], - ], - Tuple[ - InfixNotationOperatorArgType, - int, - OpAssoc, - ], -] - - -def infix_notation( - base_expr: ParserElement, - op_list: List[InfixNotationOperatorSpec], - lpar: Union[str, ParserElement] = Suppress("("), - rpar: Union[str, ParserElement] = Suppress(")"), -) -> ParserElement: - """Helper method for constructing grammars of expressions made up of - operators working in a precedence hierarchy. Operators may be unary - or binary, left- or right-associative. Parse actions can also be - attached to operator expressions. The generated parser will also - recognize the use of parentheses to override operator precedences - (see example below). - - Note: if you define a deep operator list, you may see performance - issues when using infix_notation. See - :class:`ParserElement.enable_packrat` for a mechanism to potentially - improve your parser performance. - - Parameters: - - - ``base_expr`` - expression representing the most basic operand to - be used in the expression - - ``op_list`` - list of tuples, one for each operator precedence level - in the expression grammar; each tuple is of the form ``(op_expr, - num_operands, right_left_assoc, (optional)parse_action)``, where: - - - ``op_expr`` is the pyparsing expression for the operator; may also - be a string, which will be converted to a Literal; if ``num_operands`` - is 3, ``op_expr`` is a tuple of two expressions, for the two - operators separating the 3 terms - - ``num_operands`` is the number of terms for this operator (must be 1, - 2, or 3) - - ``right_left_assoc`` is the indicator whether the operator is right - or left associative, using the pyparsing-defined constants - ``OpAssoc.RIGHT`` and ``OpAssoc.LEFT``. - - ``parse_action`` is the parse action to be associated with - expressions matching this operator expression (the parse action - tuple member may be omitted); if the parse action is passed - a tuple or list of functions, this is equivalent to calling - ``set_parse_action(*fn)`` - (:class:`ParserElement.set_parse_action`) - - ``lpar`` - expression for matching left-parentheses; if passed as a - str, then will be parsed as ``Suppress(lpar)``. If lpar is passed as - an expression (such as ``Literal('(')``), then it will be kept in - the parsed results, and grouped with them. (default= ``Suppress('(')``) - - ``rpar`` - expression for matching right-parentheses; if passed as a - str, then will be parsed as ``Suppress(rpar)``. If rpar is passed as - an expression (such as ``Literal(')')``), then it will be kept in - the parsed results, and grouped with them. (default= ``Suppress(')')``) - - Example:: - - # simple example of four-function arithmetic with ints and - # variable names - integer = pyparsing_common.signed_integer - varname = pyparsing_common.identifier - - arith_expr = infix_notation(integer | varname, - [ - ('-', 1, OpAssoc.RIGHT), - (one_of('* /'), 2, OpAssoc.LEFT), - (one_of('+ -'), 2, OpAssoc.LEFT), - ]) - - arith_expr.run_tests(''' - 5+3*6 - (5+3)*6 - -2--11 - ''', full_dump=False) - - prints:: - - 5+3*6 - [[5, '+', [3, '*', 6]]] - - (5+3)*6 - [[[5, '+', 3], '*', 6]] - - (5+x)*y - [[[5, '+', 'x'], '*', 'y']] - - -2--11 - [[['-', 2], '-', ['-', 11]]] - """ - - # captive version of FollowedBy that does not do parse actions or capture results names - class _FB(FollowedBy): - def parseImpl(self, instring, loc, doActions=True): - self.expr.try_parse(instring, loc) - return loc, [] - - _FB.__name__ = "FollowedBy>" - - ret = Forward() - if isinstance(lpar, str): - lpar = Suppress(lpar) - if isinstance(rpar, str): - rpar = Suppress(rpar) - - # if lpar and rpar are not suppressed, wrap in group - if not (isinstance(rpar, Suppress) and isinstance(rpar, Suppress)): - lastExpr = base_expr | Group(lpar + ret + rpar) - else: - lastExpr = base_expr | (lpar + ret + rpar) - - arity: int - rightLeftAssoc: opAssoc - pa: typing.Optional[ParseAction] - opExpr1: ParserElement - opExpr2: ParserElement - for i, operDef in enumerate(op_list): - opExpr, arity, rightLeftAssoc, pa = (operDef + (None,))[:4] # type: ignore[assignment] - if isinstance(opExpr, str_type): - opExpr = ParserElement._literalStringClass(opExpr) - opExpr = typing.cast(ParserElement, opExpr) - if arity == 3: - if not isinstance(opExpr, (tuple, list)) or len(opExpr) != 2: - raise ValueError( - "if numterms=3, opExpr must be a tuple or list of two expressions" - ) - opExpr1, opExpr2 = opExpr - term_name = f"{opExpr1}{opExpr2} term" - else: - term_name = f"{opExpr} term" - - if not 1 <= arity <= 3: - raise ValueError("operator must be unary (1), binary (2), or ternary (3)") - - if rightLeftAssoc not in (OpAssoc.LEFT, OpAssoc.RIGHT): - raise ValueError("operator must indicate right or left associativity") - - thisExpr: ParserElement = Forward().set_name(term_name) - thisExpr = typing.cast(Forward, thisExpr) - if rightLeftAssoc is OpAssoc.LEFT: - if arity == 1: - matchExpr = _FB(lastExpr + opExpr) + Group(lastExpr + opExpr[1, ...]) - elif arity == 2: - if opExpr is not None: - matchExpr = _FB(lastExpr + opExpr + lastExpr) + Group( - lastExpr + (opExpr + lastExpr)[1, ...] - ) - else: - matchExpr = _FB(lastExpr + lastExpr) + Group(lastExpr[2, ...]) - elif arity == 3: - matchExpr = _FB( - lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr - ) + Group(lastExpr + OneOrMore(opExpr1 + lastExpr + opExpr2 + lastExpr)) - elif rightLeftAssoc is OpAssoc.RIGHT: - if arity == 1: - # try to avoid LR with this extra test - if not isinstance(opExpr, Opt): - opExpr = Opt(opExpr) - matchExpr = _FB(opExpr.expr + thisExpr) + Group(opExpr + thisExpr) - elif arity == 2: - if opExpr is not None: - matchExpr = _FB(lastExpr + opExpr + thisExpr) + Group( - lastExpr + (opExpr + thisExpr)[1, ...] - ) - else: - matchExpr = _FB(lastExpr + thisExpr) + Group( - lastExpr + thisExpr[1, ...] - ) - elif arity == 3: - matchExpr = _FB( - lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr - ) + Group(lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr) - if pa: - if isinstance(pa, (tuple, list)): - matchExpr.set_parse_action(*pa) - else: - matchExpr.set_parse_action(pa) - thisExpr <<= (matchExpr | lastExpr).setName(term_name) - lastExpr = thisExpr - ret <<= lastExpr - return ret - - -def indentedBlock(blockStatementExpr, indentStack, indent=True, backup_stacks=[]): - """ - (DEPRECATED - use :class:`IndentedBlock` class instead) - Helper method for defining space-delimited indentation blocks, - such as those used to define block statements in Python source code. - - Parameters: - - - ``blockStatementExpr`` - expression defining syntax of statement that - is repeated within the indented block - - ``indentStack`` - list created by caller to manage indentation stack - (multiple ``statementWithIndentedBlock`` expressions within a single - grammar should share a common ``indentStack``) - - ``indent`` - boolean indicating whether block must be indented beyond - the current level; set to ``False`` for block of left-most statements - (default= ``True``) - - A valid block must contain at least one ``blockStatement``. - - (Note that indentedBlock uses internal parse actions which make it - incompatible with packrat parsing.) - - Example:: - - data = ''' - def A(z): - A1 - B = 100 - G = A2 - A2 - A3 - B - def BB(a,b,c): - BB1 - def BBA(): - bba1 - bba2 - bba3 - C - D - def spam(x,y): - def eggs(z): - pass - ''' - - - indentStack = [1] - stmt = Forward() - - identifier = Word(alphas, alphanums) - funcDecl = ("def" + identifier + Group("(" + Opt(delimitedList(identifier)) + ")") + ":") - func_body = indentedBlock(stmt, indentStack) - funcDef = Group(funcDecl + func_body) - - rvalue = Forward() - funcCall = Group(identifier + "(" + Opt(delimitedList(rvalue)) + ")") - rvalue << (funcCall | identifier | Word(nums)) - assignment = Group(identifier + "=" + rvalue) - stmt << (funcDef | assignment | identifier) - - module_body = stmt[1, ...] - - parseTree = module_body.parseString(data) - parseTree.pprint() - - prints:: - - [['def', - 'A', - ['(', 'z', ')'], - ':', - [['A1'], [['B', '=', '100']], [['G', '=', 'A2']], ['A2'], ['A3']]], - 'B', - ['def', - 'BB', - ['(', 'a', 'b', 'c', ')'], - ':', - [['BB1'], [['def', 'BBA', ['(', ')'], ':', [['bba1'], ['bba2'], ['bba3']]]]]], - 'C', - 'D', - ['def', - 'spam', - ['(', 'x', 'y', ')'], - ':', - [[['def', 'eggs', ['(', 'z', ')'], ':', [['pass']]]]]]] - """ - backup_stacks.append(indentStack[:]) - - def reset_stack(): - indentStack[:] = backup_stacks[-1] - - def checkPeerIndent(s, l, t): - if l >= len(s): - return - curCol = col(l, s) - if curCol != indentStack[-1]: - if curCol > indentStack[-1]: - raise ParseException(s, l, "illegal nesting") - raise ParseException(s, l, "not a peer entry") - - def checkSubIndent(s, l, t): - curCol = col(l, s) - if curCol > indentStack[-1]: - indentStack.append(curCol) - else: - raise ParseException(s, l, "not a subentry") - - def checkUnindent(s, l, t): - if l >= len(s): - return - curCol = col(l, s) - if not (indentStack and curCol in indentStack): - raise ParseException(s, l, "not an unindent") - if curCol < indentStack[-1]: - indentStack.pop() - - NL = OneOrMore(LineEnd().set_whitespace_chars("\t ").suppress()) - INDENT = (Empty() + Empty().set_parse_action(checkSubIndent)).set_name("INDENT") - PEER = Empty().set_parse_action(checkPeerIndent).set_name("") - UNDENT = Empty().set_parse_action(checkUnindent).set_name("UNINDENT") - if indent: - smExpr = Group( - Opt(NL) - + INDENT - + OneOrMore(PEER + Group(blockStatementExpr) + Opt(NL)) - + UNDENT - ) - else: - smExpr = Group( - Opt(NL) - + OneOrMore(PEER + Group(blockStatementExpr) + Opt(NL)) - + Opt(UNDENT) - ) - - # add a parse action to remove backup_stack from list of backups - smExpr.add_parse_action( - lambda: backup_stacks.pop(-1) and None if backup_stacks else None - ) - smExpr.set_fail_action(lambda a, b, c, d: reset_stack()) - blockStatementExpr.ignore(_bslash + LineEnd()) - return smExpr.set_name("indented block") - - -# it's easy to get these comment structures wrong - they're very common, so may as well make them available -c_style_comment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + "*/").set_name( - "C style comment" -) -"Comment of the form ``/* ... */``" - -html_comment = Regex(r"").set_name("HTML comment") -"Comment of the form ````" - -rest_of_line = Regex(r".*").leave_whitespace().set_name("rest of line") -dbl_slash_comment = Regex(r"//(?:\\\n|[^\n])*").set_name("// comment") -"Comment of the form ``// ... (to end of line)``" - -cpp_style_comment = Combine( - Regex(r"/\*(?:[^*]|\*(?!/))*") + "*/" | dbl_slash_comment -).set_name("C++ style comment") -"Comment of either form :class:`c_style_comment` or :class:`dbl_slash_comment`" - -java_style_comment = cpp_style_comment -"Same as :class:`cpp_style_comment`" - -python_style_comment = Regex(r"#.*").set_name("Python style comment") -"Comment of the form ``# ... (to end of line)``" - - -# build list of built-in expressions, for future reference if a global default value -# gets updated -_builtin_exprs: List[ParserElement] = [ - v for v in vars().values() if isinstance(v, ParserElement) -] - - -# compatibility function, superseded by DelimitedList class -def delimited_list( - expr: Union[str, ParserElement], - delim: Union[str, ParserElement] = ",", - combine: bool = False, - min: typing.Optional[int] = None, - max: typing.Optional[int] = None, - *, - allow_trailing_delim: bool = False, -) -> ParserElement: - """(DEPRECATED - use :class:`DelimitedList` class)""" - return DelimitedList( - expr, delim, combine, min, max, allow_trailing_delim=allow_trailing_delim - ) - - -# pre-PEP8 compatible names -# fmt: off -opAssoc = OpAssoc -anyOpenTag = any_open_tag -anyCloseTag = any_close_tag -commonHTMLEntity = common_html_entity -cStyleComment = c_style_comment -htmlComment = html_comment -restOfLine = rest_of_line -dblSlashComment = dbl_slash_comment -cppStyleComment = cpp_style_comment -javaStyleComment = java_style_comment -pythonStyleComment = python_style_comment - -@replaced_by_pep8(DelimitedList) -def delimitedList(): ... - -@replaced_by_pep8(DelimitedList) -def delimited_list(): ... - -@replaced_by_pep8(counted_array) -def countedArray(): ... - -@replaced_by_pep8(match_previous_literal) -def matchPreviousLiteral(): ... - -@replaced_by_pep8(match_previous_expr) -def matchPreviousExpr(): ... - -@replaced_by_pep8(one_of) -def oneOf(): ... - -@replaced_by_pep8(dict_of) -def dictOf(): ... - -@replaced_by_pep8(original_text_for) -def originalTextFor(): ... - -@replaced_by_pep8(nested_expr) -def nestedExpr(): ... - -@replaced_by_pep8(make_html_tags) -def makeHTMLTags(): ... - -@replaced_by_pep8(make_xml_tags) -def makeXMLTags(): ... - -@replaced_by_pep8(replace_html_entity) -def replaceHTMLEntity(): ... - -@replaced_by_pep8(infix_notation) -def infixNotation(): ... -# fmt: on diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/py.typed b/myenv/Lib/site-packages/pip/_vendor/pyparsing/py.typed deleted file mode 100644 index e69de29..0000000 diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/results.py b/myenv/Lib/site-packages/pip/_vendor/pyparsing/results.py deleted file mode 100644 index 0313049..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/pyparsing/results.py +++ /dev/null @@ -1,796 +0,0 @@ -# results.py -from collections.abc import ( - MutableMapping, - Mapping, - MutableSequence, - Iterator, - Sequence, - Container, -) -import pprint -from typing import Tuple, Any, Dict, Set, List - -str_type: Tuple[type, ...] = (str, bytes) -_generator_type = type((_ for _ in ())) - - -class _ParseResultsWithOffset: - tup: Tuple["ParseResults", int] - __slots__ = ["tup"] - - def __init__(self, p1: "ParseResults", p2: int): - self.tup: Tuple[ParseResults, int] = (p1, p2) - - def __getitem__(self, i): - return self.tup[i] - - def __getstate__(self): - return self.tup - - def __setstate__(self, *args): - self.tup = args[0] - - -class ParseResults: - """Structured parse results, to provide multiple means of access to - the parsed data: - - - as a list (``len(results)``) - - by list index (``results[0], results[1]``, etc.) - - by attribute (``results.`` - see :class:`ParserElement.set_results_name`) - - Example:: - - integer = Word(nums) - date_str = (integer.set_results_name("year") + '/' - + integer.set_results_name("month") + '/' - + integer.set_results_name("day")) - # equivalent form: - # date_str = (integer("year") + '/' - # + integer("month") + '/' - # + integer("day")) - - # parse_string returns a ParseResults object - result = date_str.parse_string("1999/12/31") - - def test(s, fn=repr): - print(f"{s} -> {fn(eval(s))}") - test("list(result)") - test("result[0]") - test("result['month']") - test("result.day") - test("'month' in result") - test("'minutes' in result") - test("result.dump()", str) - - prints:: - - list(result) -> ['1999', '/', '12', '/', '31'] - result[0] -> '1999' - result['month'] -> '12' - result.day -> '31' - 'month' in result -> True - 'minutes' in result -> False - result.dump() -> ['1999', '/', '12', '/', '31'] - - day: '31' - - month: '12' - - year: '1999' - """ - - _null_values: Tuple[Any, ...] = (None, [], ()) - - _name: str - _parent: "ParseResults" - _all_names: Set[str] - _modal: bool - _toklist: List[Any] - _tokdict: Dict[str, Any] - - __slots__ = ( - "_name", - "_parent", - "_all_names", - "_modal", - "_toklist", - "_tokdict", - ) - - class List(list): - """ - Simple wrapper class to distinguish parsed list results that should be preserved - as actual Python lists, instead of being converted to :class:`ParseResults`:: - - LBRACK, RBRACK = map(pp.Suppress, "[]") - element = pp.Forward() - item = ppc.integer - element_list = LBRACK + pp.DelimitedList(element) + RBRACK - - # add parse actions to convert from ParseResults to actual Python collection types - def as_python_list(t): - return pp.ParseResults.List(t.as_list()) - element_list.add_parse_action(as_python_list) - - element <<= item | element_list - - element.run_tests(''' - 100 - [2,3,4] - [[2, 1],3,4] - [(2, 1),3,4] - (2,3,4) - ''', post_parse=lambda s, r: (r[0], type(r[0]))) - - prints:: - - 100 - (100, ) - - [2,3,4] - ([2, 3, 4], ) - - [[2, 1],3,4] - ([[2, 1], 3, 4], ) - - (Used internally by :class:`Group` when `aslist=True`.) - """ - - def __new__(cls, contained=None): - if contained is None: - contained = [] - - if not isinstance(contained, list): - raise TypeError( - f"{cls.__name__} may only be constructed with a list, not {type(contained).__name__}" - ) - - return list.__new__(cls) - - def __new__(cls, toklist=None, name=None, **kwargs): - if isinstance(toklist, ParseResults): - return toklist - self = object.__new__(cls) - self._name = None - self._parent = None - self._all_names = set() - - if toklist is None: - self._toklist = [] - elif isinstance(toklist, (list, _generator_type)): - self._toklist = ( - [toklist[:]] - if isinstance(toklist, ParseResults.List) - else list(toklist) - ) - else: - self._toklist = [toklist] - self._tokdict = dict() - return self - - # Performance tuning: we construct a *lot* of these, so keep this - # constructor as small and fast as possible - def __init__( - self, toklist=None, name=None, asList=True, modal=True, isinstance=isinstance - ): - self._tokdict: Dict[str, _ParseResultsWithOffset] - self._modal = modal - if name is not None and name != "": - if isinstance(name, int): - name = str(name) - if not modal: - self._all_names = {name} - self._name = name - if toklist not in self._null_values: - if isinstance(toklist, (str_type, type)): - toklist = [toklist] - if asList: - if isinstance(toklist, ParseResults): - self[name] = _ParseResultsWithOffset( - ParseResults(toklist._toklist), 0 - ) - else: - self[name] = _ParseResultsWithOffset( - ParseResults(toklist[0]), 0 - ) - self[name]._name = name - else: - try: - self[name] = toklist[0] - except (KeyError, TypeError, IndexError): - if toklist is not self: - self[name] = toklist - else: - self._name = name - - def __getitem__(self, i): - if isinstance(i, (int, slice)): - return self._toklist[i] - else: - if i not in self._all_names: - return self._tokdict[i][-1][0] - else: - return ParseResults([v[0] for v in self._tokdict[i]]) - - def __setitem__(self, k, v, isinstance=isinstance): - if isinstance(v, _ParseResultsWithOffset): - self._tokdict[k] = self._tokdict.get(k, list()) + [v] - sub = v[0] - elif isinstance(k, (int, slice)): - self._toklist[k] = v - sub = v - else: - self._tokdict[k] = self._tokdict.get(k, list()) + [ - _ParseResultsWithOffset(v, 0) - ] - sub = v - if isinstance(sub, ParseResults): - sub._parent = self - - def __delitem__(self, i): - if isinstance(i, (int, slice)): - mylen = len(self._toklist) - del self._toklist[i] - - # convert int to slice - if isinstance(i, int): - if i < 0: - i += mylen - i = slice(i, i + 1) - # get removed indices - removed = list(range(*i.indices(mylen))) - removed.reverse() - # fixup indices in token dictionary - for name, occurrences in self._tokdict.items(): - for j in removed: - for k, (value, position) in enumerate(occurrences): - occurrences[k] = _ParseResultsWithOffset( - value, position - (position > j) - ) - else: - del self._tokdict[i] - - def __contains__(self, k) -> bool: - return k in self._tokdict - - def __len__(self) -> int: - return len(self._toklist) - - def __bool__(self) -> bool: - return not not (self._toklist or self._tokdict) - - def __iter__(self) -> Iterator: - return iter(self._toklist) - - def __reversed__(self) -> Iterator: - return iter(self._toklist[::-1]) - - def keys(self): - return iter(self._tokdict) - - def values(self): - return (self[k] for k in self.keys()) - - def items(self): - return ((k, self[k]) for k in self.keys()) - - def haskeys(self) -> bool: - """ - Since ``keys()`` returns an iterator, this method is helpful in bypassing - code that looks for the existence of any defined results names.""" - return not not self._tokdict - - def pop(self, *args, **kwargs): - """ - Removes and returns item at specified index (default= ``last``). - Supports both ``list`` and ``dict`` semantics for ``pop()``. If - passed no argument or an integer argument, it will use ``list`` - semantics and pop tokens from the list of parsed tokens. If passed - a non-integer argument (most likely a string), it will use ``dict`` - semantics and pop the corresponding value from any defined results - names. A second default return value argument is supported, just as in - ``dict.pop()``. - - Example:: - - numlist = Word(nums)[...] - print(numlist.parse_string("0 123 321")) # -> ['0', '123', '321'] - - def remove_first(tokens): - tokens.pop(0) - numlist.add_parse_action(remove_first) - print(numlist.parse_string("0 123 321")) # -> ['123', '321'] - - label = Word(alphas) - patt = label("LABEL") + Word(nums)[1, ...] - print(patt.parse_string("AAB 123 321").dump()) - - # Use pop() in a parse action to remove named result (note that corresponding value is not - # removed from list form of results) - def remove_LABEL(tokens): - tokens.pop("LABEL") - return tokens - patt.add_parse_action(remove_LABEL) - print(patt.parse_string("AAB 123 321").dump()) - - prints:: - - ['AAB', '123', '321'] - - LABEL: 'AAB' - - ['AAB', '123', '321'] - """ - if not args: - args = [-1] - for k, v in kwargs.items(): - if k == "default": - args = (args[0], v) - else: - raise TypeError(f"pop() got an unexpected keyword argument {k!r}") - if isinstance(args[0], int) or len(args) == 1 or args[0] in self: - index = args[0] - ret = self[index] - del self[index] - return ret - else: - defaultvalue = args[1] - return defaultvalue - - def get(self, key, default_value=None): - """ - Returns named result matching the given key, or if there is no - such name, then returns the given ``default_value`` or ``None`` if no - ``default_value`` is specified. - - Similar to ``dict.get()``. - - Example:: - - integer = Word(nums) - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - result = date_str.parse_string("1999/12/31") - print(result.get("year")) # -> '1999' - print(result.get("hour", "not specified")) # -> 'not specified' - print(result.get("hour")) # -> None - """ - if key in self: - return self[key] - else: - return default_value - - def insert(self, index, ins_string): - """ - Inserts new element at location index in the list of parsed tokens. - - Similar to ``list.insert()``. - - Example:: - - numlist = Word(nums)[...] - print(numlist.parse_string("0 123 321")) # -> ['0', '123', '321'] - - # use a parse action to insert the parse location in the front of the parsed results - def insert_locn(locn, tokens): - tokens.insert(0, locn) - numlist.add_parse_action(insert_locn) - print(numlist.parse_string("0 123 321")) # -> [0, '0', '123', '321'] - """ - self._toklist.insert(index, ins_string) - # fixup indices in token dictionary - for name, occurrences in self._tokdict.items(): - for k, (value, position) in enumerate(occurrences): - occurrences[k] = _ParseResultsWithOffset( - value, position + (position > index) - ) - - def append(self, item): - """ - Add single element to end of ``ParseResults`` list of elements. - - Example:: - - numlist = Word(nums)[...] - print(numlist.parse_string("0 123 321")) # -> ['0', '123', '321'] - - # use a parse action to compute the sum of the parsed integers, and add it to the end - def append_sum(tokens): - tokens.append(sum(map(int, tokens))) - numlist.add_parse_action(append_sum) - print(numlist.parse_string("0 123 321")) # -> ['0', '123', '321', 444] - """ - self._toklist.append(item) - - def extend(self, itemseq): - """ - Add sequence of elements to end of ``ParseResults`` list of elements. - - Example:: - - patt = Word(alphas)[1, ...] - - # use a parse action to append the reverse of the matched strings, to make a palindrome - def make_palindrome(tokens): - tokens.extend(reversed([t[::-1] for t in tokens])) - return ''.join(tokens) - patt.add_parse_action(make_palindrome) - print(patt.parse_string("lskdj sdlkjf lksd")) # -> 'lskdjsdlkjflksddsklfjkldsjdksl' - """ - if isinstance(itemseq, ParseResults): - self.__iadd__(itemseq) - else: - self._toklist.extend(itemseq) - - def clear(self): - """ - Clear all elements and results names. - """ - del self._toklist[:] - self._tokdict.clear() - - def __getattr__(self, name): - try: - return self[name] - except KeyError: - if name.startswith("__"): - raise AttributeError(name) - return "" - - def __add__(self, other: "ParseResults") -> "ParseResults": - ret = self.copy() - ret += other - return ret - - def __iadd__(self, other: "ParseResults") -> "ParseResults": - if not other: - return self - - if other._tokdict: - offset = len(self._toklist) - addoffset = lambda a: offset if a < 0 else a + offset - otheritems = other._tokdict.items() - otherdictitems = [ - (k, _ParseResultsWithOffset(v[0], addoffset(v[1]))) - for k, vlist in otheritems - for v in vlist - ] - for k, v in otherdictitems: - self[k] = v - if isinstance(v[0], ParseResults): - v[0]._parent = self - - self._toklist += other._toklist - self._all_names |= other._all_names - return self - - def __radd__(self, other) -> "ParseResults": - if isinstance(other, int) and other == 0: - # useful for merging many ParseResults using sum() builtin - return self.copy() - else: - # this may raise a TypeError - so be it - return other + self - - def __repr__(self) -> str: - return f"{type(self).__name__}({self._toklist!r}, {self.as_dict()})" - - def __str__(self) -> str: - return ( - "[" - + ", ".join( - [ - str(i) if isinstance(i, ParseResults) else repr(i) - for i in self._toklist - ] - ) - + "]" - ) - - def _asStringList(self, sep=""): - out = [] - for item in self._toklist: - if out and sep: - out.append(sep) - if isinstance(item, ParseResults): - out += item._asStringList() - else: - out.append(str(item)) - return out - - def as_list(self) -> list: - """ - Returns the parse results as a nested list of matching tokens, all converted to strings. - - Example:: - - patt = Word(alphas)[1, ...] - result = patt.parse_string("sldkj lsdkj sldkj") - # even though the result prints in string-like form, it is actually a pyparsing ParseResults - print(type(result), result) # -> ['sldkj', 'lsdkj', 'sldkj'] - - # Use as_list() to create an actual list - result_list = result.as_list() - print(type(result_list), result_list) # -> ['sldkj', 'lsdkj', 'sldkj'] - """ - return [ - res.as_list() if isinstance(res, ParseResults) else res - for res in self._toklist - ] - - def as_dict(self) -> dict: - """ - Returns the named parse results as a nested dictionary. - - Example:: - - integer = Word(nums) - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - result = date_str.parse_string('12/31/1999') - print(type(result), repr(result)) # -> (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]}) - - result_dict = result.as_dict() - print(type(result_dict), repr(result_dict)) # -> {'day': '1999', 'year': '12', 'month': '31'} - - # even though a ParseResults supports dict-like access, sometime you just need to have a dict - import json - print(json.dumps(result)) # -> Exception: TypeError: ... is not JSON serializable - print(json.dumps(result.as_dict())) # -> {"month": "31", "day": "1999", "year": "12"} - """ - - def to_item(obj): - if isinstance(obj, ParseResults): - return obj.as_dict() if obj.haskeys() else [to_item(v) for v in obj] - else: - return obj - - return dict((k, to_item(v)) for k, v in self.items()) - - def copy(self) -> "ParseResults": - """ - Returns a new shallow copy of a :class:`ParseResults` object. `ParseResults` - items contained within the source are shared with the copy. Use - :class:`ParseResults.deepcopy()` to create a copy with its own separate - content values. - """ - ret = ParseResults(self._toklist) - ret._tokdict = self._tokdict.copy() - ret._parent = self._parent - ret._all_names |= self._all_names - ret._name = self._name - return ret - - def deepcopy(self) -> "ParseResults": - """ - Returns a new deep copy of a :class:`ParseResults` object. - """ - ret = self.copy() - # replace values with copies if they are of known mutable types - for i, obj in enumerate(self._toklist): - if isinstance(obj, ParseResults): - self._toklist[i] = obj.deepcopy() - elif isinstance(obj, (str, bytes)): - pass - elif isinstance(obj, MutableMapping): - self._toklist[i] = dest = type(obj)() - for k, v in obj.items(): - dest[k] = v.deepcopy() if isinstance(v, ParseResults) else v - elif isinstance(obj, Container): - self._toklist[i] = type(obj)( - v.deepcopy() if isinstance(v, ParseResults) else v for v in obj - ) - return ret - - def get_name(self): - r""" - Returns the results name for this token expression. Useful when several - different expressions might match at a particular location. - - Example:: - - integer = Word(nums) - ssn_expr = Regex(r"\d\d\d-\d\d-\d\d\d\d") - house_number_expr = Suppress('#') + Word(nums, alphanums) - user_data = (Group(house_number_expr)("house_number") - | Group(ssn_expr)("ssn") - | Group(integer)("age")) - user_info = user_data[1, ...] - - result = user_info.parse_string("22 111-22-3333 #221B") - for item in result: - print(item.get_name(), ':', item[0]) - - prints:: - - age : 22 - ssn : 111-22-3333 - house_number : 221B - """ - if self._name: - return self._name - elif self._parent: - par: "ParseResults" = self._parent - parent_tokdict_items = par._tokdict.items() - return next( - ( - k - for k, vlist in parent_tokdict_items - for v, loc in vlist - if v is self - ), - None, - ) - elif ( - len(self) == 1 - and len(self._tokdict) == 1 - and next(iter(self._tokdict.values()))[0][1] in (0, -1) - ): - return next(iter(self._tokdict.keys())) - else: - return None - - def dump(self, indent="", full=True, include_list=True, _depth=0) -> str: - """ - Diagnostic method for listing out the contents of - a :class:`ParseResults`. Accepts an optional ``indent`` argument so - that this string can be embedded in a nested display of other data. - - Example:: - - integer = Word(nums) - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - result = date_str.parse_string('1999/12/31') - print(result.dump()) - - prints:: - - ['1999', '/', '12', '/', '31'] - - day: '31' - - month: '12' - - year: '1999' - """ - out = [] - NL = "\n" - out.append(indent + str(self.as_list()) if include_list else "") - - if full: - if self.haskeys(): - items = sorted((str(k), v) for k, v in self.items()) - for k, v in items: - if out: - out.append(NL) - out.append(f"{indent}{(' ' * _depth)}- {k}: ") - if isinstance(v, ParseResults): - if v: - out.append( - v.dump( - indent=indent, - full=full, - include_list=include_list, - _depth=_depth + 1, - ) - ) - else: - out.append(str(v)) - else: - out.append(repr(v)) - if any(isinstance(vv, ParseResults) for vv in self): - v = self - for i, vv in enumerate(v): - if isinstance(vv, ParseResults): - out.append( - "\n{}{}[{}]:\n{}{}{}".format( - indent, - (" " * (_depth)), - i, - indent, - (" " * (_depth + 1)), - vv.dump( - indent=indent, - full=full, - include_list=include_list, - _depth=_depth + 1, - ), - ) - ) - else: - out.append( - "\n%s%s[%d]:\n%s%s%s" - % ( - indent, - (" " * (_depth)), - i, - indent, - (" " * (_depth + 1)), - str(vv), - ) - ) - - return "".join(out) - - def pprint(self, *args, **kwargs): - """ - Pretty-printer for parsed results as a list, using the - `pprint `_ module. - Accepts additional positional or keyword args as defined for - `pprint.pprint `_ . - - Example:: - - ident = Word(alphas, alphanums) - num = Word(nums) - func = Forward() - term = ident | num | Group('(' + func + ')') - func <<= ident + Group(Optional(DelimitedList(term))) - result = func.parse_string("fna a,b,(fnb c,d,200),100") - result.pprint(width=40) - - prints:: - - ['fna', - ['a', - 'b', - ['(', 'fnb', ['c', 'd', '200'], ')'], - '100']] - """ - pprint.pprint(self.as_list(), *args, **kwargs) - - # add support for pickle protocol - def __getstate__(self): - return ( - self._toklist, - ( - self._tokdict.copy(), - None, - self._all_names, - self._name, - ), - ) - - def __setstate__(self, state): - self._toklist, (self._tokdict, par, inAccumNames, self._name) = state - self._all_names = set(inAccumNames) - self._parent = None - - def __getnewargs__(self): - return self._toklist, self._name - - def __dir__(self): - return dir(type(self)) + list(self.keys()) - - @classmethod - def from_dict(cls, other, name=None) -> "ParseResults": - """ - Helper classmethod to construct a ``ParseResults`` from a ``dict``, preserving the - name-value relations as results names. If an optional ``name`` argument is - given, a nested ``ParseResults`` will be returned. - """ - - def is_iterable(obj): - try: - iter(obj) - except Exception: - return False - # str's are iterable, but in pyparsing, we don't want to iterate over them - else: - return not isinstance(obj, str_type) - - ret = cls([]) - for k, v in other.items(): - if isinstance(v, Mapping): - ret += cls.from_dict(v, name=k) - else: - ret += cls([v], name=k, asList=is_iterable(v)) - if name is not None: - ret = cls([ret], name=name) - return ret - - asList = as_list - """Deprecated - use :class:`as_list`""" - asDict = as_dict - """Deprecated - use :class:`as_dict`""" - getName = get_name - """Deprecated - use :class:`get_name`""" - - -MutableMapping.register(ParseResults) -MutableSequence.register(ParseResults) diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/testing.py b/myenv/Lib/site-packages/pip/_vendor/pyparsing/testing.py deleted file mode 100644 index 6a254c1..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/pyparsing/testing.py +++ /dev/null @@ -1,331 +0,0 @@ -# testing.py - -from contextlib import contextmanager -import typing - -from .core import ( - ParserElement, - ParseException, - Keyword, - __diag__, - __compat__, -) - - -class pyparsing_test: - """ - namespace class for classes useful in writing unit tests - """ - - class reset_pyparsing_context: - """ - Context manager to be used when writing unit tests that modify pyparsing config values: - - packrat parsing - - bounded recursion parsing - - default whitespace characters. - - default keyword characters - - literal string auto-conversion class - - __diag__ settings - - Example:: - - with reset_pyparsing_context(): - # test that literals used to construct a grammar are automatically suppressed - ParserElement.inlineLiteralsUsing(Suppress) - - term = Word(alphas) | Word(nums) - group = Group('(' + term[...] + ')') - - # assert that the '()' characters are not included in the parsed tokens - self.assertParseAndCheckList(group, "(abc 123 def)", ['abc', '123', 'def']) - - # after exiting context manager, literals are converted to Literal expressions again - """ - - def __init__(self): - self._save_context = {} - - def save(self): - self._save_context["default_whitespace"] = ParserElement.DEFAULT_WHITE_CHARS - self._save_context["default_keyword_chars"] = Keyword.DEFAULT_KEYWORD_CHARS - - self._save_context[ - "literal_string_class" - ] = ParserElement._literalStringClass - - self._save_context["verbose_stacktrace"] = ParserElement.verbose_stacktrace - - self._save_context["packrat_enabled"] = ParserElement._packratEnabled - if ParserElement._packratEnabled: - self._save_context[ - "packrat_cache_size" - ] = ParserElement.packrat_cache.size - else: - self._save_context["packrat_cache_size"] = None - self._save_context["packrat_parse"] = ParserElement._parse - self._save_context[ - "recursion_enabled" - ] = ParserElement._left_recursion_enabled - - self._save_context["__diag__"] = { - name: getattr(__diag__, name) for name in __diag__._all_names - } - - self._save_context["__compat__"] = { - "collect_all_And_tokens": __compat__.collect_all_And_tokens - } - - return self - - def restore(self): - # reset pyparsing global state - if ( - ParserElement.DEFAULT_WHITE_CHARS - != self._save_context["default_whitespace"] - ): - ParserElement.set_default_whitespace_chars( - self._save_context["default_whitespace"] - ) - - ParserElement.verbose_stacktrace = self._save_context["verbose_stacktrace"] - - Keyword.DEFAULT_KEYWORD_CHARS = self._save_context["default_keyword_chars"] - ParserElement.inlineLiteralsUsing( - self._save_context["literal_string_class"] - ) - - for name, value in self._save_context["__diag__"].items(): - (__diag__.enable if value else __diag__.disable)(name) - - ParserElement._packratEnabled = False - if self._save_context["packrat_enabled"]: - ParserElement.enable_packrat(self._save_context["packrat_cache_size"]) - else: - ParserElement._parse = self._save_context["packrat_parse"] - ParserElement._left_recursion_enabled = self._save_context[ - "recursion_enabled" - ] - - __compat__.collect_all_And_tokens = self._save_context["__compat__"] - - return self - - def copy(self): - ret = type(self)() - ret._save_context.update(self._save_context) - return ret - - def __enter__(self): - return self.save() - - def __exit__(self, *args): - self.restore() - - class TestParseResultsAsserts: - """ - A mixin class to add parse results assertion methods to normal unittest.TestCase classes. - """ - - def assertParseResultsEquals( - self, result, expected_list=None, expected_dict=None, msg=None - ): - """ - Unit test assertion to compare a :class:`ParseResults` object with an optional ``expected_list``, - and compare any defined results names with an optional ``expected_dict``. - """ - if expected_list is not None: - self.assertEqual(expected_list, result.as_list(), msg=msg) - if expected_dict is not None: - self.assertEqual(expected_dict, result.as_dict(), msg=msg) - - def assertParseAndCheckList( - self, expr, test_string, expected_list, msg=None, verbose=True - ): - """ - Convenience wrapper assert to test a parser element and input string, and assert that - the resulting ``ParseResults.asList()`` is equal to the ``expected_list``. - """ - result = expr.parse_string(test_string, parse_all=True) - if verbose: - print(result.dump()) - else: - print(result.as_list()) - self.assertParseResultsEquals(result, expected_list=expected_list, msg=msg) - - def assertParseAndCheckDict( - self, expr, test_string, expected_dict, msg=None, verbose=True - ): - """ - Convenience wrapper assert to test a parser element and input string, and assert that - the resulting ``ParseResults.asDict()`` is equal to the ``expected_dict``. - """ - result = expr.parse_string(test_string, parseAll=True) - if verbose: - print(result.dump()) - else: - print(result.as_list()) - self.assertParseResultsEquals(result, expected_dict=expected_dict, msg=msg) - - def assertRunTestResults( - self, run_tests_report, expected_parse_results=None, msg=None - ): - """ - Unit test assertion to evaluate output of ``ParserElement.runTests()``. If a list of - list-dict tuples is given as the ``expected_parse_results`` argument, then these are zipped - with the report tuples returned by ``runTests`` and evaluated using ``assertParseResultsEquals``. - Finally, asserts that the overall ``runTests()`` success value is ``True``. - - :param run_tests_report: tuple(bool, [tuple(str, ParseResults or Exception)]) returned from runTests - :param expected_parse_results (optional): [tuple(str, list, dict, Exception)] - """ - run_test_success, run_test_results = run_tests_report - - if expected_parse_results is not None: - merged = [ - (*rpt, expected) - for rpt, expected in zip(run_test_results, expected_parse_results) - ] - for test_string, result, expected in merged: - # expected should be a tuple containing a list and/or a dict or an exception, - # and optional failure message string - # an empty tuple will skip any result validation - fail_msg = next( - (exp for exp in expected if isinstance(exp, str)), None - ) - expected_exception = next( - ( - exp - for exp in expected - if isinstance(exp, type) and issubclass(exp, Exception) - ), - None, - ) - if expected_exception is not None: - with self.assertRaises( - expected_exception=expected_exception, msg=fail_msg or msg - ): - if isinstance(result, Exception): - raise result - else: - expected_list = next( - (exp for exp in expected if isinstance(exp, list)), None - ) - expected_dict = next( - (exp for exp in expected if isinstance(exp, dict)), None - ) - if (expected_list, expected_dict) != (None, None): - self.assertParseResultsEquals( - result, - expected_list=expected_list, - expected_dict=expected_dict, - msg=fail_msg or msg, - ) - else: - # warning here maybe? - print(f"no validation for {test_string!r}") - - # do this last, in case some specific test results can be reported instead - self.assertTrue( - run_test_success, msg=msg if msg is not None else "failed runTests" - ) - - @contextmanager - def assertRaisesParseException(self, exc_type=ParseException, msg=None): - with self.assertRaises(exc_type, msg=msg): - yield - - @staticmethod - def with_line_numbers( - s: str, - start_line: typing.Optional[int] = None, - end_line: typing.Optional[int] = None, - expand_tabs: bool = True, - eol_mark: str = "|", - mark_spaces: typing.Optional[str] = None, - mark_control: typing.Optional[str] = None, - ) -> str: - """ - Helpful method for debugging a parser - prints a string with line and column numbers. - (Line and column numbers are 1-based.) - - :param s: tuple(bool, str - string to be printed with line and column numbers - :param start_line: int - (optional) starting line number in s to print (default=1) - :param end_line: int - (optional) ending line number in s to print (default=len(s)) - :param expand_tabs: bool - (optional) expand tabs to spaces, to match the pyparsing default - :param eol_mark: str - (optional) string to mark the end of lines, helps visualize trailing spaces (default="|") - :param mark_spaces: str - (optional) special character to display in place of spaces - :param mark_control: str - (optional) convert non-printing control characters to a placeholding - character; valid values: - - "unicode" - replaces control chars with Unicode symbols, such as "␍" and "␊" - - any single character string - replace control characters with given string - - None (default) - string is displayed as-is - - :return: str - input string with leading line numbers and column number headers - """ - if expand_tabs: - s = s.expandtabs() - if mark_control is not None: - mark_control = typing.cast(str, mark_control) - if mark_control == "unicode": - transtable_map = { - c: u for c, u in zip(range(0, 33), range(0x2400, 0x2433)) - } - transtable_map[127] = 0x2421 - tbl = str.maketrans(transtable_map) - eol_mark = "" - else: - ord_mark_control = ord(mark_control) - tbl = str.maketrans( - {c: ord_mark_control for c in list(range(0, 32)) + [127]} - ) - s = s.translate(tbl) - if mark_spaces is not None and mark_spaces != " ": - if mark_spaces == "unicode": - tbl = str.maketrans({9: 0x2409, 32: 0x2423}) - s = s.translate(tbl) - else: - s = s.replace(" ", mark_spaces) - if start_line is None: - start_line = 1 - if end_line is None: - end_line = len(s) - end_line = min(end_line, len(s)) - start_line = min(max(1, start_line), end_line) - - if mark_control != "unicode": - s_lines = s.splitlines()[start_line - 1 : end_line] - else: - s_lines = [line + "␊" for line in s.split("␊")[start_line - 1 : end_line]] - if not s_lines: - return "" - - lineno_width = len(str(end_line)) - max_line_len = max(len(line) for line in s_lines) - lead = " " * (lineno_width + 1) - if max_line_len >= 99: - header0 = ( - lead - + "".join( - f"{' ' * 99}{(i + 1) % 100}" - for i in range(max(max_line_len // 100, 1)) - ) - + "\n" - ) - else: - header0 = "" - header1 = ( - header0 - + lead - + "".join(f" {(i + 1) % 10}" for i in range(-(-max_line_len // 10))) - + "\n" - ) - header2 = lead + "1234567890" * (-(-max_line_len // 10)) + "\n" - return ( - header1 - + header2 - + "\n".join( - f"{i:{lineno_width}d}:{line}{eol_mark}" - for i, line in enumerate(s_lines, start=start_line) - ) - + "\n" - ) diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/unicode.py b/myenv/Lib/site-packages/pip/_vendor/pyparsing/unicode.py deleted file mode 100644 index ec0b3a4..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/pyparsing/unicode.py +++ /dev/null @@ -1,361 +0,0 @@ -# unicode.py - -import sys -from itertools import filterfalse -from typing import List, Tuple, Union - - -class _lazyclassproperty: - def __init__(self, fn): - self.fn = fn - self.__doc__ = fn.__doc__ - self.__name__ = fn.__name__ - - def __get__(self, obj, cls): - if cls is None: - cls = type(obj) - if not hasattr(cls, "_intern") or any( - cls._intern is getattr(superclass, "_intern", []) - for superclass in cls.__mro__[1:] - ): - cls._intern = {} - attrname = self.fn.__name__ - if attrname not in cls._intern: - cls._intern[attrname] = self.fn(cls) - return cls._intern[attrname] - - -UnicodeRangeList = List[Union[Tuple[int, int], Tuple[int]]] - - -class unicode_set: - """ - A set of Unicode characters, for language-specific strings for - ``alphas``, ``nums``, ``alphanums``, and ``printables``. - A unicode_set is defined by a list of ranges in the Unicode character - set, in a class attribute ``_ranges``. Ranges can be specified using - 2-tuples or a 1-tuple, such as:: - - _ranges = [ - (0x0020, 0x007e), - (0x00a0, 0x00ff), - (0x0100,), - ] - - Ranges are left- and right-inclusive. A 1-tuple of (x,) is treated as (x, x). - - A unicode set can also be defined using multiple inheritance of other unicode sets:: - - class CJK(Chinese, Japanese, Korean): - pass - """ - - _ranges: UnicodeRangeList = [] - - @_lazyclassproperty - def _chars_for_ranges(cls): - ret = [] - for cc in cls.__mro__: - if cc is unicode_set: - break - for rr in getattr(cc, "_ranges", ()): - ret.extend(range(rr[0], rr[-1] + 1)) - return [chr(c) for c in sorted(set(ret))] - - @_lazyclassproperty - def printables(cls): - """all non-whitespace characters in this range""" - return "".join(filterfalse(str.isspace, cls._chars_for_ranges)) - - @_lazyclassproperty - def alphas(cls): - """all alphabetic characters in this range""" - return "".join(filter(str.isalpha, cls._chars_for_ranges)) - - @_lazyclassproperty - def nums(cls): - """all numeric digit characters in this range""" - return "".join(filter(str.isdigit, cls._chars_for_ranges)) - - @_lazyclassproperty - def alphanums(cls): - """all alphanumeric characters in this range""" - return cls.alphas + cls.nums - - @_lazyclassproperty - def identchars(cls): - """all characters in this range that are valid identifier characters, plus underscore '_'""" - return "".join( - sorted( - set( - "".join(filter(str.isidentifier, cls._chars_for_ranges)) - + "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyzªµº" - + "ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ" - + "_" - ) - ) - ) - - @_lazyclassproperty - def identbodychars(cls): - """ - all characters in this range that are valid identifier body characters, - plus the digits 0-9, and · (Unicode MIDDLE DOT) - """ - return "".join( - sorted( - set( - cls.identchars - + "0123456789·" - + "".join( - [c for c in cls._chars_for_ranges if ("_" + c).isidentifier()] - ) - ) - ) - ) - - @_lazyclassproperty - def identifier(cls): - """ - a pyparsing Word expression for an identifier using this range's definitions for - identchars and identbodychars - """ - from pip._vendor.pyparsing import Word - - return Word(cls.identchars, cls.identbodychars) - - -class pyparsing_unicode(unicode_set): - """ - A namespace class for defining common language unicode_sets. - """ - - # fmt: off - - # define ranges in language character sets - _ranges: UnicodeRangeList = [ - (0x0020, sys.maxunicode), - ] - - class BasicMultilingualPlane(unicode_set): - """Unicode set for the Basic Multilingual Plane""" - _ranges: UnicodeRangeList = [ - (0x0020, 0xFFFF), - ] - - class Latin1(unicode_set): - """Unicode set for Latin-1 Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x0020, 0x007E), - (0x00A0, 0x00FF), - ] - - class LatinA(unicode_set): - """Unicode set for Latin-A Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x0100, 0x017F), - ] - - class LatinB(unicode_set): - """Unicode set for Latin-B Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x0180, 0x024F), - ] - - class Greek(unicode_set): - """Unicode set for Greek Unicode Character Ranges""" - _ranges: UnicodeRangeList = [ - (0x0342, 0x0345), - (0x0370, 0x0377), - (0x037A, 0x037F), - (0x0384, 0x038A), - (0x038C,), - (0x038E, 0x03A1), - (0x03A3, 0x03E1), - (0x03F0, 0x03FF), - (0x1D26, 0x1D2A), - (0x1D5E,), - (0x1D60,), - (0x1D66, 0x1D6A), - (0x1F00, 0x1F15), - (0x1F18, 0x1F1D), - (0x1F20, 0x1F45), - (0x1F48, 0x1F4D), - (0x1F50, 0x1F57), - (0x1F59,), - (0x1F5B,), - (0x1F5D,), - (0x1F5F, 0x1F7D), - (0x1F80, 0x1FB4), - (0x1FB6, 0x1FC4), - (0x1FC6, 0x1FD3), - (0x1FD6, 0x1FDB), - (0x1FDD, 0x1FEF), - (0x1FF2, 0x1FF4), - (0x1FF6, 0x1FFE), - (0x2129,), - (0x2719, 0x271A), - (0xAB65,), - (0x10140, 0x1018D), - (0x101A0,), - (0x1D200, 0x1D245), - (0x1F7A1, 0x1F7A7), - ] - - class Cyrillic(unicode_set): - """Unicode set for Cyrillic Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x0400, 0x052F), - (0x1C80, 0x1C88), - (0x1D2B,), - (0x1D78,), - (0x2DE0, 0x2DFF), - (0xA640, 0xA672), - (0xA674, 0xA69F), - (0xFE2E, 0xFE2F), - ] - - class Chinese(unicode_set): - """Unicode set for Chinese Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x2E80, 0x2E99), - (0x2E9B, 0x2EF3), - (0x31C0, 0x31E3), - (0x3400, 0x4DB5), - (0x4E00, 0x9FEF), - (0xA700, 0xA707), - (0xF900, 0xFA6D), - (0xFA70, 0xFAD9), - (0x16FE2, 0x16FE3), - (0x1F210, 0x1F212), - (0x1F214, 0x1F23B), - (0x1F240, 0x1F248), - (0x20000, 0x2A6D6), - (0x2A700, 0x2B734), - (0x2B740, 0x2B81D), - (0x2B820, 0x2CEA1), - (0x2CEB0, 0x2EBE0), - (0x2F800, 0x2FA1D), - ] - - class Japanese(unicode_set): - """Unicode set for Japanese Unicode Character Range, combining Kanji, Hiragana, and Katakana ranges""" - - class Kanji(unicode_set): - "Unicode set for Kanji Unicode Character Range" - _ranges: UnicodeRangeList = [ - (0x4E00, 0x9FBF), - (0x3000, 0x303F), - ] - - class Hiragana(unicode_set): - """Unicode set for Hiragana Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x3041, 0x3096), - (0x3099, 0x30A0), - (0x30FC,), - (0xFF70,), - (0x1B001,), - (0x1B150, 0x1B152), - (0x1F200,), - ] - - class Katakana(unicode_set): - """Unicode set for Katakana Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x3099, 0x309C), - (0x30A0, 0x30FF), - (0x31F0, 0x31FF), - (0x32D0, 0x32FE), - (0xFF65, 0xFF9F), - (0x1B000,), - (0x1B164, 0x1B167), - (0x1F201, 0x1F202), - (0x1F213,), - ] - - 漢字 = Kanji - カタカナ = Katakana - ひらがな = Hiragana - - _ranges = ( - Kanji._ranges - + Hiragana._ranges - + Katakana._ranges - ) - - class Hangul(unicode_set): - """Unicode set for Hangul (Korean) Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x1100, 0x11FF), - (0x302E, 0x302F), - (0x3131, 0x318E), - (0x3200, 0x321C), - (0x3260, 0x327B), - (0x327E,), - (0xA960, 0xA97C), - (0xAC00, 0xD7A3), - (0xD7B0, 0xD7C6), - (0xD7CB, 0xD7FB), - (0xFFA0, 0xFFBE), - (0xFFC2, 0xFFC7), - (0xFFCA, 0xFFCF), - (0xFFD2, 0xFFD7), - (0xFFDA, 0xFFDC), - ] - - Korean = Hangul - - class CJK(Chinese, Japanese, Hangul): - """Unicode set for combined Chinese, Japanese, and Korean (CJK) Unicode Character Range""" - - class Thai(unicode_set): - """Unicode set for Thai Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x0E01, 0x0E3A), - (0x0E3F, 0x0E5B) - ] - - class Arabic(unicode_set): - """Unicode set for Arabic Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x0600, 0x061B), - (0x061E, 0x06FF), - (0x0700, 0x077F), - ] - - class Hebrew(unicode_set): - """Unicode set for Hebrew Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x0591, 0x05C7), - (0x05D0, 0x05EA), - (0x05EF, 0x05F4), - (0xFB1D, 0xFB36), - (0xFB38, 0xFB3C), - (0xFB3E,), - (0xFB40, 0xFB41), - (0xFB43, 0xFB44), - (0xFB46, 0xFB4F), - ] - - class Devanagari(unicode_set): - """Unicode set for Devanagari Unicode Character Range""" - _ranges: UnicodeRangeList = [ - (0x0900, 0x097F), - (0xA8E0, 0xA8FF) - ] - - BMP = BasicMultilingualPlane - - # add language identifiers using language Unicode - العربية = Arabic - 中文 = Chinese - кириллица = Cyrillic - Ελληνικά = Greek - עִברִית = Hebrew - 日本語 = Japanese - 한국어 = Korean - ไทย = Thai - देवनागरी = Devanagari - - # fmt: on diff --git a/myenv/Lib/site-packages/pip/_vendor/pyparsing/util.py b/myenv/Lib/site-packages/pip/_vendor/pyparsing/util.py deleted file mode 100644 index d8d3f41..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/pyparsing/util.py +++ /dev/null @@ -1,284 +0,0 @@ -# util.py -import inspect -import warnings -import types -import collections -import itertools -from functools import lru_cache, wraps -from typing import Callable, List, Union, Iterable, TypeVar, cast - -_bslash = chr(92) -C = TypeVar("C", bound=Callable) - - -class __config_flags: - """Internal class for defining compatibility and debugging flags""" - - _all_names: List[str] = [] - _fixed_names: List[str] = [] - _type_desc = "configuration" - - @classmethod - def _set(cls, dname, value): - if dname in cls._fixed_names: - warnings.warn( - f"{cls.__name__}.{dname} {cls._type_desc} is {str(getattr(cls, dname)).upper()}" - f" and cannot be overridden", - stacklevel=3, - ) - return - if dname in cls._all_names: - setattr(cls, dname, value) - else: - raise ValueError(f"no such {cls._type_desc} {dname!r}") - - enable = classmethod(lambda cls, name: cls._set(name, True)) - disable = classmethod(lambda cls, name: cls._set(name, False)) - - -@lru_cache(maxsize=128) -def col(loc: int, strg: str) -> int: - """ - Returns current column within a string, counting newlines as line separators. - The first column is number 1. - - Note: the default parsing behavior is to expand tabs in the input string - before starting the parsing process. See - :class:`ParserElement.parse_string` for more - information on parsing strings containing ```` s, and suggested - methods to maintain a consistent view of the parsed string, the parse - location, and line and column positions within the parsed string. - """ - s = strg - return 1 if 0 < loc < len(s) and s[loc - 1] == "\n" else loc - s.rfind("\n", 0, loc) - - -@lru_cache(maxsize=128) -def lineno(loc: int, strg: str) -> int: - """Returns current line number within a string, counting newlines as line separators. - The first line is number 1. - - Note - the default parsing behavior is to expand tabs in the input string - before starting the parsing process. See :class:`ParserElement.parse_string` - for more information on parsing strings containing ```` s, and - suggested methods to maintain a consistent view of the parsed string, the - parse location, and line and column positions within the parsed string. - """ - return strg.count("\n", 0, loc) + 1 - - -@lru_cache(maxsize=128) -def line(loc: int, strg: str) -> str: - """ - Returns the line of text containing loc within a string, counting newlines as line separators. - """ - last_cr = strg.rfind("\n", 0, loc) - next_cr = strg.find("\n", loc) - return strg[last_cr + 1 : next_cr] if next_cr >= 0 else strg[last_cr + 1 :] - - -class _UnboundedCache: - def __init__(self): - cache = {} - cache_get = cache.get - self.not_in_cache = not_in_cache = object() - - def get(_, key): - return cache_get(key, not_in_cache) - - def set_(_, key, value): - cache[key] = value - - def clear(_): - cache.clear() - - self.size = None - self.get = types.MethodType(get, self) - self.set = types.MethodType(set_, self) - self.clear = types.MethodType(clear, self) - - -class _FifoCache: - def __init__(self, size): - self.not_in_cache = not_in_cache = object() - cache = {} - keyring = [object()] * size - cache_get = cache.get - cache_pop = cache.pop - keyiter = itertools.cycle(range(size)) - - def get(_, key): - return cache_get(key, not_in_cache) - - def set_(_, key, value): - cache[key] = value - i = next(keyiter) - cache_pop(keyring[i], None) - keyring[i] = key - - def clear(_): - cache.clear() - keyring[:] = [object()] * size - - self.size = size - self.get = types.MethodType(get, self) - self.set = types.MethodType(set_, self) - self.clear = types.MethodType(clear, self) - - -class LRUMemo: - """ - A memoizing mapping that retains `capacity` deleted items - - The memo tracks retained items by their access order; once `capacity` items - are retained, the least recently used item is discarded. - """ - - def __init__(self, capacity): - self._capacity = capacity - self._active = {} - self._memory = collections.OrderedDict() - - def __getitem__(self, key): - try: - return self._active[key] - except KeyError: - self._memory.move_to_end(key) - return self._memory[key] - - def __setitem__(self, key, value): - self._memory.pop(key, None) - self._active[key] = value - - def __delitem__(self, key): - try: - value = self._active.pop(key) - except KeyError: - pass - else: - while len(self._memory) >= self._capacity: - self._memory.popitem(last=False) - self._memory[key] = value - - def clear(self): - self._active.clear() - self._memory.clear() - - -class UnboundedMemo(dict): - """ - A memoizing mapping that retains all deleted items - """ - - def __delitem__(self, key): - pass - - -def _escape_regex_range_chars(s: str) -> str: - # escape these chars: ^-[] - for c in r"\^-[]": - s = s.replace(c, _bslash + c) - s = s.replace("\n", r"\n") - s = s.replace("\t", r"\t") - return str(s) - - -def _collapse_string_to_ranges( - s: Union[str, Iterable[str]], re_escape: bool = True -) -> str: - def is_consecutive(c): - c_int = ord(c) - is_consecutive.prev, prev = c_int, is_consecutive.prev - if c_int - prev > 1: - is_consecutive.value = next(is_consecutive.counter) - return is_consecutive.value - - is_consecutive.prev = 0 # type: ignore [attr-defined] - is_consecutive.counter = itertools.count() # type: ignore [attr-defined] - is_consecutive.value = -1 # type: ignore [attr-defined] - - def escape_re_range_char(c): - return "\\" + c if c in r"\^-][" else c - - def no_escape_re_range_char(c): - return c - - if not re_escape: - escape_re_range_char = no_escape_re_range_char - - ret = [] - s = "".join(sorted(set(s))) - if len(s) > 3: - for _, chars in itertools.groupby(s, key=is_consecutive): - first = last = next(chars) - last = collections.deque( - itertools.chain(iter([last]), chars), maxlen=1 - ).pop() - if first == last: - ret.append(escape_re_range_char(first)) - else: - sep = "" if ord(last) == ord(first) + 1 else "-" - ret.append( - f"{escape_re_range_char(first)}{sep}{escape_re_range_char(last)}" - ) - else: - ret = [escape_re_range_char(c) for c in s] - - return "".join(ret) - - -def _flatten(ll: list) -> list: - ret = [] - for i in ll: - if isinstance(i, list): - ret.extend(_flatten(i)) - else: - ret.append(i) - return ret - - -def _make_synonym_function(compat_name: str, fn: C) -> C: - # In a future version, uncomment the code in the internal _inner() functions - # to begin emitting DeprecationWarnings. - - # Unwrap staticmethod/classmethod - fn = getattr(fn, "__func__", fn) - - # (Presence of 'self' arg in signature is used by explain_exception() methods, so we take - # some extra steps to add it if present in decorated function.) - if "self" == list(inspect.signature(fn).parameters)[0]: - - @wraps(fn) - def _inner(self, *args, **kwargs): - # warnings.warn( - # f"Deprecated - use {fn.__name__}", DeprecationWarning, stacklevel=3 - # ) - return fn(self, *args, **kwargs) - - else: - - @wraps(fn) - def _inner(*args, **kwargs): - # warnings.warn( - # f"Deprecated - use {fn.__name__}", DeprecationWarning, stacklevel=3 - # ) - return fn(*args, **kwargs) - - _inner.__doc__ = f"""Deprecated - use :class:`{fn.__name__}`""" - _inner.__name__ = compat_name - _inner.__annotations__ = fn.__annotations__ - if isinstance(fn, types.FunctionType): - _inner.__kwdefaults__ = fn.__kwdefaults__ - elif isinstance(fn, type) and hasattr(fn, "__init__"): - _inner.__kwdefaults__ = fn.__init__.__kwdefaults__ - else: - _inner.__kwdefaults__ = None - _inner.__qualname__ = fn.__qualname__ - return cast(C, _inner) - - -def replaced_by_pep8(fn: C) -> Callable[[Callable], C]: - """ - Decorator for pre-PEP8 compatibility synonyms, to link them to the new function. - """ - return lambda other: _make_synonym_function(other.__name__, fn) diff --git a/myenv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/__init__.cpython-311.pyc index 60ebb3457fc5cba45dabeb707d1bf94b299bca1b..8d558ffded9043301c3bf365245a47d972c34695 100644 GIT binary patch delta 19 ZcmX@ldY+YQIWI340}!~L+{ks52>>%a1r7iJ delta 19 ZcmX@ldY+YQIWI340}wbL+Q@a32>>$=1qA>A diff --git a/myenv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/_compat.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/_compat.cpython-311.pyc index 080c482698931a653cf046878c9fe1b4ce581ab5..13afe243716ae58e34d3bd289aefb105afe7c688 100644 GIT binary patch delta 19 ZcmZ3;ypWk|IWI340}!~L+{iVZ5dbVC1b+Yk delta 19 ZcmZ3;ypWk|IWI340}wbL+Q>DX5dbUo1a<%b diff --git a/myenv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/_impl.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/_impl.cpython-311.pyc index 81a342cc2bb514b50a8d24e6c96bc7980afd2138..543f89ec9ab13258d721394e1ac24558c71ae55b 100644 GIT binary patch delta 21 bcmZ48#JIYNk!v|GFBbz4xSrg|rRWF%L23nE delta 21 bcmZ48#JIYNk!v|GFBbz4I3L=`rRWF%K|2Lh diff --git a/myenv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__pycache__/__init__.cpython-311.pyc index 3e1421d05f1d3d4e74fa4a7b1b16413c3a08e495..42e96722ed017d8077bae0410f849ed70f9613a1 100644 GIT binary patch delta 19 ZcmbQuIh&JfIWI340}!~L+{iVN1pq7$1bhGh delta 19 ZcmbQuIh&JfIWI340}wbL+Q>DL1pq7H1aklY diff --git a/myenv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__pycache__/_in_process.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__pycache__/_in_process.cpython-311.pyc index 6753449f992363002b91db6ed94e883e47229f20..dbea4245a85dec767737a27921763e1d92789db1 100644 GIT binary patch delta 21 bcmey`!1%R+k!v|GFBbz4xSrg|mF)lkO!)>j delta 21 bcmey`!1%R+k!v|GFBbz4I3L=`mF)lkOv(l= diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/__init__.py b/myenv/Lib/site-packages/pip/_vendor/requests/__init__.py index 10ff67f..04230fc 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/__init__.py @@ -45,11 +45,7 @@ from .exceptions import RequestsDependencyWarning charset_normalizer_version = None - -try: - from pip._vendor.chardet import __version__ as chardet_version -except ImportError: - chardet_version = None +chardet_version = None def check_compatibility(urllib3_version, chardet_version, charset_normalizer_version): @@ -80,7 +76,8 @@ def check_compatibility(urllib3_version, chardet_version, charset_normalizer_ver # charset_normalizer >= 2.0.0 < 4.0.0 assert (2, 0, 0) <= (major, minor, patch) < (4, 0, 0) else: - raise Exception("You need either charset_normalizer or chardet installed") + # pip does not need or use character detection + pass def _check_cryptography(cryptography_version): diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-311.pyc index 5bb22fb541dd849f6813c05b376de17fc5f069eb..255f2531ab4ab623fbf65a82313aa0c2c9ab6467 100644 GIT binary patch delta 1276 zcmZ8gO>7%Q6rS;}e|Ej=*lRm>{+y&qlRAyv#1<52$Zy>?P!LkYp(CNi@@`t29ow4S zP%0`4hyw?N6wLu7q^JVP2=xS!dV)jJ6UQPXsy%T-+#*0ia45XlG^OE5@7p);eeZ8} z_nXT7xx|;ct|E}y_aATWrMDA#d}@2TG--uM)QWt7NX&`?DhdiAJ7!C*fGiU1==M%- zDQ;_~`YNI*$J<@kjNR;`GrZNn&It-8d9US!xd>bO-cM-p2~E zuoZF)Vzl)MU_iq#Mlhps1-0et=q>3Ax{e_?Z5vkH(s~l)gC2@I1=+fjp;?j*#>}?* zk77NFQJ>0%@6nXLqw?4w>qzV1M-3RQac3+n+ONGYccK{h- zP;vhKTey=?&`rd@i%s!=B7aHNO$_#D{G-^P5esdgqQ<{aCgK{9nYcfu@cT**EBsfb zFjSQNu-kQ-o-a9e+mF<{UAt}hQnT&xP4#DW5E81O?&tiK_#IUX>kkU0p9<9xRj$Mn)UKSDc}?YL}R_+Ak3B7h%rZC5PrvdhBvlJIG+SNFDD zvjG_{dzo)!rVHX5Vd66Xjx9i?EyrGDSK%oBbywz}W-jF(82#_|9YjX3et;gsGTyCZ zzmnE#z}qqA(btugDQWK{7C4h$lhNLyyegsn5C(f+imvL?z8Vs?hJ~#^4fZ`byrxO_ H;u!E>2PzSZ delta 1576 zcmZWpOH3O_7@qOk>$ibjFb~IO0fP$x!b1uq4G%-et7%X{O~o9#wY-yJx?@|jOY;yC zRn&7OI#Sh3R1T4=ic{*|dI}t>N>xRq9MDRUdg&ojR8jSUdZ;?Hjsvt~&%giw{g0XN zpV@sj^8Hxs+h{Zd_?X}Q;?8LER;&%)+R6-V27v($+4PeD3PMnf_5d781L}jo@Sxxd zD0=ULd(sNH3l0D00ELYJmysaw0362BT0oQ(0|&8OkpS4?vo?6ONnS0AV|P5f;xH6B zaIK;4H-g)ZpsQ}3c%Cl1_3QX%$ZR4CQXs&J73Nh!Mz{j`T71^VL+JAGm?~2L!$CdC zf#)`3)rc6;(|fi0co$-33yGt+yU+MqYrS>_Xnd)<1$bjb!`gVm+TG9yZfD!DWmB|G zg5czGJhH*;APJOsP5w;1jM0b_6%Vh=XKlE3J!TRmc~+B|Bq@~QnAcFuPNE@=bfGTS zR?PtEM%|RA*&yqnjNQTf58Aik896Cov&-jhLix=?mDeS*~sXmhXpsahq23%uL%v$epi;5jnlJhp<1&J`DD3MtJ}g z$3VsV(J#G}-v9#bmt4FSQ3GCjPenYKSShV*MT`v%7wlC`wft(1TG-Z$B}#H;;Q@zA zHPpbiRw!C_&NQ*n?{j=sSJ^Dsj%4DZBj?IxTr?c1P_&)k!o55$+nh9e5&SJAIy1qi zwZnc2?S#U;<|g|yY&ZNKYu#^q?^$f=d2DGvuv9f8T~HA(DW~D? z+GX3ozKLFyRl%Z>y^6lync%9U>iJci|3uHz`(?ZIG0l}%@6!zT+^&8UD?;|7p$cWT z)z}R?*bj~WG%2F&4acwRMk%lBw1@3AWp0c2#!<_K@-RQNqEVv5q8pqyb^96@?(lU| zE>U}d(h{YDnY)Y=%UTwuf^y9xJ`OZ3L^n$*n)fZPvPESO4zLX+1AEzHB@NHApOu7f zh`Sv2hcd3wNuf%)a)DkDsTYNKTZl_Sbg-;CGfTz2bYxO8uxZg7!tss}Hw7H9uq7^= zMc)FFdCa!Q?V1-nh&xj5KufkKb_=QL?I=@EJ-6uNev>wB%f`A%ss H1-bkeA&pxg diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-311.pyc index 205254538eecf3c10b35695d3471a7498d0933c0..93eb2f442b8735b01aebf1a24bbe94ce94b36862 100644 GIT binary patch delta 34 ocmcb?a)X6yIWI340}!~LoX9nk%}CEUli6tEN) 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 Xfu2WL-!W+8UbC48UHaF`d4T^72hDLa delta 4975 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/api.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/api.cpython-311.pyc index fda347e11bec671f91e577e74d29023c7010459c..3de96fb6842a41e17da3f2b21a14df7981887220 100644 GIT binary patch delta 26 gcmca>b=Qh(IWI340}!~L+{k6i#u&fZgH2Q%0Ab=Qh(IWI340}wbL+Q?`Obfk@t~4>g=S4mj{eMyiXRxTlM^C7f@QwokS~%2S_A+{ CV<^4= delta 151 zcmdl|w55o5IWI340}wbL>PtJlk@t~4> diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-311.pyc index cb1a8041d53c8a52c161e65a69177f326a043e6f..f4f82231d76a0c87c8b3a838beb8b0757d7c0b12 100644 GIT binary patch delta 19 ZcmaFD{)C-tIWI340}!~L+{kr{82~n*1yTS2 delta 19 ZcmaFD{)C-tIWI340}wbL+Q@Z_82~nM1xWw^ diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-311.pyc index 6c4c5c0049f0df5ffbbfe3b43e170dc91c56050f..8aec690f69eb404c8109f4d81c3592757c163d58 100644 GIT binary patch delta 536 zcmX|-&ui2`6vy98vTjK>soi4hTC3>~3PoHzS}FFRR_I|t7ca}g5|b$#h|Ts*wxv~R zkkVse$wBboQ4x>*2Lw-o;txDXPF}@Jp|_rVuWDzQ&%BxUec$=<()~Q_ymlN5sNMOn zzxrw5)aus+z;g(p1)&IKELtKocA+IDDEW$nZ&`iPT80vX&18nl}_Rf)!~ZHsUw!DaD;}g z5Hk4bR}u9HqBR^$%N5}odP|=Ou|#|MGvmsrO+jG?NgV&ZnZ`=~&Nw&b&_241 zVOE&kH0|Np{I@YV!KV~5O0dd7rH?Varrz^Wt9;R{E#Y}Ct1&JxCKwk9h5Jv7YQ3*? zij$nV#JJ4x7*qLU^ZqQF91k(h5RQiyA0=TwRyT2hmi$TjTYj%JHfLuR_e0kZqla*c Y3fR+Mtf{Zo%y(-hD<5Q~7s6z_Kl?p}ng9R* delta 373 zcmX@lKaY=hIWI340}wbL>Pusr$SbL!#K^!fogsxGiXnwDg(-(Imnn*g5yWQBVUA)> zWu6#f&&WJ+%3((4$q|facr+Pru_tFF7Nw+?_-)o>_F@#{F32pAFX9C;cuI?Max#UI_%cdL3iOim^RqKkvl5FoFJvrZ zWc)r^g4qvUCZ9Q#iy5TkI&UN!*)>d$a+& CrcR{* delta 191 zcmbPqh4IT}M&9MTyj%=G;C!ertzjdt10&;TX2v&@4@!67%Q6vub+ReMv%j=hfUkifLrmYTW=Z9ZB;2q6%KG)hdUMI-~V*1MBroAs_W zyH;rVa1lsIh~&T%MQso#1VX*E>WNAf;)JS#luA7%CnRowL#6q_tkY_^)-SBfoGvtX;$ za!$#%-uymPZAzI0x9*K*@r&OdPr!k2Z~aT5U2EuK4>1g}RO#L*tT0+Cac0#_Rw~g7 z3syXfnug;ri>|FOmsV|a)v?`W8VFafe4d#Bt3(WLj zBOIz96CQRz&-6^geOjS?A6^=X7W>Va~zk5=W&A1RA$1D!@KEIkm|Uro*!zbVigQ71!ZGd9kCv-9@qx_tBQ5{2f#43zvIvJC~x>kUXl40V( zFTyr1ZIj8f>I6C?e7Ky{$%GVsOFF8o0b&izE*%b~2H{p$K0by1h&OTaoB-^ko`OQE zq)wv+QHR?p9WJE@K}(NAPbN&>gV)kJnGwM^;ajo(0FGvKGAj>zJ2R=y;a0>3+!4Z@ z6lgbB^C%!bhR?cnl85iQzsM}05pfwOrx5sJ_yWB12&>C}XK^k2DO)DnBU>?q0+x7N zeZ_EUyDw7~mye<(i#Lw5352WyUUxfOxKQ2mmKU8tc@~ueiw1Ya|A@T6Hk5m`HktMU myw%f7ig2~(N`I1wXSyF-T}QW$J@WvSKOf3Z-ZXmuZvGbnURH1b delta 756 zcmZXSOK1~O6ozw~Ml)A3c_))+(N5JsV>PL@32AK`l2BtBimgwI1R5n!YdVre3ogVi zidND5D=FwwiV8}%T}fR?Db#HQL01am16)XT;XN0@g#+_(?*E^2X3o9$R^jc4`q*aU zCh=rn-o5lyeW9*cnT9u-n=hKqw@;f-nPTm0Th@A;c`RnZkk!*>sJIbv+byETAascL zS`1BFr(&{N2EP%oWoxiFvg!)&qCCP8d{lMTh4L=?sy>~iMP?cszLU7%Q&<&2zs@rB5zP5dz~NU|4X=bYD7COQ!-uH>;R>3X z&W5G&Nh`auWDw>kI4*$aS_(G<7kQ2pLIa-zI?KTstn&hign8T!>Z~9eeF)b0C>ez7 zm<;J`R2ol1BPfOxwuqlXD@v^#HtwUmkZ`rm9hmK=lrwzd0A#h9(l wUN(xj6V-N=sIH7B(Fi+>*U<-u_AqhX{>Qd&|MtOw@8taWXNTABb?lh`0JQhCiU0rr diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/help.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/help.cpython-311.pyc index c6d5a1a5b89bad0a8e1acf922181543394c937c2..5721180464844770e0d9e7356b9d81e4fca7b409 100644 GIT binary patch delta 442 zcmdm{d`O9JIWI340}!~L>`QyfH<3?*@!Ul9z?c-KC>~CR6vht3lDwrb~${ABQS{R~)QaFL6a0(ZY z6iF3L;hy+Qm62z%0%PRn7RGQ^Rt2E#(wiT!&1Dwm2QrHUfrMWX50KPkDiWMLflHoE z2qZ2$c`KI}=PmZ+jKrdp)RM_8+$NG>31yJ13Xr(P?jP)0RFq#-q%b*H-i`z4|Ait;t z=B)4hvT|_iesS33=BJeAq}mnv1JyDDak1KDBY`~j8(e%1>>pSrKM>do4wO}FmJB<& M9od-=vM~Zl0PA{T>;M1& delta 577 zcmZXO%}Z2K7{834!5D9CGA34VCM#1#H6ma7V->7FIDa11paiJYe%yTB5<6K{ z`N^LMOw8vH_Yp<;(;wFdJ>-QyLYdTp)Bpeg diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-311.pyc index 5aab333ed58304496d176d36585559a9979238bd..fc3dfff8269b8c416db0c3707a8a5d7d5f944bbc 100644 GIT binary patch delta 19 Zcmeys`GJ#bIWI340}!~L+{pEe1pqj$1$zJh delta 19 Zcmeys`GJ#bIWI340}wbL+Q{{c1pqjH1#$oY diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-311.pyc index a8ddb220132804d0ef70ea3a3a0a22daa5a317ca..1255db126ccb951d4d3d476022024954feaeb679 100644 GIT binary patch delta 722 zcmZ{iT}YF06vqG0`@VafHm7axvbNU5Ev9|VvO+QZO6h|prXfX|m13bqw3T4?u|jYf ze&AnF%TU5f=tAS%bm4_U^dUquMnRAlWzm(rGmF5RUacU(&czST^Bg#bhjVjS7#S9f z4`O3um{tWZ+Ny82JTm$cOctxktkFr41vKXebA#upGodpMYx#P&H%VFDW9hfuvh~{g z?30Q+thiN%=+s60p5|TdDY(d=Y!Kk)ferIYqRyeRrO2oDjV1|&bk{R1pn{6Gd4LAG zkv0lkrR*IoKr>D390c0wTzaC6Uh2q-lkkxS@;=L$p{9Lh5_ZwFcU-^$x?kjwaFU)L z$^q(lROuUJ&{U~OhfW?j`UB(qOIbgjP_R4=c*#ePHR2iNR#XD7_`TyF@RounW`TFS zq4FB0`F!P=wqdl&D`1vlPTc`OL#HbMJ=fQKMLhpm<57yW)VkS)h4B8=bqC*EyVWeL z`75vzRwb6O6p5d$J*Y4AMKr^=hmX~krdmYC{K;A$VBckCFo#yGdvCUOWevCnH%*#7 zVY6o>CTz|O88THpQ*0fSamE>iR4VuH7vP|wixVP_aDV-FLwvMdWg3D7s!UYhC*Tql zU4AX1m7IZM2}E^`-vorIrYT3nCwkc86a_(|P^%pX&`jGF?2XddRHh*!GTGR8SQQoo zQ@U=I%9f%I%$oAp^4z704xRQVOOZ!a9arSEB4DM;mS@Q5h%8!j{|;1hr8_;_D?>YD Qc}5oXx&OGn-CB~r0GDyxmH+?% delta 668 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 B_|E_U delta 4630 zcmZu#32;WN zsWri|gQ-8iNv`82e$|85nlUzy&q((&JO8ONm$%%JF~8M0bTZx!jo0cLns+fMjCqG< zlGN%R8b@5QEQ$Y)<&9yII%@ol22UB{iskdyGK#&4JEB>nND}`%BM03=BZzw&TPHXuQ7V+Gu0HejkMkgC&&EYR+7P2w?Y-S1KrOc^pEHBC`NlLB< zvZ+y@wU(u2!crW=3W9q6hwP26l{8$%r}$=-)#FfiAo%eUo;N*uJSs!5T~=W;F6<(X zbErtabTK=xzwTmQ{&|PbIPN>k=BN9riltM?sw5+2s3_O_ZfTrD;?Q8ab6!t zAC?ZlFHcaI#@CfJqDfvYDRe%GJW0lfCHLAVAH<=V)X}EL`Lby%(c)Kk6d1;|H*I+@Au-?q zp?W@T&LDW1-(8wrO0VB^v@2-AU*m9O4)EghZmwsVTus1H{z3V}XzjkHg0h*o^RT2~ zLhO~QrHz?8Y`wNtq*-4t!&xG2EJEVGtX{STlP`a2@j&U|kwU$I-L!>U&6KdFwJDZf zrpua)Flk0bLFE|~Lr++rj)Q*bO1hMt)4%+SEZ-H0IcEsC-*s_(;JHQjryQt#c=-jl z|GeA(MM~~@M=ntCaZ3o!AYtDGAd1@KPNeAtqb@&qk znk>n3y$%#`=DFvGXe=74m|*-6-tYx@jzfT>T<5T^KJK=upGITrr=;cu{>R z9>1b~g7Z6Mn8my5-$vDE-u@F?!An;L^5_|2Xv8p=>g`Hc*5L=FRP)Z2JBPLMu6obb zM+d;)5dz7Ouo%2YRJsiOjUb=kj|gV!T2%>a5xIu$18)+^)6gBY=BV;zqIhGV$dMpc zWi5iX*5RK>9oCds3Mc`_RfVr>$aY>wO1%+nC~&aVe9yW{RN{kmrEDMnXvbQbWn|HA;_Y+BN_^~VHS3Dg!DEj zLQ*0U@p#BZf`GSpc~hl`#slRf2yzJK(iIt2IW&;k5>%o$WHWrpO0;WsFcgWPk~-Xi zTTUBw;W4(dMTMJ3~rZR91)G!%p>QHcb@N(5jsuAehLlil`F zYe-Bx0flD3VY+3tD<}%a5pGi^4w_9zm2p7rRX>F86G zHKYiipq4QQ->5D?`gjCPR2k3S5w({PGhUq*Arp7wI3Xlqb-rCM zaMmJA8GlU2Ucz`^{};R>Ta2JoLmq*V6iJJ%y~H{aAd7Mc5d zzgt3cGq1X)wsLJf zy5oD>Y=#7(VUKgsV*kW(Ksh|%6zN!00IQ16L#oJS7$HY^;oZfx!o`%Isq;|V;1l8y zasGcykY&|&>lWCEsBJpPc=7?G@9sErwb9AceBVDl-anfmV zf_(%<2!Rw~1L{$?2CYbhpCPvh9@8NjP3cXCs)565!8r{e+ zTphT&H_zFRq#unvd*5MYAJZNR9MSI#^C88|!Dkh28}z@G^ORUO+=IK_d|-ctmDBC~ ziw!>Gll>2{l!Tm~H9Y>{qT=wD5QM^5CMW3uzoPmrANqT23;g)ZbbjH%@$Q9mUnhLb zuRpll>Td@~BZ6#x$ASN%0~!wIu)eKCr5p`A2}o^JlU^ydoZ?4-<&C5fZ%#OhEH0V> z=phl?5%eUa2_p|R_-S!y$9PA72!HKErdu4y*o2Jz()Xzn|K_1h!?k@gU&Gic{>HBRDCiHNw0ZpCq1PKIT?beLzSVU!YBiIB!H5dkEClS#YKMEkKbj0#*bRkY9n^aZ|Fp z=3dmHMdI!9Vt5W$@sFe*GLjxUX!DM9=3J2yu#~^>c(M0qY}OSi0oDBC6>X a0b}_7C;sD|&oZw_3D{;FdNQ4fAo?G8)u_k- diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/__version__.py b/myenv/Lib/site-packages/pip/_vendor/requests/__version__.py index 5063c3f..2c105ac 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/__version__.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/__version__.py @@ -5,10 +5,10 @@ __title__ = "requests" __description__ = "Python HTTP for Humans." __url__ = "https://requests.readthedocs.io" -__version__ = "2.31.0" -__build__ = 0x023100 +__version__ = "2.32.3" +__build__ = 0x023203 __author__ = "Kenneth Reitz" __author_email__ = "me@kennethreitz.org" -__license__ = "Apache 2.0" +__license__ = "Apache-2.0" __copyright__ = "Copyright Kenneth Reitz" __cake__ = "\u2728 \U0001f370 \u2728" diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/adapters.py b/myenv/Lib/site-packages/pip/_vendor/requests/adapters.py index 10c1767..7030777 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/adapters.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/adapters.py @@ -8,6 +8,8 @@ import os.path import socket # noqa: F401 +import typing +import warnings from pip._vendor.urllib3.exceptions import ClosedPoolError, ConnectTimeoutError from pip._vendor.urllib3.exceptions import HTTPError as _HTTPError @@ -25,6 +27,7 @@ from pip._vendor.urllib3.util import Timeout as TimeoutSauce from pip._vendor.urllib3.util import parse_url from pip._vendor.urllib3.util.retry import Retry +from pip._vendor.urllib3.util.ssl_ import create_urllib3_context from .auth import _basic_auth_str from .compat import basestring, urlparse @@ -61,12 +64,76 @@ def SOCKSProxyManager(*args, **kwargs): raise InvalidSchema("Missing dependencies for SOCKS support.") +if typing.TYPE_CHECKING: + from .models import PreparedRequest + + DEFAULT_POOLBLOCK = False DEFAULT_POOLSIZE = 10 DEFAULT_RETRIES = 0 DEFAULT_POOL_TIMEOUT = None +try: + import ssl # noqa: F401 + + _preloaded_ssl_context = create_urllib3_context() + _preloaded_ssl_context.load_verify_locations( + extract_zipped_paths(DEFAULT_CA_BUNDLE_PATH) + ) +except ImportError: + # Bypass default SSLContext creation when Python + # interpreter isn't built with the ssl module. + _preloaded_ssl_context = None + + +def _urllib3_request_context( + request: "PreparedRequest", + verify: "bool | str | None", + client_cert: "typing.Tuple[str, str] | str | None", + poolmanager: "PoolManager", +) -> "(typing.Dict[str, typing.Any], typing.Dict[str, typing.Any])": + host_params = {} + pool_kwargs = {} + parsed_request_url = urlparse(request.url) + scheme = parsed_request_url.scheme.lower() + port = parsed_request_url.port + + # Determine if we have and should use our default SSLContext + # to optimize performance on standard requests. + poolmanager_kwargs = getattr(poolmanager, "connection_pool_kw", {}) + has_poolmanager_ssl_context = poolmanager_kwargs.get("ssl_context") + should_use_default_ssl_context = ( + _preloaded_ssl_context is not None and not has_poolmanager_ssl_context + ) + + cert_reqs = "CERT_REQUIRED" + if verify is False: + cert_reqs = "CERT_NONE" + elif verify is True and should_use_default_ssl_context: + pool_kwargs["ssl_context"] = _preloaded_ssl_context + elif isinstance(verify, str): + if not os.path.isdir(verify): + pool_kwargs["ca_certs"] = verify + else: + pool_kwargs["ca_cert_dir"] = verify + pool_kwargs["cert_reqs"] = cert_reqs + if client_cert is not None: + if isinstance(client_cert, tuple) and len(client_cert) == 2: + pool_kwargs["cert_file"] = client_cert[0] + pool_kwargs["key_file"] = client_cert[1] + else: + # According to our docs, we allow users to specify just the client + # cert path + pool_kwargs["cert_file"] = client_cert + host_params = { + "scheme": scheme, + "host": parsed_request_url.hostname, + "port": port, + } + return host_params, pool_kwargs + + class BaseAdapter: """The Base Transport Adapter""" @@ -247,28 +314,26 @@ def cert_verify(self, conn, url, verify, cert): :param cert: The SSL certificate to verify. """ if url.lower().startswith("https") and verify: + conn.cert_reqs = "CERT_REQUIRED" - cert_loc = None - - # Allow self-specified cert location. + # Only load the CA certificates if 'verify' is a string indicating the CA bundle to use. + # Otherwise, if verify is a boolean, we don't load anything since + # the connection will be using a context with the default certificates already loaded, + # and this avoids a call to the slow load_verify_locations() if verify is not True: + # `verify` must be a str with a path then cert_loc = verify - if not cert_loc: - cert_loc = extract_zipped_paths(DEFAULT_CA_BUNDLE_PATH) + if not os.path.exists(cert_loc): + raise OSError( + f"Could not find a suitable TLS CA certificate bundle, " + f"invalid path: {cert_loc}" + ) - if not cert_loc or not os.path.exists(cert_loc): - raise OSError( - f"Could not find a suitable TLS CA certificate bundle, " - f"invalid path: {cert_loc}" - ) - - conn.cert_reqs = "CERT_REQUIRED" - - if not os.path.isdir(cert_loc): - conn.ca_certs = cert_loc - else: - conn.ca_cert_dir = cert_loc + if not os.path.isdir(cert_loc): + conn.ca_certs = cert_loc + else: + conn.ca_cert_dir = cert_loc else: conn.cert_reqs = "CERT_NONE" conn.ca_certs = None @@ -328,8 +393,110 @@ def build_response(self, req, resp): return response + def build_connection_pool_key_attributes(self, request, verify, cert=None): + """Build the PoolKey attributes used by urllib3 to return a connection. + + This looks at the PreparedRequest, the user-specified verify value, + and the value of the cert parameter to determine what PoolKey values + to use to select a connection from a given urllib3 Connection Pool. + + The SSL related pool key arguments are not consistently set. As of + this writing, use the following to determine what keys may be in that + dictionary: + + * If ``verify`` is ``True``, ``"ssl_context"`` will be set and will be the + default Requests SSL Context + * If ``verify`` is ``False``, ``"ssl_context"`` will not be set but + ``"cert_reqs"`` will be set + * If ``verify`` is a string, (i.e., it is a user-specified trust bundle) + ``"ca_certs"`` will be set if the string is not a directory recognized + by :py:func:`os.path.isdir`, otherwise ``"ca_certs_dir"`` will be + set. + * If ``"cert"`` is specified, ``"cert_file"`` will always be set. If + ``"cert"`` is a tuple with a second item, ``"key_file"`` will also + be present + + To override these settings, one may subclass this class, call this + method and use the above logic to change parameters as desired. For + example, if one wishes to use a custom :py:class:`ssl.SSLContext` one + must both set ``"ssl_context"`` and based on what else they require, + alter the other keys to ensure the desired behaviour. + + :param request: + The PreparedReqest being sent over the connection. + :type request: + :class:`~requests.models.PreparedRequest` + :param verify: + Either a boolean, in which case it controls whether + we verify the server's TLS certificate, or a string, in which case it + must be a path to a CA bundle to use. + :param cert: + (optional) Any user-provided SSL certificate for client + authentication (a.k.a., mTLS). This may be a string (i.e., just + the path to a file which holds both certificate and key) or a + tuple of length 2 with the certificate file path and key file + path. + :returns: + A tuple of two dictionaries. The first is the "host parameters" + portion of the Pool Key including scheme, hostname, and port. The + second is a dictionary of SSLContext related parameters. + """ + return _urllib3_request_context(request, verify, cert, self.poolmanager) + + def get_connection_with_tls_context(self, request, verify, proxies=None, cert=None): + """Returns a urllib3 connection for the given request and TLS settings. + This should not be called from user code, and is only exposed for use + when subclassing the :class:`HTTPAdapter `. + + :param request: + The :class:`PreparedRequest ` object to be sent + over the connection. + :param verify: + Either a boolean, in which case it controls whether we verify the + server's TLS certificate, or a string, in which case it must be a + path to a CA bundle to use. + :param proxies: + (optional) The proxies dictionary to apply to the request. + :param cert: + (optional) Any user-provided SSL certificate to be used for client + authentication (a.k.a., mTLS). + :rtype: + urllib3.ConnectionPool + """ + proxy = select_proxy(request.url, proxies) + try: + host_params, pool_kwargs = self.build_connection_pool_key_attributes( + request, + verify, + cert, + ) + except ValueError as e: + raise InvalidURL(e, request=request) + if proxy: + proxy = prepend_scheme_if_needed(proxy, "http") + proxy_url = parse_url(proxy) + if not proxy_url.host: + raise InvalidProxyURL( + "Please check proxy URL. It is malformed " + "and could be missing the host." + ) + proxy_manager = self.proxy_manager_for(proxy) + conn = proxy_manager.connection_from_host( + **host_params, pool_kwargs=pool_kwargs + ) + else: + # Only scheme should be lower case + conn = self.poolmanager.connection_from_host( + **host_params, pool_kwargs=pool_kwargs + ) + + return conn + def get_connection(self, url, proxies=None): - """Returns a urllib3 connection for the given URL. This should not be + """DEPRECATED: Users should move to `get_connection_with_tls_context` + for all subclasses of HTTPAdapter using Requests>=2.32.2. + + Returns a urllib3 connection for the given URL. This should not be called from user code, and is only exposed for use when subclassing the :class:`HTTPAdapter `. @@ -337,6 +504,15 @@ def get_connection(self, url, proxies=None): :param proxies: (optional) A Requests-style dictionary of proxies used on this request. :rtype: urllib3.ConnectionPool """ + warnings.warn( + ( + "`get_connection` has been deprecated in favor of " + "`get_connection_with_tls_context`. Custom HTTPAdapter subclasses " + "will need to migrate for Requests>=2.32.2. Please see " + "https://github.com/psf/requests/pull/6710 for more details." + ), + DeprecationWarning, + ) proxy = select_proxy(url, proxies) if proxy: @@ -391,6 +567,9 @@ def request_url(self, request, proxies): using_socks_proxy = proxy_scheme.startswith("socks") url = request.path_url + if url.startswith("//"): # Don't confuse urllib3 + url = f"/{url.lstrip('/')}" + if is_proxied_http_request and not using_socks_proxy: url = urldefragauth(request.url) @@ -451,7 +630,9 @@ def send( """ try: - conn = self.get_connection(request.url, proxies) + conn = self.get_connection_with_tls_context( + request, verify, proxies=proxies, cert=cert + ) except LocationValueError as e: raise InvalidURL(e, request=request) diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/api.py b/myenv/Lib/site-packages/pip/_vendor/requests/api.py index cd0b3ee..5960744 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/api.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/api.py @@ -25,7 +25,7 @@ def request(method, url, **kwargs): :param cookies: (optional) Dict or CookieJar object to send with the :class:`Request`. :param files: (optional) Dictionary of ``'name': file-like-objects`` (or ``{'name': file-tuple}``) for multipart encoding upload. ``file-tuple`` can be a 2-tuple ``('filename', fileobj)``, 3-tuple ``('filename', fileobj, 'content_type')`` - or a 4-tuple ``('filename', fileobj, 'content_type', custom_headers)``, where ``'content-type'`` is a string + or a 4-tuple ``('filename', fileobj, 'content_type', custom_headers)``, where ``'content_type'`` is a string defining the content type of the given file and ``custom_headers`` a dict-like object containing additional headers to add for the file. :param auth: (optional) Auth tuple to enable Basic/Digest/Custom HTTP Auth. diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/auth.py b/myenv/Lib/site-packages/pip/_vendor/requests/auth.py index 9733686..4a7ce6d 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/auth.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/auth.py @@ -258,7 +258,6 @@ def handle_401(self, r, **kwargs): s_auth = r.headers.get("www-authenticate", "") if "digest" in s_auth.lower() and self._thread_local.num_401_calls < 2: - self._thread_local.num_401_calls += 1 pat = re.compile(r"digest ", flags=re.IGNORECASE) self._thread_local.chal = parse_dict_header(pat.sub("", s_auth, count=1)) diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/compat.py b/myenv/Lib/site-packages/pip/_vendor/requests/compat.py index 9ab2bb4..7081da7 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/compat.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/compat.py @@ -7,10 +7,21 @@ compatibility until the next major version. """ -from pip._vendor import chardet - import sys +# ------------------- +# Character Detection +# ------------------- + + +def _resolve_char_detection(): + """Find supported character detection libraries.""" + chardet = None + return chardet + + +chardet = _resolve_char_detection() + # ------- # Pythons # ------- diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/cookies.py b/myenv/Lib/site-packages/pip/_vendor/requests/cookies.py index bf54ab2..f69d0cd 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/cookies.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/cookies.py @@ -2,7 +2,7 @@ requests.cookies ~~~~~~~~~~~~~~~~ -Compatibility code to be able to use `cookielib.CookieJar` with requests. +Compatibility code to be able to use `http.cookiejar.CookieJar` with requests. requests.utils imports from here, so be careful with imports. """ @@ -23,7 +23,7 @@ class MockRequest: """Wraps a `requests.Request` to mimic a `urllib2.Request`. - The code in `cookielib.CookieJar` expects this interface in order to correctly + The code in `http.cookiejar.CookieJar` expects this interface in order to correctly manage cookie policies, i.e., determine whether a cookie can be set, given the domains of the request and the cookie. @@ -76,7 +76,7 @@ def get_header(self, name, default=None): return self._r.headers.get(name, self._new_headers.get(name, default)) def add_header(self, key, val): - """cookielib has no legitimate use for this method; add it back if you find one.""" + """cookiejar has no legitimate use for this method; add it back if you find one.""" raise NotImplementedError( "Cookie headers should be added with add_unredirected_header()" ) @@ -104,11 +104,11 @@ class MockResponse: """Wraps a `httplib.HTTPMessage` to mimic a `urllib.addinfourl`. ...what? Basically, expose the parsed HTTP headers from the server response - the way `cookielib` expects to see them. + the way `http.cookiejar` expects to see them. """ def __init__(self, headers): - """Make a MockResponse for `cookielib` to read. + """Make a MockResponse for `cookiejar` to read. :param headers: a httplib.HTTPMessage or analogous carrying the headers """ @@ -124,7 +124,7 @@ def getheaders(self, name): def extract_cookies_to_jar(jar, request, response): """Extract the cookies from the response into a CookieJar. - :param jar: cookielib.CookieJar (not necessarily a RequestsCookieJar) + :param jar: http.cookiejar.CookieJar (not necessarily a RequestsCookieJar) :param request: our own requests.Request object :param response: urllib3.HTTPResponse object """ @@ -174,7 +174,7 @@ class CookieConflictError(RuntimeError): class RequestsCookieJar(cookielib.CookieJar, MutableMapping): - """Compatibility class; is a cookielib.CookieJar, but exposes a dict + """Compatibility class; is a http.cookiejar.CookieJar, but exposes a dict interface. This is the CookieJar we create by default for requests and sessions that @@ -341,7 +341,7 @@ def __setitem__(self, name, value): self.set(name, value) def __delitem__(self, name): - """Deletes a cookie given a name. Wraps ``cookielib.CookieJar``'s + """Deletes a cookie given a name. Wraps ``http.cookiejar.CookieJar``'s ``remove_cookie_by_name()``. """ remove_cookie_by_name(self, name) diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/exceptions.py b/myenv/Lib/site-packages/pip/_vendor/requests/exceptions.py index 168d073..7f3660f 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/exceptions.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/exceptions.py @@ -41,6 +41,16 @@ def __init__(self, *args, **kwargs): CompatJSONDecodeError.__init__(self, *args) InvalidJSONError.__init__(self, *self.args, **kwargs) + def __reduce__(self): + """ + The __reduce__ method called when pickling the object must + be the one from the JSONDecodeError (be it json/simplejson) + as it expects all the arguments for instantiation, not just + one like the IOError, and the MRO would by default call the + __reduce__ method from the IOError due to the inheritance order. + """ + return CompatJSONDecodeError.__reduce__(self) + class HTTPError(RequestException): """An HTTP error occurred.""" diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/help.py b/myenv/Lib/site-packages/pip/_vendor/requests/help.py index 2d292c2..ddbb615 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/help.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/help.py @@ -11,11 +11,7 @@ from . import __version__ as requests_version charset_normalizer = None - -try: - from pip._vendor import chardet -except ImportError: - chardet = None +chardet = None try: from pip._vendor.urllib3.contrib import pyopenssl diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/models.py b/myenv/Lib/site-packages/pip/_vendor/requests/models.py index 76e6f19..85a008c 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/models.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/models.py @@ -170,7 +170,7 @@ def _encode_files(files, data): ) ) - for (k, v) in files: + for k, v in files: # support for explicit filename ft = None fh = None @@ -268,7 +268,6 @@ def __init__( hooks=None, json=None, ): - # Default empty dicts for dict params. data = [] if data is None else data files = [] if files is None else files @@ -277,7 +276,7 @@ def __init__( hooks = {} if hooks is None else hooks self.hooks = default_hooks() - for (k, v) in list(hooks.items()): + for k, v in list(hooks.items()): self.register_hook(event=k, hook=v) self.method = method @@ -790,7 +789,12 @@ def next(self): @property def apparent_encoding(self): """The apparent encoding, provided by the charset_normalizer or chardet libraries.""" - return chardet.detect(self.content)["encoding"] + if chardet is not None: + return chardet.detect(self.content)["encoding"] + else: + # If no character detection library is available, we'll fall back + # to a standard Python utf-8 str. + return "utf-8" def iter_content(self, chunk_size=1, decode_unicode=False): """Iterates over the response data. When stream=True is set on the @@ -865,7 +869,6 @@ def iter_lines( for chunk in self.iter_content( chunk_size=chunk_size, decode_unicode=decode_unicode ): - if pending is not None: chunk = pending + chunk diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/packages.py b/myenv/Lib/site-packages/pip/_vendor/requests/packages.py index 9582fa7..200c382 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/packages.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/packages.py @@ -1,9 +1,11 @@ import sys +from .compat import chardet + # This code exists for backwards compatibility reasons. # I don't like it either. Just look the other way. :) -for package in ('urllib3', 'idna', 'chardet'): +for package in ("urllib3", "idna"): vendored_package = "pip._vendor." + package locals()[package] = __import__(vendored_package) # This traversal is apparently necessary such that the identities are @@ -13,4 +15,11 @@ unprefixed_mod = mod[len("pip._vendor."):] sys.modules['pip._vendor.requests.packages.' + unprefixed_mod] = sys.modules[mod] -# Kinda cool, though, right? +if chardet is not None: + target = chardet.__name__ + for mod in list(sys.modules): + if mod == target or mod.startswith(f"{target}."): + imported_mod = sys.modules[mod] + sys.modules[f"requests.packages.{mod}"] = imported_mod + mod = mod.replace(target, "chardet") + sys.modules[f"requests.packages.{mod}"] = imported_mod diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/sessions.py b/myenv/Lib/site-packages/pip/_vendor/requests/sessions.py index dbcf2a7..b387bc3 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/sessions.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/sessions.py @@ -262,7 +262,6 @@ def resolve_redirects( if yield_requests: yield req else: - resp = self.send( req, stream=stream, @@ -326,7 +325,7 @@ def rebuild_proxies(self, prepared_request, proxies): # urllib3 handles proxy authorization for us in the standard adapter. # Avoid appending this to TLS tunneled requests where it may be leaked. - if not scheme.startswith('https') and username and password: + if not scheme.startswith("https") and username and password: headers["Proxy-Authorization"] = _basic_auth_str(username, password) return new_proxies @@ -389,7 +388,6 @@ class Session(SessionRedirectMixin): ] def __init__(self): - #: A case-insensitive dictionary of headers to be sent on each #: :class:`Request ` sent from this #: :class:`Session `. @@ -545,6 +543,8 @@ def request( :type allow_redirects: bool :param proxies: (optional) Dictionary mapping protocol or protocol and hostname to the URL of the proxy. + :param hooks: (optional) Dictionary mapping hook name to one event or + list of events, event must be callable. :param stream: (optional) whether to immediately download the response content. Defaults to ``False``. :param verify: (optional) Either a boolean, in which case it controls whether we verify @@ -711,7 +711,6 @@ def send(self, request, **kwargs): # Persist cookies if r.history: - # If the hooks create history then we want those cookies too for resp in r.history: extract_cookies_to_jar(self.cookies, resp.request, resp.raw) @@ -759,7 +758,7 @@ def merge_environment_settings(self, url, proxies, stream, verify, cert): # Set environment's proxies. no_proxy = proxies.get("no_proxy") if proxies is not None else None env_proxies = get_environ_proxies(url, no_proxy=no_proxy) - for (k, v) in env_proxies.items(): + for k, v in env_proxies.items(): proxies.setdefault(k, v) # Look for requests environment configuration @@ -785,8 +784,7 @@ def get_adapter(self, url): :rtype: requests.adapters.BaseAdapter """ - for (prefix, adapter) in self.adapters.items(): - + for prefix, adapter in self.adapters.items(): if url.lower().startswith(prefix.lower()): return adapter diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/status_codes.py b/myenv/Lib/site-packages/pip/_vendor/requests/status_codes.py index 4bd072b..c7945a2 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/status_codes.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/status_codes.py @@ -24,7 +24,7 @@ # Informational. 100: ("continue",), 101: ("switching_protocols",), - 102: ("processing",), + 102: ("processing", "early-hints"), 103: ("checkpoint",), 122: ("uri_too_long", "request_uri_too_long"), 200: ("ok", "okay", "all_ok", "all_okay", "all_good", "\\o/", "✓"), @@ -65,8 +65,8 @@ 410: ("gone",), 411: ("length_required",), 412: ("precondition_failed", "precondition"), - 413: ("request_entity_too_large",), - 414: ("request_uri_too_large",), + 413: ("request_entity_too_large", "content_too_large"), + 414: ("request_uri_too_large", "uri_too_long"), 415: ("unsupported_media_type", "unsupported_media", "media_type"), 416: ( "requested_range_not_satisfiable", @@ -76,10 +76,10 @@ 417: ("expectation_failed",), 418: ("im_a_teapot", "teapot", "i_am_a_teapot"), 421: ("misdirected_request",), - 422: ("unprocessable_entity", "unprocessable"), + 422: ("unprocessable_entity", "unprocessable", "unprocessable_content"), 423: ("locked",), 424: ("failed_dependency", "dependency"), - 425: ("unordered_collection", "unordered"), + 425: ("unordered_collection", "unordered", "too_early"), 426: ("upgrade_required", "upgrade"), 428: ("precondition_required", "precondition"), 429: ("too_many_requests", "too_many"), diff --git a/myenv/Lib/site-packages/pip/_vendor/requests/utils.py b/myenv/Lib/site-packages/pip/_vendor/requests/utils.py index 36607ed..a35ce47 100644 --- a/myenv/Lib/site-packages/pip/_vendor/requests/utils.py +++ b/myenv/Lib/site-packages/pip/_vendor/requests/utils.py @@ -97,6 +97,8 @@ def proxy_bypass_registry(host): # '' string by the localhost entry and the corresponding # canonical entry. proxyOverride = proxyOverride.split(";") + # filter out empty strings to avoid re.match return true in the following code. + proxyOverride = filter(None, proxyOverride) # now check if we match one of the registry values. for test in proxyOverride: if test == "": @@ -134,6 +136,9 @@ def super_len(o): total_length = None current_position = 0 + if isinstance(o, str): + o = o.encode("utf-8") + if hasattr(o, "__len__"): total_length = len(o) @@ -466,11 +471,7 @@ def dict_from_cookiejar(cj): :rtype: dict """ - cookie_dict = {} - - for cookie in cj: - cookie_dict[cookie.name] = cookie.value - + cookie_dict = {cookie.name: cookie.value for cookie in cj} return cookie_dict @@ -767,6 +768,7 @@ def should_bypass_proxies(url, no_proxy): :rtype: bool """ + # Prioritize lowercase environment variables over uppercase # to keep a consistent behaviour with other http projects (curl, wget). def get_proxy(key): @@ -862,7 +864,7 @@ def select_proxy(url, proxies): def resolve_proxies(request, proxies, trust_env=True): """This method takes proxy information from a request and configuration input to resolve a mapping of target proxies. This will consider settings - such a NO_PROXY to strip proxy configurations. + such as NO_PROXY to strip proxy configurations. :param request: Request or PreparedRequest :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs @@ -1054,7 +1056,7 @@ def _validate_header_part(header, header_part, header_validator_index): if not validator.match(header_part): header_kind = "name" if header_validator_index == 0 else "value" raise InvalidHeader( - f"Invalid leading whitespace, reserved character(s), or return" + f"Invalid leading whitespace, reserved character(s), or return " f"character(s) in header {header_kind}: {header_part!r}" ) diff --git a/myenv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-311.pyc index b1ede4c658ea8834a271adaafa14eff2cf359551..d9c3dd4967efe98e8264e5ad86fac8a4b86bd0c3 100644 GIT binary patch delta 19 Zcmey*`k$3+IWI340}!~L+{pEn2>?1>1)cx^ delta 19 Zcmey*`k$3+IWI340}wbL+Q{{l2>?1S1(g5* diff --git a/myenv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-311.pyc index ba6a282ae5f4960987005b13c2fd7a30b250264b..aa4a77fcea3b07cfd3ea1ade249df2b0ffbabf4d 100644 GIT binary patch delta 19 ZcmZ2$zSf*;IWI340}!~L+{m?98UQrz1tkCg delta 19 ZcmZ2$zSf*;IWI340}wbL+Q_w78UQrE1snhX diff --git a/myenv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-311.pyc index 32d4a8a3e5c4a70c8dbce04ab76633545da54656..55c06ceed8561144e6cb1f00c36c869dfd7b2e51 100644 GIT binary patch delta 19 ZcmZ1|wor^~IWI340}!~L+{h))4FD~)1TO#p delta 19 ZcmZ1|wor^~IWI340}wbL+Q=o&4FD~L1SS9g diff --git a/myenv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-311.pyc index eb464e97bc8495f4de043cde3fa893640eddfc88..ee43b6ec01689b27b999fc67f0385494918a920e 100644 GIT binary patch delta 21 bcmX^3gz?}LMy}<&yj%=G;CgZ+mw6EYQ%eSv delta 21 bcmX^3gz?}LMy}<&yj%=G;CyH!mw6EYQyd11 diff --git a/myenv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-311.pyc index 22d27e377c27ba4ac430480be9efe9aacb2b6a02..b1c9581950be2e2f3d1e39d7665d6e254e67ff7c 100644 GIT binary patch delta 19 ZcmcZ?c`uS{IWI340}!~L+{krB2LM3H1`PlJ delta 19 ZcmcZ?c`uS{IWI340}wbL+Q@Z92LM2t1_S^A diff --git a/myenv/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-311.pyc index 1add8ca3678d4d5f68d60c12082c41025b76e089..50fc9a675951c5217a354f8c740387c9d970cd1f 100644 GIT binary patch delta 18 Ycmcb|c#n~5IWI340}!~LoXB+r054nx5dZ)H delta 18 Ycmcb|c#n~5IWI340}wbLn#gqp053KL2mk;8 diff --git a/myenv/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-311.pyc index 37e2a70e92dcd29cf7c27b98ec499f3b22f54576..1b8ffba3857f696da2828abc5d82f357a33f0d6f 100644 GIT binary patch delta 19 Zcmey!{E?Y!IWI340}!~L+{pEu5db&@1#bWV delta 19 Zcmey!{E?Y!IWI340}wbL+Q{{s5db&U1!e#M diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__main__.py b/myenv/Lib/site-packages/pip/_vendor/rich/__main__.py index 270629f..efb7fb7 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/__main__.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/__main__.py @@ -207,7 +207,6 @@ def iter_last(values: Iterable[T]) -> Iterable[Tuple[bool, T]]: if __name__ == "__main__": # pragma: no cover - console = Console( file=io.StringIO(), force_terminal=True, diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/__init__.cpython-311.pyc index 022844dccc8a181eccac39f218619720cb7125db..784bcabe8ba0152c80fc61e652ae78075a655019 100644 GIT binary patch delta 19 Zcmca+bSbtH;+IWI340}!~L>`Rl~$h%&P@y6!8T2)NE`HT!KQWuydiwuCW04C21;{X5v delta 43 wcmX>SbtH;+IWI340}wbL>PwT`$h%&P@xkW3T2)NEg^Ua=QWuydiwuCW04AIZ3s9D28V2C+2Q^nR>|lAyC@sZ9VBsO4Uqu8`QIv?SNRWg2Bnko6)Y^)e)wX3? zQ?4~-ZB1=i85 z_V@seE!L2&fNciuL(I5aziH4#8=W;g^Z@iRaQ!gH(UQq%6jP%b^ZC@+kH**5kb{83 z1pfmZAvg;7-oVA5r<-=SP2Gh6d>8zcCM(D!X!J|?3ZRkT7@*a_wPTK_JucO6f%Mk! zd-MeiAh;SZh#(O#oZwc#?F1_TD+&GrSVOQA5Ubxhe{8DGl1>l?Oe2^MC?qHalo2ce zEH!ZJG54Um-H66kYsiOy9Rwc(b{V(>m@lL~4x!OZjdPeUqDDxcFNxKN-keLvd@(h` zXk=JJvH>{+lL5H~ZaU^mXpd?%?xMy*%sr{G1dXNCSdaNqYHUPfn>FM^z()ih19lM{ z0yGn}0U`t;{j5l=M#t@AzKo6yqmgM1$p+*QOa|l<6aWedN&#gCt^so|I%OjoTdX15 z0XqnG0(Kd=1DJc$9)W(UrISX-y#ZR>0J{l#>DyL%YxpNuYxfZzteKm!RY z$XICf!tMe*K=2^oA%e#Ms|Z#D)*HC(n6IW&hU%MA!W#aRTL8Bb%mkDWlmf~L<^bjs z+y$s3XaGEB;2y_(4PD1GXgp^P3H0?V#TqVp`z3&ghQHD~^yMnW8Xhjv*Nybl@NgX< zgCP4{ck%3!`c?g}-h{kSfNTBZy>7?N|O#x&Q%mdUC)B_p_UIe^J@ExF) zV4%J`WVD7qWiQ|}f-e9^4BYpahuWpPQ-EOx@)MSvu_dxu-yIUs@TbHjD8y@c7!0_U zpaf7(FdI-suouum&__R!(pRHqQ1I*TPZI${2pr(Jfos7$T-(tlt`%^tfwb%AP0nff zO)t?0UwUeI$N}UVxW$;0Y!CM&AerDrzz73*T|w4DqnEw`u#sRZV4H#4jrls;!+im` zp5Q1T#Xx>gkXGn#r?}IYM_R+R0Y(wD14a{c)}=LL45XWa#6hE*4#s?gHQW?HD#27h znt|jiNC8y;#UC{aF{e}GDKu75qY?9s)^M8uVFT%_g%@SEmg9%~I(02pT=C-frB(f3%Bf<&NEsMm)@R%=90k!Jy|1c5#ZvQNV|S^$aqJa`zQvm^nc zn(MLNt18D1L zxc+B#o=n#foYO|UhF{VH&>IllGy#xAjby+KYTOK%O)wWQ&%i}6PoZN&5p9%c_*0qy z-w~VvoCQRm!uC)osL{_)2QbfEfh40Qm;``%~Q`M#Ep&AV3PiL_n5-tHpdX z?NN_LgEiz`z-EGv0G|--2J9gic9Ftpjp%i_Fy;a~#f=BtVju^x_U=8^caDd=TK$C$xjQKX&Bh*J5-8B4lTo1T`APo>UaM_q|r#+^l zal19-5x{DKq<#vcH2f)J0AmTB0K7`@8sMJpA zI0^MX8mkq4dZ=TG1P?3hdz9cYg{~U@XH?5u3auI*P6N&ov;)o&1dR$;z1^|IU59xV zE-d=vHBUiiP@@2IDK*N`m}3p82AqATV^euk zz*_`ClR_5_e@a(CFM_^+D+vYw1`=EY7-HZa$6P_zk^GG|MrlM(aeqIg^K5DySCA9X z=reZwFhIk@-XjY8H9TbMUmnRM4Zmrp7Mu9olHdivPJ%sv&k33UEe7rs z<~!+be@3It8gdp80r*e$DTT0x{}PVFJdgIsK;su{NCa@>>5e5bS!bC_kO!D!;O@g* zNt-@}#?#bz8S{KZ4_DD>}v4Q^8szR&>{cK$j)Kufr zZowx>E44-Q@2yyHchM9nEvl8eis99>%I3|QQ&C$~E!9cIcULSZuc}F^ zk+Qi-#bp(hmBsf+dEMOFYpd^V>zY2ls(fK(MYv|69vsqtYxREs1}(9nP^hKLg!AHK PS^~@ZIQ&yntBwBy9%s6X literal 7849 zcmYk>3shBQ76WZ!q$y$|pa{zQrH~4N_)L=LRd%3U??p>91yXxzR#T3( zs;OxzHP?{OYN4p3_L!U;^RZS_E0SvbN>>>6P*Z0A^?dG4tG#x=_21w3ox{E7xbm%T z-MTvbleurr9ACKOwBkSPPmtTR-^k56XRcG>yzaTzsqhp!5kW(nJ&qF*Y>@FId8IHg zJLYzj4*p?Sj{a37I&p~zCMVc&sD_I>LXTX>@HiI>&v24uobVd7m0n6 zp#6XY0_H>Xe^MjeJ9DBh7rVwpK(T=Fp~wBOiQ`CoDGB--@U4RX0Zu9S0dPjZ+;ly! z7orx8W}pdB_gdZrG%ENJ&@Nyup}#?`(Tnc|_2FXI=m!|2U@#zDK?ERD!A!s`1)l@H zQP2tq;(O@sViM4IlXI9P06re}9O(>{qegPkhpI#Y64NC?Wq@)4Q;)v8jF=|CO#-wR zBm33JA@nz^#7QJtRpK)GTU5fszi0~LVlOTUeGipLM}k&{TYN`fu`Is}Y|Ka&1FGGdYd zeHEkv`Uy}v17$(4esE1L`rA}uDiYHqL1ln)0n>oKzl@kYfB^~)0r32=yEy#8_lGIC z4seG6r7%z$)cr<{2jnQ20LWD^6);Uf8K7Li)T19LyO<`xAO+2UI~5!R3>KhI8R!ty zJ=jS=s{)6=P2}NX6N!K%1?hk+0h5bwM;|T;^9f+603E@|Q8jWLeS{=T z41cTr!vrXnffAtZwPXYG1kAhW?@}Y%kZ6(weFQk9pf^7ms1Fx+Q8OC-a9P8|10ofS z1&k1&1q`$d>K?2PutLEqz@rLQ1J)^64`>oF2hm5VT_X8`MA2OAE+YZ)3dRBw6eI&u z6wCn3R4^M*qF@1_R=_l%k5=bciNq?ESdBhL66R&VNC9&A(MiQzjC+Ib;&u*FbC1cs)K!u#OEsU75dRC5yB5O>c+($ zY$afofZ2dPPK|`|LyZP5(UW1K-Ez9_Ywds6)?-uC#jJ}B=$&x9DYDkFc*8$SoFziBo2uL zl}JLLA_Hzf$UI+YL!P|fh3N`^Y3z+ZGr>R{|Az@VF4El7H_z8)# zlAz)IvY}C2>>Y~(#49)qIHKSvphdw+z$pQ927QKXYt8{O1?YE-oR<;W!*4J;&&8hO zBA`P-NEkyX7n>Lg7@?p9P_E!GpiMzve%VkzF8)!@l|S@G0EQ_rfYSn|4Sg1;-4W9c z7$-oN`29qex!6T}@T-J+aF5hp;&~+2sYE0CDUvYFfT;r1k6*2H8yCB1KKf~r zFjE231?VS!lhRo(_UW*k-=zK-NVt!j76$5ox=_cjR$9-+-GyEPv@3AzHA%crd3mH826N|ARo}opBS5P@)(|aLtriUbWlOfn+$#~_N29dhZVd6cvV3g;H-cNdYi{* z%J0Q=2HdM41Tag01~bqQ=+zr!hNCZ1iTy|%kOZ{=&I*_g^!KTeAsaXm$;DnvHlRR3 z31BJU>PMUE01c8bThY%}i|#<;eMwLgV3&aT4t=p2iP*@A5nSv!VgMr*j0VIBm`wB~ zvWA%iC{?f&P^O>}P%c1Q7-$>R{m|_Myr*C{pjp7|MPH%TIE};^mG~9CR}$vCO$>7s zoC3^Ma0XB*K+Ze7=-*DTx_8|<&(Lw<8khkWxhFkxnG>O0?6q_U^Z~eQgaM*dA{sDR zC8hx8D5wNfDe!bKlyI?&wgA2tFqb?Y$A7;Z%(MhCR0+_cV2?vfxY(0=x-tZFvCs+7 zS-}l}Pz7TE2?8b+eYM)4( z9_oHzmILY)Yz6F4@IK%J1Lo!t0J{}@4ER*Q ze1^V8tr2xICt|qRtBpnPQ;9ev;#DFA{Q^mtuK|7mYQ@M8GD6NR3?44_Y7+rT0wxW8 zK&>$ciE2rZ4^XRMOb>=sE_TrjK$d_RkG@tGHM0Q=1!yZq-cutVpkJgC%}DH#1nmR- zQ^A&=4BNTbb2I^VDQE`lQSc?;D+Qx^F(h!YzlLP=52$mbB9W#No6tWf39}inSb!Qa zvR#erM88BO`rpcl+qu}I4+IQW5DvIYK~!&scrJEiEFeKaVjqSiF7{ed&_5*GnoPh_ z0XmA26EZ?y0RAgrTF^hNMm&8v(Uprm$0)!U1&M$Z0h5h>nOdU&iD{CcnSfaeo&da{ z;4gsn3Zidgh~r|XC*<7kKwmRuZ@uN7{jrr6s%_G!o|L{ zoJNKL?+WB|Pm>i?0Ol(20WNNlk(ZkoUg2VoKKDNi#KpoxfCdFC0Z%H}2-vJ3;|N0* z7rTb@1w$Mc3yFYg0kaVOD!D;s1>jKudI=-1$_Tv%_=f_gg`qPSyGs{9Zw37TcPJPH zxKqIpz%T{T-!Q~+v5THQ$?y{w3x`iJ9Oq&oi~lx>CU9}VT-V0^W4IRgL;s|@+TW2#Id|+NzgIC2?aj_PAfPE z_(MUra&NC!%v5*89ryv{fpn@fUe`<@=uus8Zz;OkR6XejPj-YGXI{a6w48a1P8~H27<;oW*FT(RhNananlZvO` zoi!z=aD&s%x7)c;nVC>DHQ@CJiV7=BA1JLZ%JK%PYHNH&cjsnhgcW+{*U~&LVd?Wr zs}~0-P&99`cmATHNmN!8pjvOFue7|Xbgnm0DD9RMuV1cd+q diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_export_format.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_export_format.cpython-311.pyc index 8bbac970b54a34389fd0eae35c7b07fe216fc11d..266dda911af10ea2a3d0bc308a642eedfa9af42d 100644 GIT binary patch delta 83 zcmZ21v|osKIWI340}!~L>`M!n$ZIC*&d9)Eqv+!A91%0&J{n>G delta 52 zcmdllv{;CDIWI340}wbL>Ps`3$ZN)@&B(xDqv+!A91X= diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_palettes.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_palettes.cpython-311.pyc index 3311cafbb5ca3b1016c337c32d199bc672d5ce99..1e8af9f4902099e5a406cd269cc1c3430e427185 100644 GIT binary patch delta 19 ZcmbQJIZ=~qIWI340}!~L+{o1~0st=K1g-!8 delta 19 ZcmbQJIZ=~qIWI340}wbL+Q`)|0st7~ diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_pick.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_pick.cpython-311.pyc index ba81c6b71bcc44e59e78e02c2b162f95887d21ee..92a764fafa873670591fad9496678e68d7626b92 100644 GIT binary patch delta 19 ZcmZ3$2lr&dbZi00gcl`_ke!@>WX=I|F$QNbrH2(&o9+H<|RAS>--3U=kleVqZYS hM`i{#{+7rOOdv&Elb6ax^N2FANL^r-ERqBo3IINc8yNrq delta 114 zcmeCO>#^fq&dbZi00hp5`qC0M@>WZWx&nC(Nbmz2gS_(Q+0r+e^jTQtJ}_VsA3eFIWI340}!~L+{l&30suI>1rY!M delta 19 Zcmeyt@q>eFIWI340}wbL+Q^m10suIS1qc8D diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_timer.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_timer.cpython-311.pyc index 1eeb39f6e0a26849e7267b9482a36993f4c3a9a2..3a28d2a2c19795e2f773fa11e1159be04a73aa20 100644 GIT binary patch delta 19 ZcmaFL{*;|-IWI340}!~L+{ksC82~oM1yuk5 delta 19 ZcmaFL{*;|-IWI340}wbL+Q@aA82~ny1xx?{ diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_win32_console.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_win32_console.cpython-311.pyc index bce3f38d1bfe1420fffa62260d89c3e928182220..68d08dbf6bbf154aa24e706ac40e7163f1277314 100644 GIT binary patch delta 21 bcmaF)n(^gpMy}<&yj%=G;CgZ+*ZooeTe%0F delta 21 bcmaF)n(^gpMy}<&yj%=G;CyH!*ZooeTZ#vi diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_windows.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_windows.cpython-311.pyc index dbe5cbbc9f89f69909df5f06f35e553a7ac66280..a83a274e0404f3fd384c50db362d9505f42f9404 100644 GIT binary patch delta 95 zcmbOuHb;ziIWI340}!~L>`QCi$h&}zQDgHuHdjVQrOjX1r!q3?P443CXOx>P#ib}C p$iOK+gL^^L1$KiE3@nTiNCeB|a4uC&R-oXIA3r`gOm5|x4gk`q8({zd delta 95 zcmbOuHb;ziIWI340}wbL>Pu_e$h&}zQFHS;HdjVQ<;`E%r!q3?PwwLEXH=Lh#ib}C p%)lu=gL^^L1$KiE46KY2NCeyDa4uC&cA(&oA3r`gO>X6y4gk_j8)^Um diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_windows_renderer.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_windows_renderer.cpython-311.pyc index d1a7bb68a17a4e612620adbe10c6ce8b09942709..21388a6611390803db10d74d95d40649e11db148 100644 GIT binary patch delta 19 ZcmX>se^{PtIWI340}!~L+{m?)9{@D=1uFmm delta 19 ZcmX>se^{PtIWI340}wbL+Q_w&9{@DR1tI_d diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_wrap.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/_wrap.cpython-311.pyc index 7b0bc33f2e88144cb7dd30b0b2afdd69b6c1e2b9..d6fce90a4bb9c7b80c5fb67e7fa533d049e2598a 100644 GIT binary patch literal 3871 zcmbtWYfKy26`rxj#t)1k!Gt#xZ^W(%F`LIG+9)bbLLMxEO#^H<#MC=@27AJI#=SER zfsQ2uQP-=c6^*vVs7Q5IX+oN`NgvWiRjdB)pVp2n)fy=hl6Sj{)E}1er^>IMdkqM) zM5@&5@tylP=R4<~d(U_0fy?Efpq%^LPbM$9D5{7%o5fmg&@Z3S6tzV06i-W3lpdpL z+%`$3F%!Jak~zwZF)+sP7ReH|j#)|DDpf^oW45S$%uZ7#N-$j~mM|t?bsrEP!M|L_ zoO~N!eTx~Z=G*xWe(x>Im`kYP>!(b39<2bfM{-AN$7%^uE#L5X-wp(~;Lg--z*W5X z#!5+oPzV0l`6j;MK3I4}tYD>GBy0KRU2W~DFtX9P5AR1?6EyW&pIUZW0?Gdmv2`aR zZyJU@8m4^gI`+s%8%|D^6^+wGMOKHPZ|m0t#7#)TI^GBvuuF;(3rd`-`Ami_BuG+F z5@f>>ioh`Ls2&3`B}}?$?uu^8Y;EM0Ff=MR zB>*xBbAkbB^LDAtHcwXuGGWopI-^@A%^y%paPa>p|Cn$3_nXUG8)BaQ{HiEOyvhn( zD8f!Fh-W8}5@ofBz~Z2?oXT=6389095>jN16J=2jvu~*yhqRz5^TN$;R*?D4CPwl3 z+0(2Sx4aN_fD=`siy@=j48aoRkQC>^4%p&CTAY*04sbHha`Fs29T7D_jd39mQHT^0 z!x7C-lo1Z_kdHB{kPyUn3`>;LLJ@-j4cV}SkrI#jtjG>xhApP3B0g+}1B(XBk`}T6 z!wjw)3?5f8%ivYA>?`i<$-t;8AT=-?;ifq$&?l%j~Zf8w%<{VkpuRoJL&CADb~O#3pJ4qt)-@?03Xb}$gDrSEmV$SJIZtQa)A@-b zWl5<8chf)J9nakz89L|o=H1>DQ>fXyIGjF^t!dBNHl7!r)}`?~CoGyaZ3E5pYoCwTNMcv@w`TMS?I*D2nvTE{Up!Gip4v{ovy0L7#s4FG!Xp zDh!8PH($q4q$C(fDvP!)F%nkIvN=mZGF2Y;K5G2$0l-UCC2R@1iPEjQefLDEOsh(i zghQuw%PjDH!l^rT#}u)csMf2ITep-^D>Y`}?nzi~_v)ZIg{gr;if%$98a_%JMYrqp zW7Ce*a%s-Zd036B5*1c+gd}`T!mU>!Cs=0m9d{2+={2aD_~fqC27g$+N(0X}i@rmG zcwKe-=J3DPrG>3Y;280+0ECFu1RqEt56K;1fmi8g%g_U`(olreYERV!{-$0j@@rxWuy) zFc6bOASew3LiP%Xom3DDL%!1!Ip`4SICvN&DGN+UO3LczG6sF@scNyz)g{r zVpWLCHlln;qh>fczAD4Y#bQ84s0zA-df>*yk&Pi69>FDx`~0{ zCY7paKOS|GyScnuhMio^_@+knc#;WXQw>Cp5HHMxfl=H@h?Z}WAmMkTiOj;LsllC7 z&T?qV9M9k{0)xQ|RBHj21bbVB_7PjWcthlcAQnS@7{O~-zXt~usI{5$9!S1laJA-L zZzRtb_Uug#yr^wV_J7&t%^X|4wsNgRu@*n6a<(R*R&8;l(9p3cW|#-g&zyH%_guLK zf4;$=au%99G6!?bhf?msfum1<@ch7;tZo0A^FWDevHRDm_od%Wznd9Z?p^84Rd=NZ zQUfI`RojvteeU*V-CpR_H~2?>tqa ztezfHEj!XonlH4lC5mq9Dztjj=QHmt53UTR2MaA7CCc2?Q|LOn>U-Mvu;+14dLTWp z*1G>!!>jdouim?wYxSqkrO%aI7;O*L*aje;&O&2*+M13pyH;FjSHXKQ<6G^!+jFmH zabR(vP}f?b7?(feAun*ZZr`GHG5%B6r>;d;q5aLYxXLUmE6SqtKWonBEYpmdaP)0K zxL-v%7=+KbsPK9 z&YnJVw(s2e3m5y}8@Mz$^#0}VTp1o2{ouPFUL9kJs?q!!-J3JB>-gBkuRt{d*$iJ4 z#knV!XS9eS7w3Mv{wTek{AF?ev*N;1apBj+`QH^6{#=~@ytwe7xbTPdpa1Bq!;#f2wC;7M`rL2+(5ehgq=rww)vA3yQ-7tcQa`jg)m=kI*+m%o1X=_*nD zv5zUI5{Uu6A`rgree{UWwrv8RQPhGfoNcHLS46lSTE4x8BN&{F!>6qf3?efO873qc zR&6E*jEnF!Wmtmvqq&^I7Q(RQEXRp$RE3miOq2vv13i-XBs1`C$y^jbu>{#G^fm#D z0hL3lp|~VGq{z;a%%|16bWz9_m zhRs$!Yc-x!IDIBt(~+y`$k%ivFBBN($Aj~O**zmUW;D-?W|`3fV^5w-b)~wpp2JU% zFCei;dKq?Zy delta 1659 zcmZ`(O=ufO6rTN+##Ho^i6xN-Jj9 z{V_5UB?kvWQP@H^5U5<-M4>+9m_rMpr$Ty=f)2}q!H`RnlOUJUQ{Sv`ngsf0=goU> z-n@Bl=9~R-e>YjZud00rXzus#R*r`ddd8GJ3T8lgIm;pR1HuS%2FkOMH@G67=ZivK zD2jQJLs-C~ArfX$RO^&&a(*gG$a=@hKlig zJV+*v2et=$Nqo#480Ck^P$SWk-{g4cwR~YJ2$6uAA{YYU#CGzY0QCsYX*rdF;<<}K z&kR3jan5H1KRj;}TDW2mU;IS3Y+qVjEjt1~J0??NuhPuLbY`__iZjOm7rh%6sr&lC{#PpZD&J*b) z?unC-&t8-&eQRK=aM#(Eh~BRBy^_lno?fye%-*9)q{3lto9~snXI)opWlx4kiqn#Z zh3LBKypZ=rqBP2*id<2h{?H*#b&iLIxtlOE>bM~NPQ;g~WmCOOS?UzvjC{c$rA$9% zXGIxG=qR&>u>PfvtHh$?OjQlNM6|ML>9%f`{D`(p3`2vJG|r|)jqQ?TqVknVF`Kz+ zU-Q-FYbIoXHD%Z_3azON?Wqf$ zsSEYo&h)W|YI}ONGdgwOSC!=Y1$z5vLceJ}&J9=azw~_Od zq1t&m!p=0TX~lwG(zFcchvv+ZWg6r;yYLK0)6O&HN|ikxPy*O+i|bD=1Kt%lj`L8Y7BmkX zZvFq~bkz^4Aud}N;KsPD8*U^UR&(xQys_RnG}9S*FEGE&5@TGvi-6UagP}1Q49&%0 zc(nL<^4Fz6e4EW8F}kt#R7kgkv?m^H1)pQ~pL*vp*Xldd?mN=~F3xqtxz^s-RggFe I{z2jY0?5FmN&o-= diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/abc.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/abc.cpython-311.pyc index d7280c8ff6ac2380617a050d8373b47401a94958..e7cbb6a25ce6e6d42dc84bb9c2af5c953c8079bb 100644 GIT binary patch delta 19 ZcmbQrKb42VnpJ delta 27 hcmZ3TxjK_;IWI340}wbL+Q_BP&Xk_H*_ypT7XWOd2Uq|A diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/ansi.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/ansi.cpython-311.pyc index 91f7f46eb3fa8a0422169c187c55e1c3b446844d..ad88045b21d16b12ce24228214ad2a9b856fbe0b 100644 GIT binary patch delta 19 ZcmbOfG%1K{IWI340}!~L+{neD2>>&Y1egE- delta 19 ZcmbOfG%1K{IWI340}wbL+Q`MB2>>%;1djj! diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/bar.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/bar.cpython-311.pyc index 4d85cd90f57f5e879d074dd16eaacb36901c66c1..362cab0fcae7c78fc5fb7bd1646252083872ff03 100644 GIT binary patch delta 152 zcmcbtd|8=yIWI340}!~L>`U9fk@o^OBirVC+}TWwVVk}9S{QXySY>aB%Y9%5(VFI9 s`T?it2UZ~e0|P4Iv-ubQ3`R#EMnhF0M9Nb82|tP delta 152 zcmcbtd|8=yIWI340}wbL>PtJYk@o^OBgf`@+}TWw;hVkqS{QXyS!HjC%Y9%5(VFI9 s`T?it2UZ~e0|P4IxA_hF0MOYU6vl6EjJ2ux*PFzc#5!~nghC%cp*TAf+yq7H1K0=19q%Lompp*rEIvaA zheAgmBLz1X&q;fuN!n)k2;q0Wd(U@H=9Brvd@~H4z;pHa{CIu#Zr+|JcN#GrG0tgA zGjf}Bteoj4T@sLQ6t3}UPIQG90^i{+AXZmAR7xx?v9QFVd|#-|lJF#Bm68xkk`QY` zx*$$EY!=CLyrtSkcaW8P8!rU1M9F;;^|C&?BN!nVfn_%x6;Oq=nV2GJ0cq0&P@D3W zV0AJmJ(1k)8J}iD=^5kcF`UlQann;aWUL!XwszzmK_EC4AYJryDeu6biiZDM4~Q2) zn`_WR(4+hi#?t_$qw~)(*;uWxAY<#lkQe0}^3 SW{PpIkiBrB9zR{eFZK(>$IrO{ delta 880 zcmbVL%SyvQ6rD^OAI-aySe=XyD7X^}{Q!l0LcyJGO8tQL12W55Nx)4$KyWSof#9;x zPw*2`aOcK*Q`3^9S!foAFr0Jd-gECPri-cbV%uE;U;O^~FuQzp?yi!1gE+n#=k(C% zQT9`Se+^U z;3>|tQRyl0b^*7ublmi;HxHS$haIJx`7k6hD!VGqlUkLWv@sjRdX)c4^16tr w+#)|n^&-mhCHT0bKGX{!57eN(p%+ij!&~k1?R)s4*%OU)_)#?q2&e?mKm;Ekh{{i7E13+v)9%7_w%(Zn z;;!3768nI@j0sINh6e*Akf`B-7!%{GZ(GvDbskI;Uo^fn5?>l0Jm(HuyP!8aXYV~f z-#Pc(d(Qo1&)nYnon$gbU>yDNlgaxV3HcQltxU9k&7P9(*wB@Ld!E;Hnr0RhcR4 z6oAW~W6A6CZJ6CdB{7N#Gcifo7S?q=TucU5_q(66+sabU*llRnJ<f zNvGh{P7zJ}9ldDOj~ljKaSgXzv7Ogp9kuwZK4DChOjszd8kS{TuuShG>BXUt<8nX3 zO?Q^teyD7_6Tt~05+O2t5IlYGv-BCI)O*;m$Gafqi~^$_pzmc!|A zKdh48YWTqZEX@3iy|LJ4n)Tj@6)1h+ z#O_c<1-7Q}A+L})(J8jF1vnhZLGOdaSD-zX+yvSulKs-zVU$IXXh2|t8NKZ2PT8Ka z%pkp2%FHb}Ttyw+fEEq*{5;Hk8Kd{3VuxZQW2m;%`@VB~ANux_j_C$CLVN&t=N?F1 zhv`{N0pA5=HENX|SDf2_p4j8xKd5w6iQy9(H_Z4rV{E*Xvh3_@9p#4;TR(_yO>uA1-88kP!M!odH{fe0}OUfkdu z$D)6xl%OoB_h;%*VJ}FbP01H4Wm}VYH!OWwWFPHRs4tJDcG54rTF>^ps8UIkyB{%T zW=xxDvEcUa@?K62)cvq9^*aNhZktzh$$1E5j{KD;>Prnd-`u1woSr+n zoaz76nmgId4c?MI*Oqc44LQ5KF*SF5Io-EHV&Ne{=A+H@jz)UN-ST33-%@(te5{$< zdN;P1+x_*KN4fp;oy+mu3W-FAnu-4TlMCk-jxQ#LmlDH`#Bj54blY9&OKqvJyO9`d z=C;fqpFh5w7=*>G=wf1IDKXMWj5HJ3h5d_(twIfKcPp`ImY7{sebHL+3v`CP5!4>Uxpj|GDjPj?fWIohF_#Z56V?6%O8W;k!Il~qu zLI?m3qCD%zbbWFbo;6d~IX+Up#GwyP&e{`hrD8c8n~EQC-@s{LT;EF_LS*UJ9w!?+r-wosvMlIuvyD|g^$A$ z`=FD9OS}?-=dDQ!jkcduSoX%V`L6y3Y5RE}XAgQmWrw_h-XZVJ-ZAgv-u#{wqSD@V sa|Kf-oVb^rhX delta 2593 zcmZ`4TWlLeaQA%YoPBnkIDY2U3nhhXQwmK)N@=S?+8|j4K7yb%Etc_Z9Jh`g_AXGO zvtmIc+^T|92dX86l&=y|5S1z@p>!cS%1-+|NK$nT4 zdx&pF)V<5%6_C8zJ_#`CC;l1CB@`kOC5u5$h;Q=wIk)axmXh1ry1(>q(Y}poU*hTm z52+9Q&!KMOTX(7Fp)=jwogkM`X54!3vY71Aw{vO;sA0~Lh;rY}nL$~PfR91at4Gg5 zkP)Ifm=3`V=rQ}2JYe6%(%GOM*ZZyj|0d-Jx-#XTJ=HuXB%|NP}slsedq)FKO8EpGNbUvScGfy1xc+N2G{le1&Zc5ArTF7j^JscEaGPkaOEPRSFvY!-h;kdnB zDm)HZhz!P3)gv?r*a>judMZQm`Ba`1D2t$Ce~w3a?Rzqn8^quL>WP(ET?H712G1;!_1hv>9M@& z>JZQe?c?%^92Z5}~bccOMc`?9ZM29!P0sCd&*C2h*Hw4l{{(j-r5yo>fuoD2>D3Zz< zDI-_N=1Dtr@8ooI)}Tx+Wgcsu_9dTywIecj9S^?}_k1@K8?`?Q?2hyI@f*Z!>*4JE zz<%xeFM;Rq5`P{UZVc8yhdf_2a%Qer$ZTdL$ZovTogm!)1J7k-0&!zp@Kiid>3CVT zAm=-~K*?nZB{7S#xFlJU{y_boX{Q=%FD17LiM%l^S7%B?K^#2=NmJ@7$(Crziy&y> zv&S_}$5vMsck03DzZ~H0t>m`kl6Y~PtB1@hi2}0R)|PGuReMZ#ErXh^ zw}e^~7hiv#lJr^CB5NIJ!46aMHmryj(p4=|ozRZLWO>pH^Uf{+pWw?Vi!5|HP{I}#(0Reya`74A zl5nwmdcCGtVQDTJ07N05Z9CNOy2fIiP8Smn|& z1`Yu**xx3LEg$PG49*wld5su!3iwMFldJ)NF#PRC>O@T(XbBxR<$-A?Ug80`%|i7T z1LZ`^je>pUL~}^3zEVEc^aoe=T|C+F50YQ_gEiAv(8 zFH(K9?i;Ekn!aFVYUP=_Z?NGTtnu%rGFnqcR|$Z+GTMNhI7-9z?eP2KtkvAbmV?h} zn6ih^VvazekIXC-GG?)uHz;cYj@x{99+H-_lCxiqYD@bV)di{SxN-%P_j=xw+AWy( zIo4r#7#%s4Dx~K~D&q5Mz-jxr|74?NYIZRIgjn%es z34Ck0Fvd;fDZ|gc7mY-QYv?~ddn9&HsqSc@Z8)+D$bKWH^{;(OMhv^#dS* zLwHXM0a%&lh>64Q8W;!kt@-`rcklA$R`3K8eU-%Ca696|a1xEk? diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/console.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/console.cpython-311.pyc index c9e245ad4afa5e657f659c9f50cd6f70ab18cdeb..6e69f1b3cde5e994d935665e98a9e437a864b0eb 100644 GIT binary patch delta 1127 zcmZvZdr(wm7{Wv+uG+8hc!PDW9rmkH%FFtc4cX=F za2D3&M;F&s@TjHK_3glG^ha8hfHtyh9Ouzacd|YJ&d}cMoxpiEnIof_26LH!VOH|^ z6^xNRFAkVw&*yjIclLj!o_?Kn&TR%>dHbp29z|iC!p5cnFo$^8N(@x2R;_6Hq3d-G7DW1Xf>n7$RF* zAHp^scpLsIjURXyL9F=Tw^&3=>*oYmX-VS*5J&TF(}JC*Lk=D(>`kvbk_?AXz}c$1os zbpd;+=tMlQj~d&Zz(;iN)5Hbu;!alb=%(XemI8xhIdw^c37Y)o1`h*W_UZr|`|)%) zB3R3r+seng&-NmbInVutwX~zNmdAR!-Zdd0pL%_YQO{9Y&m2%rsTUJ9sG^E~4{(?a z10e!VP~>0^aE@LavTD&oHKPSQex-@ADIRyId;B*obks5Riyn45bn`7eDkyBGL4%Xj zG3(UhreqOO4a`VxEusOlbY6!PpkJEPBTR%%3N;{^N0QrNL>V5Hd`8^RAjkcc8C^)0 zDlM1}z~|Dg2s8j&rTIwo_`xgn#9&sVOuY~ftp=e|ZxVt;rG0D--qRpYa;AbbO1*Uh z{)SYQi8j&jicT@Tp69rkYEDj;VmBdtH}a)CFTBP*n;|Zfx&Pusuvr#WspSkNS*N0Y z0sU0;=Zsd5=qYMm<=Hi4jT#DCDF>*D2e{x+Pt1^Mg&e4A!$P5^wn`3CrI9n)JRuDR z*`&%~E+ov8(Xeifyhzm{oY^LuRkU!{2j#^oS~-7%Y*X>R75`ngQ1bO6BLK^#fDue- hg%Qp!O<%>=d|dewM9AF#$7%Kc*8SO1Y51Dr@;@A#kGKE; delta 1112 zcmZvae@xV69LK-!?|r{_hjzyu9C$|z5h#Bk9r42e$>~W}fDWW2%N!y{Fb#*`H2X!i zrYV8&Fz-O81u_&et55SOL}RxJ_=^~ru4Dp@aL$Qemn1DOI=*Y=A3cA3_I`by=Xvk5 z_w(%O(%tUT8Cnd68G>&u_f!?u));KK`qkXmWxX@f8SP}we3rKzMXC$wqQ)l(?uwL?Jtx)Q3%MTk-(5uoqJfU?UBujEH!fd7iz7-PEw8 zMZ`XGENcUH(70p1290E0F(jguCSTYKbkK+Cd4PwFW+*s9KV~uwuCn5+eq5*2>{wug zy}7y*x7brTC(uiSIa3<^$p&-x;dfT_$|2k(d2O}`nQ~uq0O8cIZW|Curu73N>})hI z7YiwMLmJ>GD`Sp%O_XH~yAC9=BeBam3aemDHs<^2sX zvZ9*r5I_;NUJYhZ_<>=-PH>y2V+*X$5s^f194rM^&`*aZfDHQK@NwWJdh65Wz*=_Z zvr(+4#zq;)r(;dNgM}2*TrHxMwYEIKJJfj015}W+H4dmGcUu8aPu|ZHrc;Xha)*d6 zYWsRK&`;KHE=m}p(Qn5^7--8NM?Z_h#Y*-yDHDAeSQwJ$`8C7h>>G^0{`$ zK`X(=dl$i9_FccR7`r88@xrAb37tITIs66o#r-vGcA3#tVS(fd3xo4t;?>V%p=>PE z`TlOLC}e|0z@NRd_43P!V{Q>A`d`b|q$Y!8Co zSDTLs0U_>~E9QBML1m+0vbv?p_Y{8>O@i6xw$vFFvx)(NCDff(w?qk4(IN!dlps|G z3)aV#S*o-OGmMH&m5+?{&v*smO33pRVI_F+B`lta2;O`RV_IHy1E<8;@-Rdw!vEKM PYXAPDyCuAQ#FzTtGhB(J diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/constrain.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/constrain.cpython-311.pyc index 8068745c9baf2000bd9465fa25fff0c4a28b05a0..6bd0af4d7619aa86702790ee1d07bcd504900234 100644 GIT binary patch delta 19 Zcmdleyiu5IIWI340}!~L+{m?@696!*1lIrn delta 19 Zcmdleyiu5IIWI340}wbL+Q_w>696!M1kL~e diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/containers.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/containers.cpython-311.pyc index 9c56471663bf7e7613da838e865cc1ac8c7f3107..a4a44eaa686396d275e47d2f2c8d097110bd74e4 100644 GIT binary patch delta 190 zcmX>Wayo=}IWI340}!~L>`SYg$Q#1QJTb|Wkz?YTWFOv;$N<-PXAf6rZ%;q>TO6Jx zsYQuNIjK-qNq*5S7N5-Gl3N`91tppJd5Jl<*h4A{Qo|C9Zn1{u0Yz?cxu<>V)( zY>sAZ;bP?2{D6D60OQihb7Us-rRL-mD>$EC68ZKG^^O delta 185 zcmX>dax8>*IWI340}wbL>PxGf$Q#1QH8IJPk#pjjWFHRClGLKalKi4u5LQx7>Ma(Z z%;J(;9R39*nfZB%Ik#9t^MH(79QkFbMLGG2DYw`|DhpD>5{qu}hC~Lq#yfksI(vKi zxo?hUY~f;L-~51kw*cdU$#Y~Tb7mwKB_;!HDBf%61SK$^Gb@s WK`hqdoXq6ZA~ui|$L0#v%PatA(mfXd diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/control.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/control.cpython-311.pyc index d8336df46d9bb0b6bd107bca96da42436f2bb6e5..e9d7c1a7438560dac349bb78aeab708876862c6c 100644 GIT binary patch delta 19 ZcmeB-?TqDG&dbZi00gclH*(eM0RS|$1sDJT delta 19 ZcmeB-?TqDG&dbZi00hp5HgeVL0RS|H1rGoK diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/default_styles.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/default_styles.cpython-311.pyc index 93b79a353249ad4b7f39196e0e370dbe6bc7cd77..82c0f2f0cb6d1f3562ffb0822ef358747fddf4aa 100644 GIT binary patch delta 19 ZcmX?+bRvmsIWI340}!~L+{k5T2mn321!4dI delta 19 ZcmX?+bRvmsIWI340}wbL+Q?;R2mn2e1z7+9 diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/diagnose.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/diagnose.cpython-311.pyc index dc8439a51ba72afff61b8534ed9e4492d8cd6fc5..dfb09b21b25e35ab290fb67cd00d4c95bfa51d3b 100644 GIT binary patch delta 19 ZcmZ3(w}y{vIWI340}!~L+{mTG4gfAf1Uvu$ delta 19 ZcmZ3(w}y{vIWI340}wbL+Q_BE4gf9_1Tz2t diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/emoji.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/emoji.cpython-311.pyc index c813ed6c7f7a55e3f70dcea794de8d97db3895eb..9a30bf972ac47946836a3cb6c0176a541cab9f78 100644 GIT binary patch delta 19 ZcmX@7dQO#VIWI340}!~L+{krA2mm){1zP|B delta 19 ZcmX@7dQO#VIWI340}wbL+Q@Z82mm)Y1yTS2 diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/errors.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/errors.cpython-311.pyc index bcdfe8217d48f8f645047c664082d9b6f09f445e..011bb8470a8180160678b6f87962faf608154071 100644 GIT binary patch delta 19 ZcmZ1}v{Hy`IWI340}!~L+{h)*2>>oy1U&!% delta 19 ZcmZ1}v{Hy`IWI340}wbL+Q=o(2>>oD1T+8u diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/file_proxy.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/file_proxy.cpython-311.pyc index 0d9182a33dd4c1b08a3b03dbc5c4136900b7cb04..41c08032f410c836a79110bb807bd87335509815 100644 GIT binary patch delta 19 Zcmca8e^H)mIWI340}!~L+{ksD9{@KB1yuk5 delta 19 Zcmca8e^H)mIWI340}wbL+Q@aB9{@Jn1xx?{ diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/filesize.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/filesize.cpython-311.pyc index 66746602cca78d1c8552c31882e119b3b5c8c4da..f21ee9b163749f7eddfa114794133b300cf7c2af 100644 GIT binary patch delta 19 Zcmew=`Bjo@IWI340}!~L+{pEs2LL;h1+oAD delta 19 Zcmew=`Bjo@IWI340}wbL+Q{{q2LL-{1*rf4 diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/highlighter.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/highlighter.cpython-311.pyc index de5da1a9538eb98729c25899b13bcc2d3860c523..502744b061de4a19d1cda8f4246fbe193268a08c 100644 GIT binary patch delta 51 zcmewz`X`ikIWI340}!~L>`N=$$eSs~=sdYx%$~h2R!h@QlYMfciqzz5VpWVmn*+sH G2?GG5R1ekw delta 50 zcmewp`a6_&IWI340}wbL>Psuw$eSs~=rp-p%$_Y)OVdx2eR86V=;TXc^^Ad=gTz+} F0|1S14?q9_ diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/json.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/json.cpython-311.pyc index b0ae5807e5fb3c44edc144eabcd07c2a411e09a0..d0f024d14b19986b13703284930b7a0012f42965 100644 GIT binary patch delta 35 qcmZ2ryug@uIWI340}!~L>`Pm|k@t=`PuU(k@t=`>sQ1Wo_| delta 19 ZcmbPYG{uN(IWI340}wbL+Q`Kv2>>r$1VsP< diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/layout.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/layout.cpython-311.pyc index 0de430336be030e52efb39cc4df14c2e6fc0983e..2839a1ac8273e7cabd1d87ab91236a525ac90fa6 100644 GIT binary patch delta 323 zcmbQgjdA`qM&9MTyj%=G;CiwzZOcYpeI3Rdn{9QDF*5$x%%V4u(U6N%W`@TH1|YRU z6ig8yBsL$@cV}i4n9OH&<(utQi^YH~+M*WM=f(Tx=i5%$TwHl9N6oW8`Kgm+Q=o)st_z|7XnGe9L17GvnmV z#XhEtjNOx0`nJg_YF}40x}<1yQPJdzqR9saR$f&wF_Cuy+YHvtzJ5oTrBzr(J}|(D zkIW2gd@T_lm_PzSn{|S?*v$i3809}OU?)F<#lL__pk5~K7Re7xV5J$Gb0aq~0sxK? BUzz{_ delta 323 zcmbQgjdA`qM&9MTyj%=G;C!erZTm)EeI3RJn{9QDF*5$#%%V4u(U6-{W`@TH1|YRU z6ig8yq&6SZcV}i4oXlr@oRMwwHRFv;jB1lR%$76CZ#FP5Vr10Wyx1a@k{HvhD)WM=f-Tx=i5%$T|Pl9N6oW7K9Qm+Q=oHIr|-|7XnKe9L17Gvk!a z#XhEtj6IWA`nJg_>t0tjxuk4zQQ7Q@ve^d)R$f&wF_C|Q*bLFlzJ5oTrBzu)J}|(D zkIW2gd@T_lm_Py{n{|S?*v*4j809}OU?)F<#lL__pk5~K7Re7xV5M1`b0aq~0sz4e BU;O|8 diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/live.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/live.cpython-311.pyc index 7854f5deca7af415f2f690a94ea77b5508de28c7..eb6c3b406973f27370668d41948f6cea7fd51bfa 100644 GIT binary patch delta 64 zcmX@OjPc+yM&9MTyj%=G;CiwzZU07I(I910_v@yW^WY?fS0Jv!upa1{> delta 64 zcmX@OjPc+yM&9MTyj%=G;C!er?chdU(I91W&+F#?m(2Yyng?Dn5B$KuAt(kWE{YgW QjGK@)BV|GCWY?fS0K2so?*IS* diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/live_render.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/live_render.cpython-311.pyc index 31eb8b5c30a83710fe578d8c8f4c4bfbbaa2de3b..07042f55c06cd81deaf3c3dbcf5a952a1c534096 100644 GIT binary patch delta 149 zcmZ3fu~LI~IWI340}!~L>`M#U$jijf$hKL4{~D8#9IN~dak&r7AX?KLOh4ch{lE(3 ge_+5$Y?ctZ#AqMG$Ou$`o%{$E|AIrdND1f;03%@}R{#J2 delta 149 zcmZ3fu~LI~IWI340}wbL>PrjW$jijf$gx>~{~D8#JgfW-ak&r7AX?KLOh4ch{lE(3 ge_+5$Y?ctZ#AqMO$Ou$`o%{$E|AIrdND1f;03^gDWB>pF diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/logging.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/logging.cpython-311.pyc index 2310aea5cd86f2c3f8c0d96e5bbdbe1af60f39f5..1d6e6ea117744327ce9d2c3595f0dd9507668310 100644 GIT binary patch delta 19 ZcmX?7c%+bPIWI340}!~L+{m@d0sufM1^WO1 delta 19 ZcmX?7c%+bPIWI340}wbL+Q_xb0suey1@Zs@ diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/markup.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/markup.cpython-311.pyc index d9ec2902c737956033a266fa4b5cc394d9a0094b..d24b5224c82987a64053785deb72f15e9fa080a5 100644 GIT binary patch delta 908 zcmY+C?@JSL9LMjw-QDKxhfAAm>(0JTFP)jG^&mvjD3S0NO_Th^nC--qc{jdymdVB> zh!QDAUjpetNDmU~Nipbu@KGA0WJdU~hZhm~u>I!^@5rqj6v;A`NE7#e#Ne__id`pZ6HJ!e z7+;)ppMbNdhq%@qb8|5#aubQ#3CeCoOBwf7a|z!OT7@gb)kUs>@TM@(?eaa&Kg<`* z1D9BGi53GmX=iFT@jCH->Ok%*$$hr#ur|2OZszvg;&E|L*mrWnq{GePEB|5*IKo^g z*I}3s(n>FEyRE6ZHfxxu15Qxae5@BvE-BECLsN&VhJx2ZBY9Xo%8I_MChjGXn$%3# zW>@MNlXOX@N$q%5LOTyu^E#kH_E8Xwn#!6Pg*s7oLbMa!P!^M`Y15#?#&k{T6a<0J ziYHY=F?wwcA^sYA1V)SV;V1xcyb+lJ&+$>@7Z|~x&RhmVm=!Ocogqu2I*K3#eVNEZ zPSk-=S3 z=-hQG=P0fbl!Z(>scH$j8=9uxIK>dwB*Sk%)GV0>nV0_6u-$?aH#>*Sq#CUx7Ko!-(#O-an#8(e2wM$7q)XM=)qg9 zLn}D|0v1DQS5k582^8uJN+DA6h!$rj@QgQLxoqiXPK( delta 579 zcmXw#L1+^}6o%)yn@O^}NfuWmiP6CUf=p&iEcz98WHQ_ z$LI4j`#$<32s8L6SXHMb9J}VXbl4OX%X0@bni$MWr@~V zYTRqpmzyigY({1)5+&SByR<504aYL$R!_(UvE3b&kl}ER{66MA%uG=6%6GY1+N#VoOPIl}0Hi`&cV+ Sli50=IWI340}!~L+{ooB3jjG{1rq=O delta 19 ZcmX?ab>50=IWI340}wbL+Q{W93jjGY1quKF diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/pager.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/pager.cpython-311.pyc index 9a1a88a37c86e146526567c9287545a6774bc185..349a8c28ecbeab8c2a5cfa06491ff4715fa898c0 100644 GIT binary patch delta 19 ZcmcaAcvX;VIWI340}!~L+{ksB0{}I@1wH@( delta 19 ZcmcaAcvX;VIWI340}wbL+Q@a90{}IU1vLNw diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/palette.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/palette.cpython-311.pyc index 361c04e45e5769aaeed7b7ed55cdcae2337240d0..ca28d0ac8df769d2c7e6262e124d6409fde08a34 100644 GIT binary patch delta 19 ZcmaE*_ezgzIWI340}!~L+{l$64gfpG1x5e> delta 19 ZcmaE*_ezgzIWI340}wbL+Q^k44gfos1w8-& diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/panel.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/panel.cpython-311.pyc index b4bf0f7b1f9e2412de8984c86ca5683839ba2f9e..8254d70d6fee68f5c792fd2de616f9ff616b876a 100644 GIT binary patch delta 530 zcmZvWF=!M)6o%jIBzKqHo!Q;n^KN(V&fO(@kuye6QlwQ-L2Se_WtIa`EKH{n1uXxV7HqT>EZ$+T5yW|llEMe?=l|xt`FZcxo|R%-2pdeDcyn*` z;kkHcv5ERIXBBYFqG=6SfRN3x>7X2`;THUIhR$+vF&$p*wWS0cN(+}jpVi)vFf5&21^(egWvWNP6dXuv|`pW#{ z8uRtw;0wlH>CcNj#&Y%ZQ2%;XRD;DTNiof5P0C;S)GBb6pawF)IyoEsXxx~1IXZ+c zv~v{XB!u1Z%A{GKN9aRbU_h=(gXPV`7!tL>k8vNlHgq!Vkc-YzD8G9RW5NW2cpPpD z>=N~$IgfpE`=J&6IWPk|z?|OxojT=E3vR8VMXx8Be!Dc}N6*c$A;SOl_L=GL$?o3y JMRnlF_Al+4izNU6 delta 481 zcmZurJ4*vW5T3nDV(z@XTplKu7a9|Vs0kV@Qi+dNOf8n4ieROMl_)4^AzG}Uf_35x zM7Gq*%0?>-!N#93K|4X*Q6d%&%*XfGZ<#Caah5kYH$lzB-QN7vHGk09t$5My{Q)m^ zVu(w9+KA6tp6kK9E4zIkL1u`WnG#hVO82VTtWIS$hFV)K>9;|##5+xoU21g;;KCBe ze4LrBBB$bVPQe)zEs?RS201J0DTqb8H#nxq24J^1v8xM%Tksky zpr1ql>@cf={6wwv)6VoTB{W0X`3oFsM- zi$kId6U1ElQ{SzuVUlDDBKe;~GGK-=OWyBEO&tQ^tr^tF9g(GSQLof|tcdVG?o2kn MllQ;5Cw7J!UtYU+xBvhE diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/pretty.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/pretty.cpython-311.pyc index 2da929342fb032284c80136479ffd103fb13571f..e38405da626fb1b0206276125f38d9557e5a7e41 100644 GIT binary patch delta 1385 zcmZuw4NMeA6rQ)cw|BR2{0K+SS`;|ouqY9zQqBXh6hT`7`H5Z&5pnOVh7;U7e&kP! zVAcdG_SsZTC@l$E#YXMav^F-?8WWqQElsYCl~S>^F-Bw7#wMg`YG*k~f702_H}89I z=I!_1%zkl$o0#A%CoC3;uu=5+YhKeK%Y69xoMQ=RXp$2=aVYT>c#7K$O;qBSasM^w(iMlv_>@bFALS)Is zOqs7Fb`pr1^AeIwlqkTjZS$ktv(Z-4#=A)?EDodhZLf=TU{NK2A8#e}!W4QF`lr3;7ch43Oy+YioLU?_%3i|s&df33=CCSrEt zKyq)v%x~Ew+^P{UIR1v~Po@s={gLYIqwy>@Gc)6lW+^|6SnVR0U2)IF@t;|NAx%u_ zFhL6rEo}u8wPvu@EhuKyfrD<#isfM=b}sK?uHTn$f^}HA;>WNyUD<9O+R>Hs6m+0F zCk-Cbo}3jN)Zm5OX^?TqISkt|Z>1j-T;X_er3^kybk*Yzj2(2Xhen)qwL%kC=hch5 zfaUrWBlFYnm%L<9P|B}oZT02L5djwR>u0u?j4w#XLoNr3t6qR+TCu7bpo3m3xFRrd z{Y6XR4f=6Wwl4mDNd=7I>b29%PFa@;7wN`zH+lFDb4qtI*YVO#a0wrk-d*&MLiB1* z>F})%4|V87b9p=~&QV?qeYCH1a?Ef`ak0=H>y6;soKXR5Q|9-Xc( z(Pb=gx3Q*-x?4H0VtkE%@&A49Pd!(%fqpF_~>oxe`Ur9-tUBGCN(jSO>QUEeRSwOQ#|hYKBl;Bw>-7 zF=U%atW7hAY>7nAKN54;qJ@Qc_#C%{cm#>E9pU@Cw8#*TBGFbYI%LlyqNK&ggh)uh yV;yr-9ew{qy1_mrnD-W`scPzA?Aujm>&KcLRb?Pm5{oTBES-2wT?1XzAnh_JENZtJ&-EBpM~SoCt>F~AjLH6Ob%g95rTbQ*$ePydgdP5@OL6Ginj{6QAUcdLAXDIb@q_ zK9?CrH^#rC(l6^etnTI`U0(NLhn-&DydS`gLQ()$@Kn+X#`VdG(2M5eDy561E~77b z0Q&LoWV1=#VRN*$*j&yoKC!NU}-BjaiP?L*Gj{1>vlJ|>Brl9 z0Q%_q9p5OJ*VXcDI8VbW@^~+0RkbjSSapwa&z>Ckiq7o0E5c1Yz0b}EN*Mt?SX1c*V$L09Jgm3zWBi{s$u@H+<|>Y8kDoAx$+CPD(uZh1=y zNAXH~85hg#h5VOb}?^G`rLRmZ$9nY==m*6Ips^Hip5P8OUBAaqL3LU6FPD7hKe<9AGW~D z^oQYjB{a|>yrj^&xit=hbjN5Bz%=^ClK=H<%#5YO6fTZEj{Q%k&yI8LJri7}n)kOT zaM#2%+{Irfvb0`)*&J3`W(*cw$Yk~pT^I*u;>m|6!H*{WLSa&(CDsu9nMKeZsgPLrmy Ll!7dwW6t&uzT|{V diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/progress.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/progress.cpython-311.pyc index 510ed4287a81dc8362a787df0775595dfe590005..6a22ecbca33e9813c5ff97417bddb698822c6964 100644 GIT binary patch delta 926 zcmZvaYe-Z<6vyv>cJHpPt?sVws*5T1HjAZ*456neQWSluK(lvQnQm-lv1rqg zg`Nb9iz)SS=+Yn9x!sww<3L;hZ}ZGzi@^sx>ygD%^AaPr)`iw=xEfU()iGtEZ_2_a zri2btg3pvdMR{v=u+gjhb_O3c6m&B5(TTzu919Z-vY^OIYlJMSMkh?0DeF}V5KNJB zph^b85+etxG)XX9Wur>Lf-Sl%%V(V}hp5&hgvXTS`fM{~vuZ7ZHBt^$DNHZ~%T|@t zHvfxmEI5bgRFDQ5x^w0YgOMtWoWKZ$o=;(j=V`?oF^i<)7r+8uQj&>zG+F`;QkpJ) z23GPfmwJ#$ZRJG_8!4mWrUu){R(TFsN7Ys33@3S#_ashGyVnMsr{0=EE$;E`x=(n> z)9WknnE$LFR>m^euny?vsg3v1OQxo+z70PXgyW0cLX$8TRuDm#3wj`E+>T!Y7mgmW$+VHhOhr86+*9v^* zNBR$Al;nPI0D`G($gM#-g?`(`u!r2=ujz3_iU(SBxFNmOLln^?eV7DgC_kja5KIUA zB}xq@D1*^Tt!9L1V39h*Pz}VC9<|{k0;Rp-Cs delta 897 zcmZvaYeg@Ule3j`5Ged&f+28Bu(StxPlo z3C^*eTIw(9;cV_OaUakHIQ7F(d@ z{^B`?M0Dv2H{=xLuP;p0@&4jz++MOA**w2wUi8MAB!5z;$#vW03YlDVrDUlVW650F zA>bZ8DGLkeqhR@I?6Qb@nJLm^87qsb(X#jiS*KDYGuh-QmGmseA&*jNG&5UdgG$lN zI=*^y$l{cZsx`4Oj_Pe8>r~mS+8AcB$+0TMF@3abQAs`Kf6@L*CR1<4C=DWLV1KWG zXu4Zf0DPvjLm2{+c!g&*66vMqF))j_9odMPlMqK3rf9^4ZNmWsuh%`^k5K!^etE;K%^5b2gF2WCre-ns=k=h5{8my+wPq_j%QN!m(9d=0TfEF!+ zk}VRVh)0sc0OkE(rOQT4fxxs(7y~abU7Bsf zpokR7=|Gl%RZ`(ZxCGdxy2`QyHk#~s#BirUp3gygC+K_x%X~qWcbIIb^%wvft0_1D delta 148 zcmbOdHYJRAIWI340}wbL>PvgNk#~s#Bgf`V3gygX;b0J}_V>C+K_x%X~qWcbaUd^%wvg$|*(w diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/prompt.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/prompt.cpython-311.pyc index 93643c58c9d63c0dd2c60e6b93b5119524e9d21c..15b991e2e1226ae246c847472e396dc973f40e80 100644 GIT binary patch delta 356 zcmeBbV4Tpv$h(}Emx}=iTu=6;X>8<;U}Th<_)d~vnu)=kAw{HxAw@J*G*t#DBrBUL zmm-$U1X5gdC50hHJV!oPAxeRfAysyP;^d9yB9m`0N;5)O98992N~uaIOxdhp_3S{l zY&Ij9&6vl-#E`0xBDW04Ukw%mi8C_v7=Xp)Q!j@#AOvylv9;wGhvztH;;o^l2a9Iw|c7TWG!ZCMup98%xM;kYLnMm z_cE4GHnYj+ie+YC_`uA_$arJ&K^x7<2W*5kzp}|@WC^_@q&zvo&X4iN=H+(bj6CKH OEK(PkC5t41egXhK6;2QU delta 336 zcmbQxz}VHm$h(}Emx}=ioDcP-sc+eVBDW04Ukw%mi8C_v7=Xp)Qx#`3%w!j@#AW4Efa+#5VVVdxkAqo~Qw40ddaBA~EoNy(`OR+3X%>vClh<1J sPPVtnW{laq+Gaf?bMO@X$#Hgmj1M-iwF_tDv1DM8y1*=1Bnfms06k+!5dZ)H diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/protocol.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/protocol.cpython-311.pyc index f6ee51ff28bb3327a984c95630029f1b91370a56..9d2816834b0adc3a97e040f1bac9ee176eef4852 100644 GIT binary patch delta 19 ZcmX>ga6o`-IWI340}!~L+{k6d0RS<71bqMi delta 19 ZcmX>ga6o`-IWI340}wbL+Q?>j$1d0Fv delta 19 ZcmZ3?x|o$~IWI340}wbL+Q>DN2>>jH1c3km diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/repr.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/repr.cpython-311.pyc index 6cde74dd1618b2dd955c124f252b0cdd76461a11..66ee78534e50074d93f2a213a1cc41924506440a 100644 GIT binary patch delta 108 zcmca*ea)I{IWI340}!~L+{o3&$9QV;M7{#X_Q_2AY9A@HjR$)HOBkU~Cd{~~Q~}g&dbZi00gclH*&EG0st(g1Q!4R delta 19 ZcmeBI>Q~}g&dbZi00hp5Hgd5F0st&`1P%ZI diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/screen.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/screen.cpython-311.pyc index b3183cfe559860de89f962b5a8d46d391191ffa9..938eee3c6d2a54e49fd45678aa14637fbba68a92 100644 GIT binary patch delta 19 ZcmaDR`b?B-IWI340}!~L+{kr@3jjFJ1$zJh delta 19 ZcmaDR`b?B-IWI340}wbL+Q@Z>3jjEv1#$oY diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/segment.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/segment.cpython-311.pyc index 144a1867857c92a0ec2d75200c5e73a58a5453e2..d1322982a03d76d9e0023698cd596e2f1d4692cb 100644 GIT binary patch delta 369 zcmZqq&e-yuk#{*SFBbz4xSs4w+qRL{P?C{tv%O?F3*(f{+hr9Q8CPw-DL0*&@#yA4 zB`Ze8QvM?^5oaj}u*~VRk zneo8pM6ch>jCVK3`b}hJ{ImIe-~lE^@y#1T_?Q?qHt!EhVq!GitQ6_O%ILj0JvM?^0oaj}u*~VRk znepJ}M6ch>jQ2Lj`b}hJ{JZ&m-~lE^iOm~A_?Q?qH}4NiVq!GgtQ6_O%ILE>J zIXF9kk#YXyEjh0kCvBde%gD^QX7j>=WJbpAlUa+N0t4Z7Q7@aNKPRKy2L|k9N7hHM Y%oi{Tw1tVcMfw91SaHhcjg^-f0dZJ=CjbBd diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/spinner.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/spinner.cpython-311.pyc index 7444d1dddf2269cfd190c88b6546b94d0c6830b7..f1225da9ae61af9e8141e0f647d6c941570787bd 100644 GIT binary patch delta 19 Zcmexh`oWZIIWI340}!~L+{pDz3IINv1?d0) delta 19 Zcmexh`oWZIIWI340}wbL+Q{`x3IINA1>gVx diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/status.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/status.cpython-311.pyc index 4a70ee3288dfa457e9ac807e4306370ab96a6e89..c54025d033d3e8330b6e2671ede1a3d3947c013c 100644 GIT binary patch delta 35 pcmexn^38;IIWI340}!~L>`U|5$a_tK@y6yS62**+x|1WMPz$7$a_tK@xkUN62**+`jaE1>k61c?9u delta 19 ZcmbO(JYAS;IWI340}wbL+Q`+*2>>ji1b_el diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/syntax.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/syntax.cpython-311.pyc index 685c1bf12a32d3b72fb0e8cbea424f749fa725c0..8c1ab2c4247479123fd05cd74535d14455318ce5 100644 GIT binary patch delta 1964 zcmZuxeN0nV6o2=%eYC~$Q7Kq5;i(`L1u8}aoot$o$%j$oV~$N(<-V2@XuJCgMMnGz zVT{EYJvcS|BXe_6H;sE{f4IbCZhzpMkvNyJnlKl2(SZ&#&E|}5_dNW}cANh0z32SS z@0@$?d+*>`abQ@C`^09m3VghL`h73-9gEwaDGEkS%Umdu#W0q&QC6O#CdK9zX=b2(< zUL(!r%uHQ3p6llQM|U>OSF+%rZ09C7kIl9SPkwX>UBGQFWY7X7hbzwExeK{%?o+m0 zCC~Y&Oo96sa(_N8QquLBjI@~V-PER7d3>T0r&zt>Q+y*`#QpQA#aJ!4O0)sjvUG9~ zMwj0r1cu9!HWhH`-9nf=&LB`iMQZ30njhOfH6AeXX7T^z;7X>>#Y^Q?8+@%wAgs!j zN{7Paa8Pbj71{5Vg8@FNav&I%)sWKY_xcqo2bt^-w0m0oG%solD;?p|8us-juILh( zolk5K;dKrwW|mnU$Eb}eUQb&~xS<7ebS71A2!uTydCyo+aK7r|?9IX*Nl2J6GQ~cU zcN z`h2q@mLxuum~X>#>SN3FE)xv4CQH=9v)ZA#GClsW9&>aF`y7xMaA==Zo)XD#T4?1W zk(`6WRej_F6t1o&e`tNHj}S5n#WhQb4c@M4AjxpCX0gal!_?YhG7KwfD>J_1x!4fG zF9@Ru_}sIf5iTKIfRnX_(l^+_EAV%1t9dxVy@y^%b8Ei39}MJISW;g_oZ9yKPLcc$ z*0n0h(l)LgCcK)J4FjZ58*At>kgLEN7ux?s!9yHeCRU5<2k>QM3t6gV)A@#Jm$@Zs zZ1D#aRpd)~@`BkFP<{D?!hT;3xetH&=A=Bp&=_73JAol4=Jz#)*%?^WR72Ki+nbD{ zG)aNI&84JSyVP7|edQdd*05rZF2XiooUxGwLwpm@mH4C!oiA}}adhe#fS8X}`bmMK#)cYuEYY4GmqoS$}jX|ogk1=Qr(%XA&HXal;si78s znB9fr?F)$ntte-U zFi$9?&<4G0EE!xKKH`8K9Vw(uJJ?~A$dGnq<3}R74Aom|MY918ZCS=|=Ejx<9%;c2}LF?91avhFuok{L#KW;5Gn6Y*I#(sj#9=Fqt70lzH;_EK+p}&Vr zhCq*#IH9+vYxYeHkeGg^9KN3H?HpWHA>^aK0CL_ry8blo=Oc_E;Ma!jK)AsnYVx)O zJz=IlH`rdLt4UZwB7!cNi;fiB;>*e02oBs{$CV6)y)(#8ZB4J=kewk&aT8*U$-1X) zLg3RAxMkq3?lrn|Vw!g9y?Bw7Yv;GkGT85OnW&-FAK)!2N8MV8*->XL!zDtV=G&nX z;(?1hz0)aL6$B55PBAyq8IzkE@zZb}N>J`#qBG z_rTHq^aL-8>+uhbqy5RG2=4SRC-G3SYd!J7;I6dTQcjB+)D0?Ip?$mS3?UETgWXm9 zxw^JHgRBDEo-bVYu!xli6k#*MYE;)RU>j}$p$x|NDAIcL#KWt5OHzwaTT=BeEjz|3 tQB#Qd17YTaqkE^50qyMGadW|P3(1)f{vUhaxTSk;Kkcv6#y&i0_!qPe8+`x( delta 1760 zcmZuvZA_C_6z+ZBwzN>BR`9zDN`Zm}6cPNGIyGo!*+c{roUN7n7CJuK+;(drL~)P- zW^U0VY{*PlG%jOWvpFJm;L} z9L~K%BhsfoNYg$^O-iQ<|wDW}8u3XB)> zGG&1_lb)BOUj&Dp^HNr#Rm{!RI_FF3H_i2UVHh^SxHlahY;~mAUSxySoek^Vxv5jQNIEQVFM@+^3!KOAjN8f561DE!gk|YX z@-uGgM(JVeb6G0{I<4@`ZMAji-k3hw;eZ`G+b|`g#5|QB(jAvhFgDP)jKv{b^D>j+s~RuMfQ;JJ zP*b~teGl)}x*gx4TwEVfViEBhnj%g>wSfOe!x8%T46!BZQr|l=y9MWYne8#@oJMdOL=D+bfhofniR+sKtx8xzGc!}vQqE2Iwy}uS!M(;EYy#E>3T8beT91Q>3shndfriG2 zxB{Jl9qd(gG@zG^i4?feRKfPBIn7nco3CN&4zUu^$wV8~>FY%>gpLK3@JAE8LUCE6 z;>Jcr6Q<=LM>S$PTzqS7$}H+lw6H=_G=JVLGKUF1LWrANd@*k{z$1-f0^HHr>@FzL z-qd8QiW|bA=0HR|fr)6@e3=-t()wnLB76}=9H(mBKsX|scy1jBQ%;6D3<{UEWYI(2C{SY6YX=B!Zu5q9p2(8Wp}!Na0>>yJ7|e+ZyKBFw$bml>f`+#9KN$}|H4S1&|U8U>^1iH#?w@ICr z;!H|h<`}4573>a7bS+}zs=d2HHqp}Yu1BG%r?|vLGZi9)^+;#pNnEg<=18BMBP4?L zN;vGT4{{|9e(dSUxlbZSq3t3c?ZizLkX1!cMDe8%>OH%=g#5b%%Lon={DBZR_?v^i zh|nJ31hJYB?O#kI(9~QMNGI1sRxtrBN!%gJ4hQ(a)_~@>H^?Kkq+D7y5lhE$)G=frZw364&aVliLPnvQlUm*upIE#lYTt zjtS15cv3K281msO{gUQ4g_?a4e^9iDjTny0;kK}NMP2j3HO8KTX|M_(U)^9ftAzc7 zUpxPz>0Tq?1f7~oZMBsjA{PiMz;jG7dMRRotH;*PEhTMZ;-QIim=ZUH1ioIuA#2Fa iK2+BYJuofXXJYw}bpMaNua9ey$5Z1Q)ZHg9%KreOUGK&K diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/table.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/table.cpython-311.pyc index a35571c654baf2673846942028a129f3186fe2ce..ccd1babeadc7c51c17fd69ccb8d4a1d5bcd30419 100644 GIT binary patch delta 849 zcmZvYSxA&o6vxk*ebjH9eRUbPnQC`%Ng^0P%;R0v+gL&@2R9Hah$8e*j?MgR z?Is@OXX=)*gYT{1#1QFhc#hc3+rvxPOIE`z8XO?r<|Y*qa-ppi@jiLk9+%-8a-#FK z0>2S|*A$vo5#ao`6kA&fNWc}KD)PR&UX97Tqwf>y`0c(mH1hBI6KE!j5kI1xd>v3A z`pCxVAYy>`olRgRZx~#`TJmx5F`|-0hfs|j}7 zYJ&{Vknpt@naNW^LCG0+!QB zLsss-LTn|s?md;`7t%EILOT{xdMNyfb)!vCP0NL3(U?n>tf~UNUC@ZBSyatb14gId z6Ad|3%QT5~Tj&pm)$b zMjo)F3&*A-VtT1)E~8#n^MNf>7!j@cG+)v&TCnGZtX;IHex}7>%@87@#Yan+mV(_q ztrcwrw2Wy0>|R>Vr~;h%bRVNiHrswiRgk2kK}LHE{!KM9P#L6Mdc14o=4_q3$gk9` z+1yml?!xNbdtGazO35kw8(mN4`xUrMA`4Mvpe6-f6#k#r4}ah7Z2sL3lkCMw`7a@F B5}*J8 delta 849 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/theme.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/theme.cpython-311.pyc index 21fe04d7ca035ec0b9219eb8b733d3a6cc511fa6..4d5363b427deec7826b43234c94ec5858c74f596 100644 GIT binary patch delta 19 ZcmbPXIm41`IWI340}!~L+{o1@0{}7=1nU3* delta 19 ZcmbPXIm41`IWI340}wbL+Q`)>0{}7R1mXYy diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/themes.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/themes.cpython-311.pyc index a87544cee66fac0a04db2fe1150e84be077c1d97..34454bc6375928e3b8ce36a0257980e593e82d32 100644 GIT binary patch delta 19 Zcmey&^qGlkIWI340}!~L+{l&52mm)O1oHp@ delta 19 Zcmey&^qGlkIWI340}wbL+Q^m32mm(!1nK|) diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/traceback.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/rich/__pycache__/traceback.cpython-311.pyc index 59956abf175df29e16729a268857b3837b9ad5ab..94c94139de9cd51bbcce5024f78dee33b82d1a7d 100644 GIT binary patch delta 278 zcmbQ<$27fJqc$1!l<`ldIdZ4cS@EJ}{sXLJX{24X%yuE$$6q_`#8pfkg_aqbLAqIRKcEQQ-gp delta 278 zcmbQ<$27fpONwI=AK$xM&4IU3=G8)K$kQyd|=sptuBMzwuYS%s0BOu5iI@%S+Jqc$1!l`Obpk$0^GW9;VL5=M-SZJXaoE@xt7+dNI?Jv-xy&21{o z%*JtytkO5c6+SS78QRtm#sg0A53C@O4-6Qj!{$Beg=}`EOpLl87_gHaHXp$Px%0k$0^GW8CK55=M-S?VI08E@xuo*gQ?3d^OpLl87_gHaHXp$H@Q5kt)!^0N!XfE&u=k diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py b/myenv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py index 36286df..608ae3a 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py @@ -4,6 +4,7 @@ (0, 0, 0), (1, 31, -1), (127, 159, -1), + (173, 173, 0), (768, 879, 0), (1155, 1161, 0), (1425, 1469, 0), @@ -11,13 +12,16 @@ (1473, 1474, 0), (1476, 1477, 0), (1479, 1479, 0), + (1536, 1541, 0), (1552, 1562, 0), + (1564, 1564, 0), (1611, 1631, 0), (1648, 1648, 0), - (1750, 1756, 0), + (1750, 1757, 0), (1759, 1764, 0), (1767, 1768, 0), (1770, 1773, 0), + (1807, 1807, 0), (1809, 1809, 0), (1840, 1866, 0), (1958, 1968, 0), @@ -28,149 +32,137 @@ (2085, 2087, 0), (2089, 2093, 0), (2137, 2139, 0), - (2259, 2273, 0), - (2275, 2306, 0), - (2362, 2362, 0), - (2364, 2364, 0), - (2369, 2376, 0), - (2381, 2381, 0), + (2192, 2193, 0), + (2200, 2207, 0), + (2250, 2307, 0), + (2362, 2364, 0), + (2366, 2383, 0), (2385, 2391, 0), (2402, 2403, 0), - (2433, 2433, 0), + (2433, 2435, 0), (2492, 2492, 0), - (2497, 2500, 0), - (2509, 2509, 0), + (2494, 2500, 0), + (2503, 2504, 0), + (2507, 2509, 0), + (2519, 2519, 0), (2530, 2531, 0), (2558, 2558, 0), - (2561, 2562, 0), + (2561, 2563, 0), (2620, 2620, 0), - (2625, 2626, 0), + (2622, 2626, 0), (2631, 2632, 0), (2635, 2637, 0), (2641, 2641, 0), (2672, 2673, 0), (2677, 2677, 0), - (2689, 2690, 0), + (2689, 2691, 0), (2748, 2748, 0), - (2753, 2757, 0), - (2759, 2760, 0), - (2765, 2765, 0), + (2750, 2757, 0), + (2759, 2761, 0), + (2763, 2765, 0), (2786, 2787, 0), (2810, 2815, 0), - (2817, 2817, 0), + (2817, 2819, 0), (2876, 2876, 0), - (2879, 2879, 0), - (2881, 2884, 0), - (2893, 2893, 0), - (2901, 2902, 0), + (2878, 2884, 0), + (2887, 2888, 0), + (2891, 2893, 0), + (2901, 2903, 0), (2914, 2915, 0), (2946, 2946, 0), - (3008, 3008, 0), - (3021, 3021, 0), - (3072, 3072, 0), - (3076, 3076, 0), - (3134, 3136, 0), + (3006, 3010, 0), + (3014, 3016, 0), + (3018, 3021, 0), + (3031, 3031, 0), + (3072, 3076, 0), + (3132, 3132, 0), + (3134, 3140, 0), (3142, 3144, 0), (3146, 3149, 0), (3157, 3158, 0), (3170, 3171, 0), - (3201, 3201, 0), + (3201, 3203, 0), (3260, 3260, 0), - (3263, 3263, 0), - (3270, 3270, 0), - (3276, 3277, 0), + (3262, 3268, 0), + (3270, 3272, 0), + (3274, 3277, 0), + (3285, 3286, 0), (3298, 3299, 0), - (3328, 3329, 0), + (3315, 3315, 0), + (3328, 3331, 0), (3387, 3388, 0), - (3393, 3396, 0), - (3405, 3405, 0), + (3390, 3396, 0), + (3398, 3400, 0), + (3402, 3405, 0), + (3415, 3415, 0), (3426, 3427, 0), - (3457, 3457, 0), + (3457, 3459, 0), (3530, 3530, 0), - (3538, 3540, 0), + (3535, 3540, 0), (3542, 3542, 0), + (3544, 3551, 0), + (3570, 3571, 0), (3633, 3633, 0), (3636, 3642, 0), (3655, 3662, 0), (3761, 3761, 0), (3764, 3772, 0), - (3784, 3789, 0), + (3784, 3790, 0), (3864, 3865, 0), (3893, 3893, 0), (3895, 3895, 0), (3897, 3897, 0), - (3953, 3966, 0), - (3968, 3972, 0), + (3902, 3903, 0), + (3953, 3972, 0), (3974, 3975, 0), (3981, 3991, 0), (3993, 4028, 0), (4038, 4038, 0), - (4141, 4144, 0), - (4146, 4151, 0), - (4153, 4154, 0), - (4157, 4158, 0), - (4184, 4185, 0), + (4139, 4158, 0), + (4182, 4185, 0), (4190, 4192, 0), + (4194, 4196, 0), + (4199, 4205, 0), (4209, 4212, 0), - (4226, 4226, 0), - (4229, 4230, 0), - (4237, 4237, 0), - (4253, 4253, 0), + (4226, 4237, 0), + (4239, 4239, 0), + (4250, 4253, 0), (4352, 4447, 2), + (4448, 4607, 0), (4957, 4959, 0), - (5906, 5908, 0), + (5906, 5909, 0), (5938, 5940, 0), (5970, 5971, 0), (6002, 6003, 0), - (6068, 6069, 0), - (6071, 6077, 0), - (6086, 6086, 0), - (6089, 6099, 0), + (6068, 6099, 0), (6109, 6109, 0), - (6155, 6157, 0), + (6155, 6159, 0), (6277, 6278, 0), (6313, 6313, 0), - (6432, 6434, 0), - (6439, 6440, 0), - (6450, 6450, 0), - (6457, 6459, 0), - (6679, 6680, 0), - (6683, 6683, 0), - (6742, 6742, 0), - (6744, 6750, 0), - (6752, 6752, 0), - (6754, 6754, 0), - (6757, 6764, 0), - (6771, 6780, 0), + (6432, 6443, 0), + (6448, 6459, 0), + (6679, 6683, 0), + (6741, 6750, 0), + (6752, 6780, 0), (6783, 6783, 0), - (6832, 6848, 0), - (6912, 6915, 0), - (6964, 6964, 0), - (6966, 6970, 0), - (6972, 6972, 0), - (6978, 6978, 0), + (6832, 6862, 0), + (6912, 6916, 0), + (6964, 6980, 0), (7019, 7027, 0), - (7040, 7041, 0), - (7074, 7077, 0), - (7080, 7081, 0), - (7083, 7085, 0), - (7142, 7142, 0), - (7144, 7145, 0), - (7149, 7149, 0), - (7151, 7153, 0), - (7212, 7219, 0), - (7222, 7223, 0), + (7040, 7042, 0), + (7073, 7085, 0), + (7142, 7155, 0), + (7204, 7223, 0), (7376, 7378, 0), - (7380, 7392, 0), - (7394, 7400, 0), + (7380, 7400, 0), (7405, 7405, 0), (7412, 7412, 0), - (7416, 7417, 0), - (7616, 7673, 0), - (7675, 7679, 0), + (7415, 7417, 0), + (7616, 7679, 0), (8203, 8207, 0), (8232, 8238, 0), - (8288, 8291, 0), + (8288, 8292, 0), + (8294, 8303, 0), (8400, 8432, 0), (8986, 8987, 2), (9001, 9002, 2), @@ -212,17 +204,16 @@ (11904, 11929, 2), (11931, 12019, 2), (12032, 12245, 2), - (12272, 12283, 2), - (12288, 12329, 2), - (12330, 12333, 0), - (12334, 12350, 2), + (12272, 12329, 2), + (12330, 12335, 0), + (12336, 12350, 2), (12353, 12438, 2), (12441, 12442, 0), (12443, 12543, 2), (12549, 12591, 2), (12593, 12686, 2), (12688, 12771, 2), - (12784, 12830, 2), + (12783, 12830, 2), (12832, 12871, 2), (12880, 19903, 2), (19968, 42124, 2), @@ -234,36 +225,33 @@ (43010, 43010, 0), (43014, 43014, 0), (43019, 43019, 0), - (43045, 43046, 0), + (43043, 43047, 0), (43052, 43052, 0), - (43204, 43205, 0), + (43136, 43137, 0), + (43188, 43205, 0), (43232, 43249, 0), (43263, 43263, 0), (43302, 43309, 0), - (43335, 43345, 0), + (43335, 43347, 0), (43360, 43388, 2), - (43392, 43394, 0), - (43443, 43443, 0), - (43446, 43449, 0), - (43452, 43453, 0), + (43392, 43395, 0), + (43443, 43456, 0), (43493, 43493, 0), - (43561, 43566, 0), - (43569, 43570, 0), - (43573, 43574, 0), + (43561, 43574, 0), (43587, 43587, 0), - (43596, 43596, 0), - (43644, 43644, 0), + (43596, 43597, 0), + (43643, 43645, 0), (43696, 43696, 0), (43698, 43700, 0), (43703, 43704, 0), (43710, 43711, 0), (43713, 43713, 0), - (43756, 43757, 0), - (43766, 43766, 0), - (44005, 44005, 0), - (44008, 44008, 0), - (44013, 44013, 0), + (43755, 43759, 0), + (43765, 43766, 0), + (44003, 44010, 0), + (44012, 44013, 0), (44032, 55203, 2), + (55216, 55295, 0), (63744, 64255, 2), (64286, 64286, 0), (65024, 65039, 0), @@ -272,8 +260,10 @@ (65072, 65106, 2), (65108, 65126, 2), (65128, 65131, 2), + (65279, 65279, 0), (65281, 65376, 2), (65504, 65510, 2), + (65529, 65531, 0), (66045, 66045, 0), (66272, 66272, 0), (66422, 66426, 0), @@ -285,102 +275,108 @@ (68325, 68326, 0), (68900, 68903, 0), (69291, 69292, 0), + (69373, 69375, 0), (69446, 69456, 0), - (69633, 69633, 0), + (69506, 69509, 0), + (69632, 69634, 0), (69688, 69702, 0), - (69759, 69761, 0), - (69811, 69814, 0), - (69817, 69818, 0), + (69744, 69744, 0), + (69747, 69748, 0), + (69759, 69762, 0), + (69808, 69818, 0), + (69821, 69821, 0), + (69826, 69826, 0), + (69837, 69837, 0), (69888, 69890, 0), - (69927, 69931, 0), - (69933, 69940, 0), + (69927, 69940, 0), + (69957, 69958, 0), (70003, 70003, 0), - (70016, 70017, 0), - (70070, 70078, 0), + (70016, 70018, 0), + (70067, 70080, 0), (70089, 70092, 0), - (70095, 70095, 0), - (70191, 70193, 0), - (70196, 70196, 0), - (70198, 70199, 0), + (70094, 70095, 0), + (70188, 70199, 0), (70206, 70206, 0), - (70367, 70367, 0), - (70371, 70378, 0), - (70400, 70401, 0), + (70209, 70209, 0), + (70367, 70378, 0), + (70400, 70403, 0), (70459, 70460, 0), - (70464, 70464, 0), + (70462, 70468, 0), + (70471, 70472, 0), + (70475, 70477, 0), + (70487, 70487, 0), + (70498, 70499, 0), (70502, 70508, 0), (70512, 70516, 0), - (70712, 70719, 0), - (70722, 70724, 0), - (70726, 70726, 0), + (70709, 70726, 0), (70750, 70750, 0), - (70835, 70840, 0), - (70842, 70842, 0), - (70847, 70848, 0), - (70850, 70851, 0), - (71090, 71093, 0), - (71100, 71101, 0), - (71103, 71104, 0), + (70832, 70851, 0), + (71087, 71093, 0), + (71096, 71104, 0), (71132, 71133, 0), - (71219, 71226, 0), - (71229, 71229, 0), - (71231, 71232, 0), - (71339, 71339, 0), - (71341, 71341, 0), - (71344, 71349, 0), - (71351, 71351, 0), - (71453, 71455, 0), - (71458, 71461, 0), - (71463, 71467, 0), - (71727, 71735, 0), - (71737, 71738, 0), - (71995, 71996, 0), - (71998, 71998, 0), - (72003, 72003, 0), - (72148, 72151, 0), - (72154, 72155, 0), - (72160, 72160, 0), + (71216, 71232, 0), + (71339, 71351, 0), + (71453, 71467, 0), + (71724, 71738, 0), + (71984, 71989, 0), + (71991, 71992, 0), + (71995, 71998, 0), + (72000, 72000, 0), + (72002, 72003, 0), + (72145, 72151, 0), + (72154, 72160, 0), + (72164, 72164, 0), (72193, 72202, 0), - (72243, 72248, 0), + (72243, 72249, 0), (72251, 72254, 0), (72263, 72263, 0), - (72273, 72278, 0), - (72281, 72283, 0), - (72330, 72342, 0), - (72344, 72345, 0), - (72752, 72758, 0), - (72760, 72765, 0), - (72767, 72767, 0), + (72273, 72283, 0), + (72330, 72345, 0), + (72751, 72758, 0), + (72760, 72767, 0), (72850, 72871, 0), - (72874, 72880, 0), - (72882, 72883, 0), - (72885, 72886, 0), + (72873, 72886, 0), (73009, 73014, 0), (73018, 73018, 0), (73020, 73021, 0), (73023, 73029, 0), (73031, 73031, 0), + (73098, 73102, 0), (73104, 73105, 0), - (73109, 73109, 0), - (73111, 73111, 0), - (73459, 73460, 0), + (73107, 73111, 0), + (73459, 73462, 0), + (73472, 73473, 0), + (73475, 73475, 0), + (73524, 73530, 0), + (73534, 73538, 0), + (78896, 78912, 0), + (78919, 78933, 0), (92912, 92916, 0), (92976, 92982, 0), (94031, 94031, 0), + (94033, 94087, 0), (94095, 94098, 0), (94176, 94179, 2), (94180, 94180, 0), - (94192, 94193, 2), + (94192, 94193, 0), (94208, 100343, 2), (100352, 101589, 2), (101632, 101640, 2), - (110592, 110878, 2), + (110576, 110579, 2), + (110581, 110587, 2), + (110589, 110590, 2), + (110592, 110882, 2), + (110898, 110898, 2), (110928, 110930, 2), + (110933, 110933, 2), (110948, 110951, 2), (110960, 111355, 2), (113821, 113822, 0), - (119143, 119145, 0), - (119163, 119170, 0), + (113824, 113827, 0), + (118528, 118573, 0), + (118576, 118598, 0), + (119141, 119145, 0), + (119149, 119170, 0), (119173, 119179, 0), (119210, 119213, 0), (119362, 119364, 0), @@ -395,8 +391,11 @@ (122907, 122913, 0), (122915, 122916, 0), (122918, 122922, 0), + (123023, 123023, 0), (123184, 123190, 0), + (123566, 123566, 0), (123628, 123631, 0), + (124140, 124143, 0), (125136, 125142, 0), (125252, 125258, 0), (126980, 126980, 2), @@ -416,7 +415,9 @@ (127951, 127955, 2), (127968, 127984, 2), (127988, 127988, 2), - (127992, 128062, 2), + (127992, 127994, 2), + (127995, 127999, 0), + (128000, 128062, 2), (128064, 128064, 2), (128066, 128252, 2), (128255, 128317, 2), @@ -430,22 +431,24 @@ (128716, 128716, 2), (128720, 128722, 2), (128725, 128727, 2), + (128732, 128735, 2), (128747, 128748, 2), (128756, 128764, 2), (128992, 129003, 2), + (129008, 129008, 2), (129292, 129338, 2), (129340, 129349, 2), - (129351, 129400, 2), - (129402, 129483, 2), - (129485, 129535, 2), - (129648, 129652, 2), - (129656, 129658, 2), - (129664, 129670, 2), - (129680, 129704, 2), - (129712, 129718, 2), - (129728, 129730, 2), - (129744, 129750, 2), + (129351, 129535, 2), + (129648, 129660, 2), + (129664, 129672, 2), + (129680, 129725, 2), + (129727, 129733, 2), + (129742, 129755, 2), + (129760, 129768, 2), + (129776, 129784, 2), (131072, 196605, 2), (196608, 262141, 2), + (917505, 917505, 0), + (917536, 917631, 0), (917760, 917999, 0), ] diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/_export_format.py b/myenv/Lib/site-packages/pip/_vendor/rich/_export_format.py index 094d2dc..e7527e5 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/_export_format.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/_export_format.py @@ -1,5 +1,6 @@ CONSOLE_HTML_FORMAT = """\ + - -
{code}
+
{code}
""" diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/_ratio.py b/myenv/Lib/site-packages/pip/_vendor/rich/_ratio.py index e8a3a67..95267b0 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/_ratio.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/_ratio.py @@ -151,7 +151,6 @@ def ratio_distribute( @dataclass class E: - size: Optional[int] = None ratio: int = 1 minimum_size: int = 1 diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/_windows.py b/myenv/Lib/site-packages/pip/_vendor/rich/_windows.py index 10fc0d7..7520a9f 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/_windows.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/_windows.py @@ -30,7 +30,6 @@ class WindowsConsoleFeatures: ) except (AttributeError, ImportError, ValueError): - # Fallback if we can't load the Windows DLL def get_windows_console_features() -> WindowsConsoleFeatures: features = WindowsConsoleFeatures() diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/_wrap.py b/myenv/Lib/site-packages/pip/_vendor/rich/_wrap.py index c45f193..2e94ff6 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/_wrap.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/_wrap.py @@ -1,5 +1,7 @@ +from __future__ import annotations + import re -from typing import Iterable, List, Tuple +from typing import Iterable from ._loop import loop_last from .cells import cell_len, chop_cells @@ -7,7 +9,11 @@ re_word = re.compile(r"\s*\S+\s*") -def words(text: str) -> Iterable[Tuple[int, int, str]]: +def words(text: str) -> Iterable[tuple[int, int, str]]: + """Yields each word from the text as a tuple + containing (start_index, end_index, word). A "word" in this context may + include the actual word and any whitespace to the right. + """ position = 0 word_match = re_word.match(text, position) while word_match is not None: @@ -17,35 +23,59 @@ def words(text: str) -> Iterable[Tuple[int, int, str]]: word_match = re_word.match(text, end) -def divide_line(text: str, width: int, fold: bool = True) -> List[int]: - divides: List[int] = [] - append = divides.append - line_position = 0 +def divide_line(text: str, width: int, fold: bool = True) -> list[int]: + """Given a string of text, and a width (measured in cells), return a list + of cell offsets which the string should be split at in order for it to fit + within the given width. + + Args: + text: The text to examine. + width: The available cell width. + fold: If True, words longer than `width` will be folded onto a new line. + + Returns: + A list of indices to break the line at. + """ + break_positions: list[int] = [] # offsets to insert the breaks at + append = break_positions.append + cell_offset = 0 _cell_len = cell_len + for start, _end, word in words(text): word_length = _cell_len(word.rstrip()) - if line_position + word_length > width: + remaining_space = width - cell_offset + word_fits_remaining_space = remaining_space >= word_length + + if word_fits_remaining_space: + # Simplest case - the word fits within the remaining width for this line. + cell_offset += _cell_len(word) + else: + # Not enough space remaining for this word on the current line. if word_length > width: + # The word doesn't fit on any line, so we can't simply + # place it on the next line... if fold: - chopped_words = chop_cells(word, max_size=width, position=0) - for last, line in loop_last(chopped_words): + # Fold the word across multiple lines. + folded_word = chop_cells(word, width=width) + for last, line in loop_last(folded_word): if start: append(start) - if last: - line_position = _cell_len(line) + cell_offset = _cell_len(line) else: start += len(line) else: + # Folding isn't allowed, so crop the word. if start: append(start) - line_position = _cell_len(word) - elif line_position and start: + cell_offset = _cell_len(word) + elif cell_offset and start: + # The word doesn't fit within the remaining space on the current + # line, but it *can* fit on to the next (empty) line. append(start) - line_position = _cell_len(word) - else: - line_position += _cell_len(word) - return divides + cell_offset = _cell_len(word) + + return break_positions if __name__ == "__main__": # pragma: no cover @@ -53,4 +83,11 @@ def divide_line(text: str, width: int, fold: bool = True) -> List[int]: console = Console(width=10) console.print("12345 abcdefghijklmnopqrstuvwyxzABCDEFGHIJKLMNOPQRSTUVWXYZ 12345") - print(chop_cells("abcdefghijklmnopqrstuvwxyz", 10, position=2)) + print(chop_cells("abcdefghijklmnopqrstuvwxyz", 10)) + + console = Console(width=20) + console.rule() + console.print("TextualはPythonの高速アプリケーション開発フレームワークです") + + console.rule() + console.print("アプリケーションは1670万色を使用でき") diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/align.py b/myenv/Lib/site-packages/pip/_vendor/rich/align.py index c310b66..f7b734f 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/align.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/align.py @@ -27,7 +27,7 @@ class Align(JupyterMixin): renderable (RenderableType): A console renderable. align (AlignMethod): One of "left", "center", or "right"" style (StyleType, optional): An optional style to apply to the background. - vertical (Optional[VerticalAlginMethod], optional): Optional vertical align, one of "top", "middle", or "bottom". Defaults to None. + vertical (Optional[VerticalAlignMethod], optional): Optional vertical align, one of "top", "middle", or "bottom". Defaults to None. pad (bool, optional): Pad the right with spaces. Defaults to True. width (int, optional): Restrict contents to given width, or None to use default width. Defaults to None. height (int, optional): Set height of align renderable, or None to fit to contents. Defaults to None. diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/bar.py b/myenv/Lib/site-packages/pip/_vendor/rich/bar.py index ed86a55..022284b 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/bar.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/bar.py @@ -48,7 +48,6 @@ def __repr__(self) -> str: def __rich_console__( self, console: Console, options: ConsoleOptions ) -> RenderResult: - width = min( self.width if self.width is not None else options.max_width, options.max_width, diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/box.py b/myenv/Lib/site-packages/pip/_vendor/rich/box.py index 97d2a94..0511a9e 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/box.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/box.py @@ -188,260 +188,224 @@ def get_bottom(self, widths: Iterable[int]) -> str: return "".join(parts) +# fmt: off ASCII: Box = Box( - """\ -+--+ -| || -|-+| -| || -|-+| -|-+| -| || -+--+ -""", + "+--+\n" + "| ||\n" + "|-+|\n" + "| ||\n" + "|-+|\n" + "|-+|\n" + "| ||\n" + "+--+\n", ascii=True, ) ASCII2: Box = Box( - """\ -+-++ -| || -+-++ -| || -+-++ -+-++ -| || -+-++ -""", + "+-++\n" + "| ||\n" + "+-++\n" + "| ||\n" + "+-++\n" + "+-++\n" + "| ||\n" + "+-++\n", ascii=True, ) ASCII_DOUBLE_HEAD: Box = Box( - """\ -+-++ -| || -+=++ -| || -+-++ -+-++ -| || -+-++ -""", + "+-++\n" + "| ||\n" + "+=++\n" + "| ||\n" + "+-++\n" + "+-++\n" + "| ||\n" + "+-++\n", ascii=True, ) SQUARE: Box = Box( - """\ -┌─┬┐ -│ ││ -├─┼┤ -│ ││ -├─┼┤ -├─┼┤ -│ ││ -└─┴┘ -""" + "┌─┬┐\n" + "│ ││\n" + "├─┼┤\n" + "│ ││\n" + "├─┼┤\n" + "├─┼┤\n" + "│ ││\n" + "└─┴┘\n" ) SQUARE_DOUBLE_HEAD: Box = Box( - """\ -┌─┬┐ -│ ││ -╞═╪╡ -│ ││ -├─┼┤ -├─┼┤ -│ ││ -└─┴┘ -""" + "┌─┬┐\n" + "│ ││\n" + "╞═╪╡\n" + "│ ││\n" + "├─┼┤\n" + "├─┼┤\n" + "│ ││\n" + "└─┴┘\n" ) MINIMAL: Box = Box( - """\ - ╷ - │ -╶─┼╴ - │ -╶─┼╴ -╶─┼╴ - │ - ╵ -""" + " ╷ \n" + " │ \n" + "╶─┼╴\n" + " │ \n" + "╶─┼╴\n" + "╶─┼╴\n" + " │ \n" + " ╵ \n" ) MINIMAL_HEAVY_HEAD: Box = Box( - """\ - ╷ - │ -╺━┿╸ - │ -╶─┼╴ -╶─┼╴ - │ - ╵ -""" + " ╷ \n" + " │ \n" + "╺━┿╸\n" + " │ \n" + "╶─┼╴\n" + "╶─┼╴\n" + " │ \n" + " ╵ \n" ) MINIMAL_DOUBLE_HEAD: Box = Box( - """\ - ╷ - │ - ═╪ - │ - ─┼ - ─┼ - │ - ╵ -""" + " ╷ \n" + " │ \n" + " ═╪ \n" + " │ \n" + " ─┼ \n" + " ─┼ \n" + " │ \n" + " ╵ \n" ) SIMPLE: Box = Box( - """\ - - - ── - - - ── - - -""" + " \n" + " \n" + " ── \n" + " \n" + " \n" + " ── \n" + " \n" + " \n" ) SIMPLE_HEAD: Box = Box( - """\ - - - ── - - - - - -""" + " \n" + " \n" + " ── \n" + " \n" + " \n" + " \n" + " \n" + " \n" ) SIMPLE_HEAVY: Box = Box( - """\ - - - ━━ - - - ━━ - - -""" + " \n" + " \n" + " ━━ \n" + " \n" + " \n" + " ━━ \n" + " \n" + " \n" ) HORIZONTALS: Box = Box( - """\ - ── - - ── - - ── - ── - - ── -""" + " ── \n" + " \n" + " ── \n" + " \n" + " ── \n" + " ── \n" + " \n" + " ── \n" ) ROUNDED: Box = Box( - """\ -╭─┬╮ -│ ││ -├─┼┤ -│ ││ -├─┼┤ -├─┼┤ -│ ││ -╰─┴╯ -""" + "╭─┬╮\n" + "│ ││\n" + "├─┼┤\n" + "│ ││\n" + "├─┼┤\n" + "├─┼┤\n" + "│ ││\n" + "╰─┴╯\n" ) HEAVY: Box = Box( - """\ -┏━┳┓ -┃ ┃┃ -┣━╋┫ -┃ ┃┃ -┣━╋┫ -┣━╋┫ -┃ ┃┃ -┗━┻┛ -""" + "┏━┳┓\n" + "┃ ┃┃\n" + "┣━╋┫\n" + "┃ ┃┃\n" + "┣━╋┫\n" + "┣━╋┫\n" + "┃ ┃┃\n" + "┗━┻┛\n" ) HEAVY_EDGE: Box = Box( - """\ -┏━┯┓ -┃ │┃ -┠─┼┨ -┃ │┃ -┠─┼┨ -┠─┼┨ -┃ │┃ -┗━┷┛ -""" + "┏━┯┓\n" + "┃ │┃\n" + "┠─┼┨\n" + "┃ │┃\n" + "┠─┼┨\n" + "┠─┼┨\n" + "┃ │┃\n" + "┗━┷┛\n" ) HEAVY_HEAD: Box = Box( - """\ -┏━┳┓ -┃ ┃┃ -┡━╇┩ -│ ││ -├─┼┤ -├─┼┤ -│ ││ -└─┴┘ -""" + "┏━┳┓\n" + "┃ ┃┃\n" + "┡━╇┩\n" + "│ ││\n" + "├─┼┤\n" + "├─┼┤\n" + "│ ││\n" + "└─┴┘\n" ) DOUBLE: Box = Box( - """\ -╔═╦╗ -║ ║║ -╠═╬╣ -║ ║║ -╠═╬╣ -╠═╬╣ -║ ║║ -╚═╩╝ -""" + "╔═╦╗\n" + "║ ║║\n" + "╠═╬╣\n" + "║ ║║\n" + "╠═╬╣\n" + "╠═╬╣\n" + "║ ║║\n" + "╚═╩╝\n" ) DOUBLE_EDGE: Box = Box( - """\ -╔═╤╗ -║ │║ -╟─┼╢ -║ │║ -╟─┼╢ -╟─┼╢ -║ │║ -╚═╧╝ -""" + "╔═╤╗\n" + "║ │║\n" + "╟─┼╢\n" + "║ │║\n" + "╟─┼╢\n" + "╟─┼╢\n" + "║ │║\n" + "╚═╧╝\n" ) MARKDOWN: Box = Box( - """\ - -| || -|-|| -| || -|-|| -|-|| -| || - -""", + " \n" + "| ||\n" + "|-||\n" + "| ||\n" + "|-||\n" + "|-||\n" + "| ||\n" + " \n", ascii=True, ) +# fmt: on # Map Boxes that don't render with raster fonts on to equivalent that do LEGACY_WINDOWS_SUBSTITUTIONS = { @@ -464,7 +428,6 @@ def get_bottom(self, widths: Iterable[int]) -> str: if __name__ == "__main__": # pragma: no cover - from pip._vendor.rich.columns import Columns from pip._vendor.rich.panel import Panel diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/cells.py b/myenv/Lib/site-packages/pip/_vendor/rich/cells.py index 9354f9e..f85f928 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/cells.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/cells.py @@ -1,6 +1,8 @@ +from __future__ import annotations + import re from functools import lru_cache -from typing import Callable, List +from typing import Callable from ._cell_widths import CELL_WIDTHS @@ -119,33 +121,44 @@ def set_cell_size(text: str, total: int) -> str: start = pos -# TODO: This is inefficient -# TODO: This might not work with CWJ type characters -def chop_cells(text: str, max_size: int, position: int = 0) -> List[str]: - """Break text in to equal (cell) length strings, returning the characters in reverse - order""" +def chop_cells( + text: str, + width: int, +) -> list[str]: + """Split text into lines such that each line fits within the available (cell) width. + + Args: + text: The text to fold such that it fits in the given width. + width: The width available (number of cells). + + Returns: + A list of strings such that each string in the list has cell width + less than or equal to the available width. + """ _get_character_cell_size = get_character_cell_size - characters = [ - (character, _get_character_cell_size(character)) for character in text - ] - total_size = position - lines: List[List[str]] = [[]] - append = lines[-1].append - - for character, size in reversed(characters): - if total_size + size > max_size: - lines.append([character]) - append = lines[-1].append - total_size = size + lines: list[list[str]] = [[]] + + append_new_line = lines.append + append_to_last_line = lines[-1].append + + total_width = 0 + + for character in text: + cell_width = _get_character_cell_size(character) + char_doesnt_fit = total_width + cell_width > width + + if char_doesnt_fit: + append_new_line([character]) + append_to_last_line = lines[-1].append + total_width = cell_width else: - total_size += size - append(character) + append_to_last_line(character) + total_width += cell_width return ["".join(line) for line in lines] if __name__ == "__main__": # pragma: no cover - print(get_character_cell_size("😽")) for line in chop_cells("""这是对亚洲语言支持的测试。面对模棱两可的想法,拒绝猜测的诱惑。""", 8): print(line) diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/color.py b/myenv/Lib/site-packages/pip/_vendor/rich/color.py index dfe4559..4270a27 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/color.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/color.py @@ -592,7 +592,6 @@ def blend_rgb( if __name__ == "__main__": # pragma: no cover - from .console import Console from .table import Table from .text import Text diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/console.py b/myenv/Lib/site-packages/pip/_vendor/rich/console.py index e559cbb..a11c7c1 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/console.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/console.py @@ -278,6 +278,7 @@ def __rich_console__( # A type that may be rendered by Console. RenderableType = Union[ConsoleRenderable, RichCast, str] +"""A string or any object that may be rendered by Rich.""" # The result of calling a __rich_console__ method. RenderResult = Iterable[Union[RenderableType, Segment]] @@ -1925,7 +1926,6 @@ def log( end (str, optional): String to write at end of print data. Defaults to "\\\\n". style (Union[str, Style], optional): A style to apply to output. Defaults to None. justify (str, optional): One of "left", "right", "center", or "full". Defaults to ``None``. - overflow (str, optional): Overflow method: "crop", "fold", or "ellipsis". Defaults to None. emoji (Optional[bool], optional): Enable emoji code, or ``None`` to use console default. Defaults to None. markup (Optional[bool], optional): Enable markup, or ``None`` to use console default. Defaults to None. highlight (Optional[bool], optional): Enable automatic highlighting, or ``None`` to use console default. Defaults to None. diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/containers.py b/myenv/Lib/site-packages/pip/_vendor/rich/containers.py index e29cf36..901ff8b 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/containers.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/containers.py @@ -1,13 +1,13 @@ from itertools import zip_longest from typing import ( - Iterator, + TYPE_CHECKING, Iterable, + Iterator, List, Optional, + TypeVar, Union, overload, - TypeVar, - TYPE_CHECKING, ) if TYPE_CHECKING: @@ -119,7 +119,7 @@ def justify( Args: console (Console): Console instance. - width (int): Number of characters per line. + width (int): Number of cells available per line. justify (str, optional): Default justify method for text: "left", "center", "full" or "right". Defaults to "left". overflow (str, optional): Default overflow for text: "crop", "fold", or "ellipsis". Defaults to "fold". diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/highlighter.py b/myenv/Lib/site-packages/pip/_vendor/rich/highlighter.py index c264679..27714b2 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/highlighter.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/highlighter.py @@ -98,7 +98,7 @@ class ReprHighlighter(RegexHighlighter): r"(?P(?\B(/[-\w._+]+)*\/)(?P[-\w._+]*)?", r"(?b?'''.*?(?(file|https|http|ws|wss)://[-0-9a-zA-Z$_+!`(),.?/;:&=%#]*)", + r"(?P(file|https|http|ws|wss)://[-0-9a-zA-Z$_+!`(),.?/;:&=%#~]*)", ), ] diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/json.py b/myenv/Lib/site-packages/pip/_vendor/rich/json.py index ea94493..4087c79 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/json.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/json.py @@ -103,7 +103,6 @@ def __rich__(self) -> Text: if __name__ == "__main__": - import argparse import sys diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/layout.py b/myenv/Lib/site-packages/pip/_vendor/rich/layout.py index 849356e..a6f1a31 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/layout.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/layout.py @@ -227,7 +227,6 @@ def tree(self) -> "Tree": from pip._vendor.rich.tree import Tree def summary(layout: "Layout") -> Table: - icon = layout.splitter.get_tree_icon() table = Table.grid(padding=(0, 1, 0, 0)) @@ -403,7 +402,7 @@ def __rich_console__( self._render_map = render_map layout_lines: List[List[Segment]] = [[] for _ in range(height)] _islice = islice - for (region, lines) in render_map.values(): + for region, lines in render_map.values(): _x, y, _layout_width, layout_height = region for row, line in zip( _islice(layout_lines, y, y + layout_height), lines diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/live.py b/myenv/Lib/site-packages/pip/_vendor/rich/live.py index 3ebbbc4..f0529a7 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/live.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/live.py @@ -362,7 +362,7 @@ def process_renderables( table.add_column("Destination Currency") table.add_column("Exchange Rate") - for ((source, dest), exchange_rate) in exchange_rate_dict.items(): + for (source, dest), exchange_rate in exchange_rate_dict.items(): table.add_row( source, dest, diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/live_render.py b/myenv/Lib/site-packages/pip/_vendor/rich/live_render.py index b90fbf7..e20745d 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/live_render.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/live_render.py @@ -82,7 +82,6 @@ def restore_cursor(self) -> Control: def __rich_console__( self, console: Console, options: ConsoleOptions ) -> RenderResult: - renderable = self.renderable style = console.get_style(self.style) lines = console.render_lines(renderable, options, style=style, pad=False) diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/markup.py b/myenv/Lib/site-packages/pip/_vendor/rich/markup.py index fd80d8c..f617187 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/markup.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/markup.py @@ -64,6 +64,9 @@ def escape_backslashes(match: Match[str]) -> str: return f"{backslashes}{backslashes}\\{text}" markup = _escape(escape_backslashes, markup) + if markup.endswith("\\") and not markup.endswith("\\\\"): + return markup + "\\" + return markup @@ -110,7 +113,10 @@ def render( Args: markup (str): A string containing console markup. + style: (Union[str, Style]): The style to use. emoji (bool, optional): Also render emoji code. Defaults to True. + emoji_variant (str, optional): Optional emoji variant, either "text" or "emoji". Defaults to None. + Raises: MarkupError: If there is a syntax error in the markup. @@ -226,7 +232,6 @@ def pop_style(style_name: str) -> Tuple[int, Tag]: if __name__ == "__main__": # pragma: no cover - MARKUP = [ "[red]Hello World[/red]", "[magenta]Hello [b]World[/b]", diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/panel.py b/myenv/Lib/site-packages/pip/_vendor/rich/panel.py index d522d80..95f4c84 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/panel.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/panel.py @@ -82,7 +82,9 @@ def fit( style: StyleType = "none", border_style: StyleType = "none", width: Optional[int] = None, + height: Optional[int] = None, padding: PaddingDimensions = (0, 1), + highlight: bool = False, ) -> "Panel": """An alternative constructor that sets expand=False.""" return cls( @@ -96,7 +98,9 @@ def fit( style=style, border_style=border_style, width=width, + height=height, padding=padding, + highlight=highlight, expand=False, ) diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/pretty.py b/myenv/Lib/site-packages/pip/_vendor/rich/pretty.py index 2bd9eb0..9b9e3ba 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/pretty.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/pretty.py @@ -211,8 +211,11 @@ def display_hook(value: Any) -> None: ) builtins._ = value # type: ignore[attr-defined] - if "get_ipython" in globals(): + try: ip = get_ipython() # type: ignore[name-defined] + except NameError: + sys.displayhook = display_hook + else: from IPython.core.formatters import BaseFormatter class RichFormatter(BaseFormatter): # type: ignore[misc] @@ -236,8 +239,6 @@ def __call__(self, value: Any) -> Any: # replace plain text formatter with rich formatter rich_formatter = RichFormatter() ip.display_formatter.formatters["text/plain"] = rich_formatter - else: - sys.displayhook = display_hook class Pretty(JupyterMixin): @@ -708,9 +709,9 @@ def iter_rich_args(rich_args: Any) -> Iterable[Union[Any, Tuple[str, Any]]]: last=root, ) - def iter_attrs() -> Iterable[ - Tuple[str, Any, Optional[Callable[[Any], str]]] - ]: + def iter_attrs() -> ( + Iterable[Tuple[str, Any, Optional[Callable[[Any], str]]]] + ): """Iterate over attr fields and values.""" for attr in attr_fields: if attr.repr: @@ -985,7 +986,7 @@ class StockKeepingUnit(NamedTuple): from pip._vendor.rich import print - # print(Pretty(data, indent_guides=True, max_string=20)) + print(Pretty(data, indent_guides=True, max_string=20)) class Thing: def __repr__(self) -> str: diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/progress.py b/myenv/Lib/site-packages/pip/_vendor/rich/progress.py index 8b0a315..2420c24 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/progress.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/progress.py @@ -681,7 +681,7 @@ def render(self, task: "Task") -> Text: elapsed = task.finished_time if task.finished else task.elapsed if elapsed is None: return Text("-:--:--", style="progress.elapsed") - delta = timedelta(seconds=int(elapsed)) + delta = timedelta(seconds=max(0, int(elapsed))) return Text(str(delta), style="progress.elapsed") @@ -710,7 +710,6 @@ def __init__( table_column: Optional[Column] = None, show_speed: bool = False, ) -> None: - self.text_format_no_percentage = text_format_no_percentage self.show_speed = show_speed super().__init__( @@ -1114,7 +1113,7 @@ def get_default_columns(cls) -> Tuple[ProgressColumn, ...]: progress = Progress( SpinnerColumn(), - *Progress.default_columns(), + *Progress.get_default_columns(), "Elapsed:", TimeElapsedColumn(), ) @@ -1636,7 +1635,6 @@ def remove_task(self, task_id: TaskID) -> None: if __name__ == "__main__": # pragma: no coverage - import random import time @@ -1689,7 +1687,6 @@ def remove_task(self, task_id: TaskID) -> None: console=console, transient=False, ) as progress: - task1 = progress.add_task("[red]Downloading", total=1000) task2 = progress.add_task("[green]Processing", total=1000) task3 = progress.add_task("[yellow]Thinking", total=None) diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/progress_bar.py b/myenv/Lib/site-packages/pip/_vendor/rich/progress_bar.py index 67361df..a2bf326 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/progress_bar.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/progress_bar.py @@ -156,7 +156,6 @@ def _render_pulse( def __rich_console__( self, console: Console, options: ConsoleOptions ) -> RenderResult: - width = min(self.width or options.max_width, options.max_width) ascii = options.legacy_windows or options.ascii_only should_pulse = self.pulse or self.total is None diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/prompt.py b/myenv/Lib/site-packages/pip/_vendor/rich/prompt.py index 2bd0a77..75ff048 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/prompt.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/prompt.py @@ -307,7 +307,7 @@ class IntPrompt(PromptBase[int]): validate_error_message = "[prompt.invalid]Please enter a valid integer number" -class FloatPrompt(PromptBase[int]): +class FloatPrompt(PromptBase[float]): """A prompt that returns a float. Example: @@ -346,7 +346,6 @@ def process_response(self, value: str) -> bool: if __name__ == "__main__": # pragma: no cover - from pip._vendor.rich import print if Confirm.ask("Run [i]prompt[/i] tests?", default=True): diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/repr.py b/myenv/Lib/site-packages/pip/_vendor/rich/repr.py index f284bca..10efc42 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/repr.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/repr.py @@ -76,7 +76,7 @@ def auto_rich_repr(self: Type[T]) -> Result: param.POSITIONAL_OR_KEYWORD, param.KEYWORD_ONLY, ): - if param.default == param.empty: + if param.default is param.empty: yield getattr(self, param.name) else: yield param.name, getattr(self, param.name), param.default diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/segment.py b/myenv/Lib/site-packages/pip/_vendor/rich/segment.py index e125798..93edbbd 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/segment.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/segment.py @@ -109,7 +109,6 @@ def is_control(self) -> bool: @classmethod @lru_cache(1024 * 16) def _split_cells(cls, segment: "Segment", cut: int) -> Tuple["Segment", "Segment"]: - text, style, control = segment _Segment = Segment diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/status.py b/myenv/Lib/site-packages/pip/_vendor/rich/status.py index 09eff40..6574483 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/status.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/status.py @@ -107,7 +107,6 @@ def __exit__( if __name__ == "__main__": # pragma: no cover - from time import sleep from .console import Console diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/syntax.py b/myenv/Lib/site-packages/pip/_vendor/rich/syntax.py index 5703376..c26fd87 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/syntax.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/syntax.py @@ -439,6 +439,16 @@ def lexer(self) -> Optional[Lexer]: except ClassNotFound: return None + @property + def default_lexer(self) -> Lexer: + """A Pygments Lexer to use if one is not specified or invalid.""" + return get_lexer_by_name( + "text", + stripnl=False, + ensurenl=True, + tabsize=self.tab_size, + ) + def highlight( self, code: str, @@ -467,7 +477,7 @@ def highlight( ) _get_theme_style = self._theme.get_style_for_token - lexer = self.lexer + lexer = self.lexer or self.default_lexer if lexer is None: text.append(code) diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/table.py b/myenv/Lib/site-packages/pip/_vendor/rich/table.py index 17409f2..43c718e 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/table.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/table.py @@ -212,7 +212,6 @@ def __init__( caption_justify: "JustifyMethod" = "center", highlight: bool = False, ) -> None: - self.columns: List[Column] = [] self.rows: List[Row] = [] self.title = title @@ -471,7 +470,6 @@ def add_section(self) -> None: def __rich_console__( self, console: "Console", options: "ConsoleOptions" ) -> "RenderResult": - if not self.columns: yield Segment("\n") return @@ -685,7 +683,7 @@ def get_padding(first_row: bool, last_row: bool) -> Tuple[int, int, int, int]: getattr(renderable, "vertical", None) or column.vertical, ) else: - for (style, renderable) in raw_cells: + for style, renderable in raw_cells: yield _Cell( style, renderable, diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/text.py b/myenv/Lib/site-packages/pip/_vendor/rich/text.py index 998cb87..209aa94 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/text.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/text.py @@ -38,6 +38,7 @@ _re_whitespace = re.compile(r"\s+$") TextType = Union[str, "Text"] +"""A plain string or a :class:`Text` instance.""" GetStyleCallable = Callable[[str], Optional[StyleType]] @@ -97,6 +98,21 @@ def right_crop(self, offset: int) -> "Span": return self return Span(start, min(offset, end), style) + def extend(self, cells: int) -> "Span": + """Extend the span by the given number of cells. + + Args: + cells (int): Additional space to add to end of span. + + Returns: + Span: A span. + """ + if cells: + start, end, style = self + return Span(start, end + cells, style) + else: + return self + class Text(JupyterMixin): """Text with color / style. @@ -108,7 +124,7 @@ class Text(JupyterMixin): overflow (str, optional): Overflow method: "crop", "fold", "ellipsis". Defaults to None. no_wrap (bool, optional): Disable text wrapping, or None for default. Defaults to None. end (str, optional): Character to end text with. Defaults to "\\\\n". - tab_size (int): Number of spaces per tab, or ``None`` to use ``console.tab_size``. Defaults to 8. + tab_size (int): Number of spaces per tab, or ``None`` to use ``console.tab_size``. Defaults to None. spans (List[Span], optional). A list of predefined style spans. Defaults to None. """ @@ -133,7 +149,7 @@ def __init__( overflow: Optional["OverflowMethod"] = None, no_wrap: Optional[bool] = None, end: str = "\n", - tab_size: Optional[int] = 8, + tab_size: Optional[int] = None, spans: Optional[List[Span]] = None, ) -> None: sanitized_text = strip_control_codes(text) @@ -255,7 +271,9 @@ def from_markup( Args: text (str): A string containing console markup. + style (Union[str, Style], optional): Base style for text. Defaults to "". emoji (bool, optional): Also render emoji code. Defaults to True. + emoji_variant (str, optional): Optional emoji variant, either "text" or "emoji". Defaults to None. justify (str, optional): Justify method: "left", "center", "full", "right". Defaults to None. overflow (str, optional): Overflow method: "crop", "fold", "ellipsis". Defaults to None. end (str, optional): Character to end text with. Defaults to "\\\\n". @@ -292,7 +310,7 @@ def from_ansi( overflow (str, optional): Overflow method: "crop", "fold", "ellipsis". Defaults to None. no_wrap (bool, optional): Disable text wrapping, or None for default. Defaults to None. end (str, optional): Character to end text with. Defaults to "\\\\n". - tab_size (int): Number of spaces per tab, or ``None`` to use ``console.tab_size``. Defaults to 8. + tab_size (int): Number of spaces per tab, or ``None`` to use ``console.tab_size``. Defaults to None. """ from .ansi import AnsiDecoder @@ -353,8 +371,9 @@ def assemble( style (Union[str, Style], optional): Base style for text. Defaults to "". justify (str, optional): Justify method: "left", "center", "full", "right". Defaults to None. overflow (str, optional): Overflow method: "crop", "fold", "ellipsis". Defaults to None. + no_wrap (bool, optional): Disable text wrapping, or None for default. Defaults to None. end (str, optional): Character to end text with. Defaults to "\\\\n". - tab_size (int): Number of spaces per tab, or ``None`` to use ``console.tab_size``. Defaults to 8. + tab_size (int): Number of spaces per tab, or ``None`` to use ``console.tab_size``. Defaults to None. meta (Dict[str, Any], optional). Meta data to apply to text, or None for no meta data. Default to None Returns: @@ -408,7 +427,7 @@ def spans(self, spans: List[Span]) -> None: self._spans = spans[:] def blank_copy(self, plain: str = "") -> "Text": - """Return a new Text instance with copied meta data (but not the string or spans).""" + """Return a new Text instance with copied metadata (but not the string or spans).""" copy_self = Text( plain, style=self.style, @@ -489,7 +508,7 @@ def stylize_before( def apply_meta( self, meta: Dict[str, Any], start: int = 0, end: Optional[int] = None ) -> None: - """Apply meta data to the text, or a portion of the text. + """Apply metadata to the text, or a portion of the text. Args: meta (Dict[str, Any]): A dict of meta information. @@ -549,6 +568,27 @@ def get_style_at_offset(self, console: "Console", offset: int) -> Style: style += get_style(span_style, default="") return style + def extend_style(self, spaces: int) -> None: + """Extend the Text given number of spaces where the spaces have the same style as the last character. + + Args: + spaces (int): Number of spaces to add to the Text. + """ + if spaces <= 0: + return + spans = self.spans + new_spaces = " " * spaces + if spans: + end_offset = len(self) + self._spans[:] = [ + span.extend(spaces) if span.end >= end_offset else span + for span in spans + ] + self._text.append(new_spaces) + self._length += spaces + else: + self.plain += new_spaces + def highlight_regex( self, re_highlight: str, @@ -597,9 +637,9 @@ def highlight_words( """Highlight words with a style. Args: - words (Iterable[str]): Worlds to highlight. + words (Iterable[str]): Words to highlight. style (Union[str, Style]): Style to apply. - case_sensitive (bool, optional): Enable case sensitive matchings. Defaults to True. + case_sensitive (bool, optional): Enable case sensitive matching. Defaults to True. Returns: int: Number of words highlighted. @@ -646,7 +686,7 @@ def set_length(self, new_length: int) -> None: def __rich_console__( self, console: "Console", options: "ConsoleOptions" ) -> Iterable[Segment]: - tab_size: int = console.tab_size or self.tab_size or 8 + tab_size: int = console.tab_size if self.tab_size is None else self.tab_size justify = self.justify or options.justify or DEFAULT_JUSTIFY overflow = self.overflow or options.overflow or DEFAULT_OVERFLOW @@ -781,27 +821,35 @@ def expand_tabs(self, tab_size: Optional[int] = None) -> None: """ if "\t" not in self.plain: return - pos = 0 if tab_size is None: tab_size = self.tab_size - assert tab_size is not None - result = self.blank_copy() - append = result.append + if tab_size is None: + tab_size = 8 + + new_text: List[Text] = [] + append = new_text.append - _style = self.style for line in self.split("\n", include_separator=True): - parts = line.split("\t", include_separator=True) - for part in parts: - if part.plain.endswith("\t"): - part._text = [part.plain[:-1] + " "] - append(part) - pos += len(part) - spaces = tab_size - ((pos - 1) % tab_size) - 1 - if spaces: - append(" " * spaces, _style) - pos += spaces - else: + if "\t" not in line.plain: + append(line) + else: + cell_position = 0 + parts = line.split("\t", include_separator=True) + for part in parts: + if part.plain.endswith("\t"): + part._text[-1] = part._text[-1][:-1] + " " + cell_position += part.cell_len + tab_remainder = cell_position % tab_size + if tab_remainder: + spaces = tab_size - tab_remainder + part.extend_style(spaces) + cell_position += spaces + else: + cell_position += part.cell_len append(part) + + result = Text("").join(new_text) + self._text = [result.plain] self._length = len(self.plain) self._spans[:] = result._spans @@ -852,6 +900,7 @@ def pad(self, count: int, character: str = " ") -> None: Args: count (int): Width of padding. + character (str): The character to pad with. Must be a string of length 1. """ assert len(character) == 1, "Character must be a string of length 1" if count: @@ -932,7 +981,7 @@ def append( self._text.append(sanitized_text) offset = len(self) text_length = len(sanitized_text) - if style is not None: + if style: self._spans.append(Span(offset, offset + text_length, style)) self._length += text_length elif isinstance(text, Text): @@ -942,7 +991,7 @@ def append( "style must not be set when appending Text instance" ) text_length = self._length - if text.style is not None: + if text.style: self._spans.append( _Span(text_length, text_length + len(text), text.style) ) @@ -958,12 +1007,15 @@ def append_text(self, text: "Text") -> "Text": """Append another Text instance. This method is more performant that Text.append, but only works for Text. + Args: + text (Text): The Text instance to append to this instance. + Returns: Text: Returns self for chaining. """ _Span = Span text_length = self._length - if text.style is not None: + if text.style: self._spans.append(_Span(text_length, text_length + len(text), text.style)) self._text.append(text.plain) self._spans.extend( @@ -979,7 +1031,7 @@ def append_tokens( """Append iterable of str and style. Style may be a Style instance or a str style definition. Args: - pairs (Iterable[Tuple[str, Optional[StyleType]]]): An iterable of tuples containing str content and style. + tokens (Iterable[Tuple[str, Optional[StyleType]]]): An iterable of tuples containing str content and style. Returns: Text: Returns self for chaining. @@ -990,7 +1042,7 @@ def append_tokens( offset = len(self) for content, style in tokens: append_text(content) - if style is not None: + if style: append_span(_Span(offset, offset + len(content), style)) offset += len(content) self._length = offset @@ -1088,7 +1140,6 @@ def divide(self, offsets: Iterable[int]) -> Lines: _Span = Span for span_start, span_end, style in self._spans: - lower_bound = 0 upper_bound = line_count start_line_no = (lower_bound + upper_bound) // 2 @@ -1158,8 +1209,7 @@ def wrap( Args: console (Console): Console instance. - width (int): Number of characters per line. - emoji (bool, optional): Also render emoji code. Defaults to True. + width (int): Number of cells available per line. justify (str, optional): Justify method: "default", "left", "center", "full", "right". Defaults to "default". overflow (str, optional): Overflow method: "crop", "fold", or "ellipsis". Defaults to None. tab_size (int, optional): Default tab size. Defaults to 8. diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/traceback.py b/myenv/Lib/site-packages/pip/_vendor/rich/traceback.py index c4ffe1f..f223ad4 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/traceback.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/traceback.py @@ -636,7 +636,6 @@ def render_locals(frame: Frame) -> Iterable[ConsoleRenderable]: excluded = False for frame_index, frame in enumerate(stack.frames): - if exclude_frames and frame_index in exclude_frames: excluded = True continue @@ -720,7 +719,6 @@ def render_locals(frame: Frame) -> Iterable[ConsoleRenderable]: if __name__ == "__main__": # pragma: no cover - from .console import Console console = Console() @@ -744,7 +742,6 @@ def foo(a: Any) -> None: bar(a) def error() -> None: - try: try: foo(0) diff --git a/myenv/Lib/site-packages/pip/_vendor/rich/tree.py b/myenv/Lib/site-packages/pip/_vendor/rich/tree.py index afe8da1..64bc75d 100644 --- a/myenv/Lib/site-packages/pip/_vendor/rich/tree.py +++ b/myenv/Lib/site-packages/pip/_vendor/rich/tree.py @@ -72,7 +72,6 @@ def add( def __rich_console__( self, console: "Console", options: "ConsoleOptions" ) -> "RenderResult": - stack: List[Iterator[Tuple[bool, Tree]]] = [] pop = stack.pop push = stack.append @@ -195,7 +194,6 @@ def __rich_measure__( if __name__ == "__main__": # pragma: no cover - from pip._vendor.rich.console import Group from pip._vendor.rich.markdown import Markdown from pip._vendor.rich.panel import Panel diff --git a/myenv/Lib/site-packages/pip/_vendor/six.py b/myenv/Lib/site-packages/pip/_vendor/six.py deleted file mode 100644 index 4e15675..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/six.py +++ /dev/null @@ -1,998 +0,0 @@ -# Copyright (c) 2010-2020 Benjamin Peterson -# -# Permission is hereby granted, free of charge, to any person obtaining a copy -# of this software and associated documentation files (the "Software"), to deal -# in the Software without restriction, including without limitation the rights -# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -# copies of the Software, and to permit persons to whom the Software is -# furnished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in all -# copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -# SOFTWARE. - -"""Utilities for writing code that runs on Python 2 and 3""" - -from __future__ import absolute_import - -import functools -import itertools -import operator -import sys -import types - -__author__ = "Benjamin Peterson " -__version__ = "1.16.0" - - -# Useful for very coarse version differentiation. -PY2 = sys.version_info[0] == 2 -PY3 = sys.version_info[0] == 3 -PY34 = sys.version_info[0:2] >= (3, 4) - -if PY3: - string_types = str, - integer_types = int, - class_types = type, - text_type = str - binary_type = bytes - - MAXSIZE = sys.maxsize -else: - string_types = basestring, - integer_types = (int, long) - class_types = (type, types.ClassType) - text_type = unicode - binary_type = str - - if sys.platform.startswith("java"): - # Jython always uses 32 bits. - MAXSIZE = int((1 << 31) - 1) - else: - # It's possible to have sizeof(long) != sizeof(Py_ssize_t). - class X(object): - - def __len__(self): - return 1 << 31 - try: - len(X()) - except OverflowError: - # 32-bit - MAXSIZE = int((1 << 31) - 1) - else: - # 64-bit - MAXSIZE = int((1 << 63) - 1) - del X - -if PY34: - from importlib.util import spec_from_loader -else: - spec_from_loader = None - - -def _add_doc(func, doc): - """Add documentation to a function.""" - func.__doc__ = doc - - -def _import_module(name): - """Import module, returning the module after the last dot.""" - __import__(name) - return sys.modules[name] - - -class _LazyDescr(object): - - def __init__(self, name): - self.name = name - - def __get__(self, obj, tp): - result = self._resolve() - setattr(obj, self.name, result) # Invokes __set__. - try: - # This is a bit ugly, but it avoids running this again by - # removing this descriptor. - delattr(obj.__class__, self.name) - except AttributeError: - pass - return result - - -class MovedModule(_LazyDescr): - - def __init__(self, name, old, new=None): - super(MovedModule, self).__init__(name) - if PY3: - if new is None: - new = name - self.mod = new - else: - self.mod = old - - def _resolve(self): - return _import_module(self.mod) - - def __getattr__(self, attr): - _module = self._resolve() - value = getattr(_module, attr) - setattr(self, attr, value) - return value - - -class _LazyModule(types.ModuleType): - - def __init__(self, name): - super(_LazyModule, self).__init__(name) - self.__doc__ = self.__class__.__doc__ - - def __dir__(self): - attrs = ["__doc__", "__name__"] - attrs += [attr.name for attr in self._moved_attributes] - return attrs - - # Subclasses should override this - _moved_attributes = [] - - -class MovedAttribute(_LazyDescr): - - def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): - super(MovedAttribute, self).__init__(name) - if PY3: - if new_mod is None: - new_mod = name - self.mod = new_mod - if new_attr is None: - if old_attr is None: - new_attr = name - else: - new_attr = old_attr - self.attr = new_attr - else: - self.mod = old_mod - if old_attr is None: - old_attr = name - self.attr = old_attr - - def _resolve(self): - module = _import_module(self.mod) - return getattr(module, self.attr) - - -class _SixMetaPathImporter(object): - - """ - A meta path importer to import six.moves and its submodules. - - This class implements a PEP302 finder and loader. It should be compatible - with Python 2.5 and all existing versions of Python3 - """ - - def __init__(self, six_module_name): - self.name = six_module_name - self.known_modules = {} - - def _add_module(self, mod, *fullnames): - for fullname in fullnames: - self.known_modules[self.name + "." + fullname] = mod - - def _get_module(self, fullname): - return self.known_modules[self.name + "." + fullname] - - def find_module(self, fullname, path=None): - if fullname in self.known_modules: - return self - return None - - def find_spec(self, fullname, path, target=None): - if fullname in self.known_modules: - return spec_from_loader(fullname, self) - return None - - def __get_module(self, fullname): - try: - return self.known_modules[fullname] - except KeyError: - raise ImportError("This loader does not know module " + fullname) - - def load_module(self, fullname): - try: - # in case of a reload - return sys.modules[fullname] - except KeyError: - pass - mod = self.__get_module(fullname) - if isinstance(mod, MovedModule): - mod = mod._resolve() - else: - mod.__loader__ = self - sys.modules[fullname] = mod - return mod - - def is_package(self, fullname): - """ - Return true, if the named module is a package. - - We need this method to get correct spec objects with - Python 3.4 (see PEP451) - """ - return hasattr(self.__get_module(fullname), "__path__") - - def get_code(self, fullname): - """Return None - - Required, if is_package is implemented""" - self.__get_module(fullname) # eventually raises ImportError - return None - get_source = get_code # same as get_code - - def create_module(self, spec): - return self.load_module(spec.name) - - def exec_module(self, module): - pass - -_importer = _SixMetaPathImporter(__name__) - - -class _MovedItems(_LazyModule): - - """Lazy loading of moved objects""" - __path__ = [] # mark as package - - -_moved_attributes = [ - MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), - MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), - MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"), - MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), - MovedAttribute("intern", "__builtin__", "sys"), - MovedAttribute("map", "itertools", "builtins", "imap", "map"), - MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), - MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), - MovedAttribute("getoutput", "commands", "subprocess"), - MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), - MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"), - MovedAttribute("reduce", "__builtin__", "functools"), - MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), - MovedAttribute("StringIO", "StringIO", "io"), - MovedAttribute("UserDict", "UserDict", "collections"), - MovedAttribute("UserList", "UserList", "collections"), - MovedAttribute("UserString", "UserString", "collections"), - MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), - MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), - MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"), - MovedModule("builtins", "__builtin__"), - MovedModule("configparser", "ConfigParser"), - MovedModule("collections_abc", "collections", "collections.abc" if sys.version_info >= (3, 3) else "collections"), - MovedModule("copyreg", "copy_reg"), - MovedModule("dbm_gnu", "gdbm", "dbm.gnu"), - MovedModule("dbm_ndbm", "dbm", "dbm.ndbm"), - MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread" if sys.version_info < (3, 9) else "_thread"), - MovedModule("http_cookiejar", "cookielib", "http.cookiejar"), - MovedModule("http_cookies", "Cookie", "http.cookies"), - MovedModule("html_entities", "htmlentitydefs", "html.entities"), - MovedModule("html_parser", "HTMLParser", "html.parser"), - MovedModule("http_client", "httplib", "http.client"), - MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), - MovedModule("email_mime_image", "email.MIMEImage", "email.mime.image"), - MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), - MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"), - MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), - MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), - MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), - MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), - MovedModule("cPickle", "cPickle", "pickle"), - MovedModule("queue", "Queue"), - MovedModule("reprlib", "repr"), - MovedModule("socketserver", "SocketServer"), - MovedModule("_thread", "thread", "_thread"), - MovedModule("tkinter", "Tkinter"), - MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), - MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), - MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), - MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), - MovedModule("tkinter_tix", "Tix", "tkinter.tix"), - MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), - MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), - MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), - MovedModule("tkinter_colorchooser", "tkColorChooser", - "tkinter.colorchooser"), - MovedModule("tkinter_commondialog", "tkCommonDialog", - "tkinter.commondialog"), - MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), - MovedModule("tkinter_font", "tkFont", "tkinter.font"), - MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), - MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", - "tkinter.simpledialog"), - MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), - MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), - MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), - MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), - MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), - MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), -] -# Add windows specific modules. -if sys.platform == "win32": - _moved_attributes += [ - MovedModule("winreg", "_winreg"), - ] - -for attr in _moved_attributes: - setattr(_MovedItems, attr.name, attr) - if isinstance(attr, MovedModule): - _importer._add_module(attr, "moves." + attr.name) -del attr - -_MovedItems._moved_attributes = _moved_attributes - -moves = _MovedItems(__name__ + ".moves") -_importer._add_module(moves, "moves") - - -class Module_six_moves_urllib_parse(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_parse""" - - -_urllib_parse_moved_attributes = [ - MovedAttribute("ParseResult", "urlparse", "urllib.parse"), - MovedAttribute("SplitResult", "urlparse", "urllib.parse"), - MovedAttribute("parse_qs", "urlparse", "urllib.parse"), - MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), - MovedAttribute("urldefrag", "urlparse", "urllib.parse"), - MovedAttribute("urljoin", "urlparse", "urllib.parse"), - MovedAttribute("urlparse", "urlparse", "urllib.parse"), - MovedAttribute("urlsplit", "urlparse", "urllib.parse"), - MovedAttribute("urlunparse", "urlparse", "urllib.parse"), - MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), - MovedAttribute("quote", "urllib", "urllib.parse"), - MovedAttribute("quote_plus", "urllib", "urllib.parse"), - MovedAttribute("unquote", "urllib", "urllib.parse"), - MovedAttribute("unquote_plus", "urllib", "urllib.parse"), - MovedAttribute("unquote_to_bytes", "urllib", "urllib.parse", "unquote", "unquote_to_bytes"), - MovedAttribute("urlencode", "urllib", "urllib.parse"), - MovedAttribute("splitquery", "urllib", "urllib.parse"), - MovedAttribute("splittag", "urllib", "urllib.parse"), - MovedAttribute("splituser", "urllib", "urllib.parse"), - MovedAttribute("splitvalue", "urllib", "urllib.parse"), - MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), - MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), - MovedAttribute("uses_params", "urlparse", "urllib.parse"), - MovedAttribute("uses_query", "urlparse", "urllib.parse"), - MovedAttribute("uses_relative", "urlparse", "urllib.parse"), -] -for attr in _urllib_parse_moved_attributes: - setattr(Module_six_moves_urllib_parse, attr.name, attr) -del attr - -Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes - -_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), - "moves.urllib_parse", "moves.urllib.parse") - - -class Module_six_moves_urllib_error(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_error""" - - -_urllib_error_moved_attributes = [ - MovedAttribute("URLError", "urllib2", "urllib.error"), - MovedAttribute("HTTPError", "urllib2", "urllib.error"), - MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), -] -for attr in _urllib_error_moved_attributes: - setattr(Module_six_moves_urllib_error, attr.name, attr) -del attr - -Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes - -_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), - "moves.urllib_error", "moves.urllib.error") - - -class Module_six_moves_urllib_request(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_request""" - - -_urllib_request_moved_attributes = [ - MovedAttribute("urlopen", "urllib2", "urllib.request"), - MovedAttribute("install_opener", "urllib2", "urllib.request"), - MovedAttribute("build_opener", "urllib2", "urllib.request"), - MovedAttribute("pathname2url", "urllib", "urllib.request"), - MovedAttribute("url2pathname", "urllib", "urllib.request"), - MovedAttribute("getproxies", "urllib", "urllib.request"), - MovedAttribute("Request", "urllib2", "urllib.request"), - MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), - MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), - MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), - MovedAttribute("BaseHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), - MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), - MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), - MovedAttribute("FileHandler", "urllib2", "urllib.request"), - MovedAttribute("FTPHandler", "urllib2", "urllib.request"), - MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), - MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), - MovedAttribute("urlretrieve", "urllib", "urllib.request"), - MovedAttribute("urlcleanup", "urllib", "urllib.request"), - MovedAttribute("URLopener", "urllib", "urllib.request"), - MovedAttribute("FancyURLopener", "urllib", "urllib.request"), - MovedAttribute("proxy_bypass", "urllib", "urllib.request"), - MovedAttribute("parse_http_list", "urllib2", "urllib.request"), - MovedAttribute("parse_keqv_list", "urllib2", "urllib.request"), -] -for attr in _urllib_request_moved_attributes: - setattr(Module_six_moves_urllib_request, attr.name, attr) -del attr - -Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes - -_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), - "moves.urllib_request", "moves.urllib.request") - - -class Module_six_moves_urllib_response(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_response""" - - -_urllib_response_moved_attributes = [ - MovedAttribute("addbase", "urllib", "urllib.response"), - MovedAttribute("addclosehook", "urllib", "urllib.response"), - MovedAttribute("addinfo", "urllib", "urllib.response"), - MovedAttribute("addinfourl", "urllib", "urllib.response"), -] -for attr in _urllib_response_moved_attributes: - setattr(Module_six_moves_urllib_response, attr.name, attr) -del attr - -Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes - -_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), - "moves.urllib_response", "moves.urllib.response") - - -class Module_six_moves_urllib_robotparser(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_robotparser""" - - -_urllib_robotparser_moved_attributes = [ - MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), -] -for attr in _urllib_robotparser_moved_attributes: - setattr(Module_six_moves_urllib_robotparser, attr.name, attr) -del attr - -Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes - -_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), - "moves.urllib_robotparser", "moves.urllib.robotparser") - - -class Module_six_moves_urllib(types.ModuleType): - - """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" - __path__ = [] # mark as package - parse = _importer._get_module("moves.urllib_parse") - error = _importer._get_module("moves.urllib_error") - request = _importer._get_module("moves.urllib_request") - response = _importer._get_module("moves.urllib_response") - robotparser = _importer._get_module("moves.urllib_robotparser") - - def __dir__(self): - return ['parse', 'error', 'request', 'response', 'robotparser'] - -_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"), - "moves.urllib") - - -def add_move(move): - """Add an item to six.moves.""" - setattr(_MovedItems, move.name, move) - - -def remove_move(name): - """Remove item from six.moves.""" - try: - delattr(_MovedItems, name) - except AttributeError: - try: - del moves.__dict__[name] - except KeyError: - raise AttributeError("no such move, %r" % (name,)) - - -if PY3: - _meth_func = "__func__" - _meth_self = "__self__" - - _func_closure = "__closure__" - _func_code = "__code__" - _func_defaults = "__defaults__" - _func_globals = "__globals__" -else: - _meth_func = "im_func" - _meth_self = "im_self" - - _func_closure = "func_closure" - _func_code = "func_code" - _func_defaults = "func_defaults" - _func_globals = "func_globals" - - -try: - advance_iterator = next -except NameError: - def advance_iterator(it): - return it.next() -next = advance_iterator - - -try: - callable = callable -except NameError: - def callable(obj): - return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) - - -if PY3: - def get_unbound_function(unbound): - return unbound - - create_bound_method = types.MethodType - - def create_unbound_method(func, cls): - return func - - Iterator = object -else: - def get_unbound_function(unbound): - return unbound.im_func - - def create_bound_method(func, obj): - return types.MethodType(func, obj, obj.__class__) - - def create_unbound_method(func, cls): - return types.MethodType(func, None, cls) - - class Iterator(object): - - def next(self): - return type(self).__next__(self) - - callable = callable -_add_doc(get_unbound_function, - """Get the function out of a possibly unbound function""") - - -get_method_function = operator.attrgetter(_meth_func) -get_method_self = operator.attrgetter(_meth_self) -get_function_closure = operator.attrgetter(_func_closure) -get_function_code = operator.attrgetter(_func_code) -get_function_defaults = operator.attrgetter(_func_defaults) -get_function_globals = operator.attrgetter(_func_globals) - - -if PY3: - def iterkeys(d, **kw): - return iter(d.keys(**kw)) - - def itervalues(d, **kw): - return iter(d.values(**kw)) - - def iteritems(d, **kw): - return iter(d.items(**kw)) - - def iterlists(d, **kw): - return iter(d.lists(**kw)) - - viewkeys = operator.methodcaller("keys") - - viewvalues = operator.methodcaller("values") - - viewitems = operator.methodcaller("items") -else: - def iterkeys(d, **kw): - return d.iterkeys(**kw) - - def itervalues(d, **kw): - return d.itervalues(**kw) - - def iteritems(d, **kw): - return d.iteritems(**kw) - - def iterlists(d, **kw): - return d.iterlists(**kw) - - viewkeys = operator.methodcaller("viewkeys") - - viewvalues = operator.methodcaller("viewvalues") - - viewitems = operator.methodcaller("viewitems") - -_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") -_add_doc(itervalues, "Return an iterator over the values of a dictionary.") -_add_doc(iteritems, - "Return an iterator over the (key, value) pairs of a dictionary.") -_add_doc(iterlists, - "Return an iterator over the (key, [values]) pairs of a dictionary.") - - -if PY3: - def b(s): - return s.encode("latin-1") - - def u(s): - return s - unichr = chr - import struct - int2byte = struct.Struct(">B").pack - del struct - byte2int = operator.itemgetter(0) - indexbytes = operator.getitem - iterbytes = iter - import io - StringIO = io.StringIO - BytesIO = io.BytesIO - del io - _assertCountEqual = "assertCountEqual" - if sys.version_info[1] <= 1: - _assertRaisesRegex = "assertRaisesRegexp" - _assertRegex = "assertRegexpMatches" - _assertNotRegex = "assertNotRegexpMatches" - else: - _assertRaisesRegex = "assertRaisesRegex" - _assertRegex = "assertRegex" - _assertNotRegex = "assertNotRegex" -else: - def b(s): - return s - # Workaround for standalone backslash - - def u(s): - return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape") - unichr = unichr - int2byte = chr - - def byte2int(bs): - return ord(bs[0]) - - def indexbytes(buf, i): - return ord(buf[i]) - iterbytes = functools.partial(itertools.imap, ord) - import StringIO - StringIO = BytesIO = StringIO.StringIO - _assertCountEqual = "assertItemsEqual" - _assertRaisesRegex = "assertRaisesRegexp" - _assertRegex = "assertRegexpMatches" - _assertNotRegex = "assertNotRegexpMatches" -_add_doc(b, """Byte literal""") -_add_doc(u, """Text literal""") - - -def assertCountEqual(self, *args, **kwargs): - return getattr(self, _assertCountEqual)(*args, **kwargs) - - -def assertRaisesRegex(self, *args, **kwargs): - return getattr(self, _assertRaisesRegex)(*args, **kwargs) - - -def assertRegex(self, *args, **kwargs): - return getattr(self, _assertRegex)(*args, **kwargs) - - -def assertNotRegex(self, *args, **kwargs): - return getattr(self, _assertNotRegex)(*args, **kwargs) - - -if PY3: - exec_ = getattr(moves.builtins, "exec") - - def reraise(tp, value, tb=None): - try: - if value is None: - value = tp() - if value.__traceback__ is not tb: - raise value.with_traceback(tb) - raise value - finally: - value = None - tb = None - -else: - def exec_(_code_, _globs_=None, _locs_=None): - """Execute code in a namespace.""" - if _globs_ is None: - frame = sys._getframe(1) - _globs_ = frame.f_globals - if _locs_ is None: - _locs_ = frame.f_locals - del frame - elif _locs_ is None: - _locs_ = _globs_ - exec("""exec _code_ in _globs_, _locs_""") - - exec_("""def reraise(tp, value, tb=None): - try: - raise tp, value, tb - finally: - tb = None -""") - - -if sys.version_info[:2] > (3,): - exec_("""def raise_from(value, from_value): - try: - raise value from from_value - finally: - value = None -""") -else: - def raise_from(value, from_value): - raise value - - -print_ = getattr(moves.builtins, "print", None) -if print_ is None: - def print_(*args, **kwargs): - """The new-style print function for Python 2.4 and 2.5.""" - fp = kwargs.pop("file", sys.stdout) - if fp is None: - return - - def write(data): - if not isinstance(data, basestring): - data = str(data) - # If the file has an encoding, encode unicode with it. - if (isinstance(fp, file) and - isinstance(data, unicode) and - fp.encoding is not None): - errors = getattr(fp, "errors", None) - if errors is None: - errors = "strict" - data = data.encode(fp.encoding, errors) - fp.write(data) - want_unicode = False - sep = kwargs.pop("sep", None) - if sep is not None: - if isinstance(sep, unicode): - want_unicode = True - elif not isinstance(sep, str): - raise TypeError("sep must be None or a string") - end = kwargs.pop("end", None) - if end is not None: - if isinstance(end, unicode): - want_unicode = True - elif not isinstance(end, str): - raise TypeError("end must be None or a string") - if kwargs: - raise TypeError("invalid keyword arguments to print()") - if not want_unicode: - for arg in args: - if isinstance(arg, unicode): - want_unicode = True - break - if want_unicode: - newline = unicode("\n") - space = unicode(" ") - else: - newline = "\n" - space = " " - if sep is None: - sep = space - if end is None: - end = newline - for i, arg in enumerate(args): - if i: - write(sep) - write(arg) - write(end) -if sys.version_info[:2] < (3, 3): - _print = print_ - - def print_(*args, **kwargs): - fp = kwargs.get("file", sys.stdout) - flush = kwargs.pop("flush", False) - _print(*args, **kwargs) - if flush and fp is not None: - fp.flush() - -_add_doc(reraise, """Reraise an exception.""") - -if sys.version_info[0:2] < (3, 4): - # This does exactly the same what the :func:`py3:functools.update_wrapper` - # function does on Python versions after 3.2. It sets the ``__wrapped__`` - # attribute on ``wrapper`` object and it doesn't raise an error if any of - # the attributes mentioned in ``assigned`` and ``updated`` are missing on - # ``wrapped`` object. - def _update_wrapper(wrapper, wrapped, - assigned=functools.WRAPPER_ASSIGNMENTS, - updated=functools.WRAPPER_UPDATES): - for attr in assigned: - try: - value = getattr(wrapped, attr) - except AttributeError: - continue - else: - setattr(wrapper, attr, value) - for attr in updated: - getattr(wrapper, attr).update(getattr(wrapped, attr, {})) - wrapper.__wrapped__ = wrapped - return wrapper - _update_wrapper.__doc__ = functools.update_wrapper.__doc__ - - def wraps(wrapped, assigned=functools.WRAPPER_ASSIGNMENTS, - updated=functools.WRAPPER_UPDATES): - return functools.partial(_update_wrapper, wrapped=wrapped, - assigned=assigned, updated=updated) - wraps.__doc__ = functools.wraps.__doc__ - -else: - wraps = functools.wraps - - -def with_metaclass(meta, *bases): - """Create a base class with a metaclass.""" - # This requires a bit of explanation: the basic idea is to make a dummy - # metaclass for one level of class instantiation that replaces itself with - # the actual metaclass. - class metaclass(type): - - def __new__(cls, name, this_bases, d): - if sys.version_info[:2] >= (3, 7): - # This version introduced PEP 560 that requires a bit - # of extra care (we mimic what is done by __build_class__). - resolved_bases = types.resolve_bases(bases) - if resolved_bases is not bases: - d['__orig_bases__'] = bases - else: - resolved_bases = bases - return meta(name, resolved_bases, d) - - @classmethod - def __prepare__(cls, name, this_bases): - return meta.__prepare__(name, bases) - return type.__new__(metaclass, 'temporary_class', (), {}) - - -def add_metaclass(metaclass): - """Class decorator for creating a class with a metaclass.""" - def wrapper(cls): - orig_vars = cls.__dict__.copy() - slots = orig_vars.get('__slots__') - if slots is not None: - if isinstance(slots, str): - slots = [slots] - for slots_var in slots: - orig_vars.pop(slots_var) - orig_vars.pop('__dict__', None) - orig_vars.pop('__weakref__', None) - if hasattr(cls, '__qualname__'): - orig_vars['__qualname__'] = cls.__qualname__ - return metaclass(cls.__name__, cls.__bases__, orig_vars) - return wrapper - - -def ensure_binary(s, encoding='utf-8', errors='strict'): - """Coerce **s** to six.binary_type. - - For Python 2: - - `unicode` -> encoded to `str` - - `str` -> `str` - - For Python 3: - - `str` -> encoded to `bytes` - - `bytes` -> `bytes` - """ - if isinstance(s, binary_type): - return s - if isinstance(s, text_type): - return s.encode(encoding, errors) - raise TypeError("not expecting type '%s'" % type(s)) - - -def ensure_str(s, encoding='utf-8', errors='strict'): - """Coerce *s* to `str`. - - For Python 2: - - `unicode` -> encoded to `str` - - `str` -> `str` - - For Python 3: - - `str` -> `str` - - `bytes` -> decoded to `str` - """ - # Optimization: Fast return for the common case. - if type(s) is str: - return s - if PY2 and isinstance(s, text_type): - return s.encode(encoding, errors) - elif PY3 and isinstance(s, binary_type): - return s.decode(encoding, errors) - elif not isinstance(s, (text_type, binary_type)): - raise TypeError("not expecting type '%s'" % type(s)) - return s - - -def ensure_text(s, encoding='utf-8', errors='strict'): - """Coerce *s* to six.text_type. - - For Python 2: - - `unicode` -> `unicode` - - `str` -> `unicode` - - For Python 3: - - `str` -> `str` - - `bytes` -> decoded to `str` - """ - if isinstance(s, binary_type): - return s.decode(encoding, errors) - elif isinstance(s, text_type): - return s - else: - raise TypeError("not expecting type '%s'" % type(s)) - - -def python_2_unicode_compatible(klass): - """ - A class decorator that defines __unicode__ and __str__ methods under Python 2. - Under Python 3 it does nothing. - - To support Python 2 and 3 with a single code base, define a __str__ method - returning text and apply this decorator to the class. - """ - if PY2: - if '__str__' not in klass.__dict__: - raise ValueError("@python_2_unicode_compatible cannot be applied " - "to %s because it doesn't define __str__()." % - klass.__name__) - klass.__unicode__ = klass.__str__ - klass.__str__ = lambda self: self.__unicode__().encode('utf-8') - return klass - - -# Complete the moves implementation. -# This code is at the end of this module to speed up module loading. -# Turn this module into a package. -__path__ = [] # required for PEP 302 and PEP 451 -__package__ = __name__ # see PEP 366 @ReservedAssignment -if globals().get("__spec__") is not None: - __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable -# Remove other six meta path importers, since they cause problems. This can -# happen if six is removed from sys.modules and then reloaded. (Setuptools does -# this for some reason.) -if sys.meta_path: - for i, importer in enumerate(sys.meta_path): - # Here's some real nastiness: Another "instance" of the six module might - # be floating around. Therefore, we can't use isinstance() to check for - # the six meta path importer, since the other six instance will have - # inserted an importer with different class. - if (type(importer).__name__ == "_SixMetaPathImporter" and - importer.name == __name__): - del sys.meta_path[i] - break - del i, importer -# Finally, add the importer to the meta path import hook. -sys.meta_path.append(_importer) diff --git a/myenv/Lib/site-packages/pip/_vendor/tenacity/__init__.py b/myenv/Lib/site-packages/pip/_vendor/tenacity/__init__.py index 4f1603a..c1b0310 100644 --- a/myenv/Lib/site-packages/pip/_vendor/tenacity/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/tenacity/__init__.py @@ -501,7 +501,7 @@ def retry(func: WrappedFn) -> WrappedFn: @t.overload def retry( - sleep: t.Callable[[t.Union[int, float]], None] = sleep, + sleep: t.Callable[[t.Union[int, float]], t.Optional[t.Awaitable[None]]] = sleep, stop: "StopBaseT" = stop_never, wait: "WaitBaseT" = wait_none(), retry: "RetryBaseT" = retry_if_exception_type(), diff --git a/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-311.pyc index a3f92e704034748ded53dc0be57eb7aefa4c297e..0b0a65e28da9f05fbcea9ee176acfa9411834fb7 100644 GIT binary patch delta 199 zcmZpB%y{}SBkyuvUM>b8a6Q?VrZ$mRl8J$RqecX)S}JQ+3`iUVfb3WZi-949Q4+>v zkYtz~z$P-ekF}LOE+rbMDt@vQ+d=t++{CCvMut@DBDNHUl%$-b+~lZaMuv2Tl;lN> zQ7M~$vAu|AOx^rAjgN`@7N=u*VrEHVQcmjRj~V4$vWyH2K*UfiwYexWosG#ac=GLh hFVVm?Q9Bs-a365FV&Qp3*Xx3q*A;H>%{m29i~y^FH!T1F delta 134 zcmX^8n6d3KBkyuvUM>b8a6Z(R#ygQ$lIaTDMvVy8$@~g@lXtPUvd5-Gr?O_nO?G2D zC?B7j5S75lkZN7Tmco#dl#`g76qUrtkj{{jyofO>d9xb(i+IMA&HU+nOp`S-%eiD2 l85n?wp_pg$%FJ{&CR3})LIqyzAs569uW%b}E-Z**1ORxMCkFrk diff --git a/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_asyncio.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_asyncio.cpython-311.pyc index a498ddd52caa1047e73ea15c6de42258e8ae38f6..18ac5104c0a1bc9f951238384aea78742e51928d 100644 GIT binary patch delta 19 ZcmeyS@lAtkIWI340}!~L+{l$90suU}1zP|B delta 19 ZcmeyS@lAtkIWI340}wbL+Q^k70suUa1yTS2 diff --git a/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-311.pyc index 86cf0fb41d2ef1d305620b485386ffd136ab67e0..dd11e659d6f62aaa44e3fc0d5e258beddc127b65 100644 GIT binary patch delta 19 ZcmbOvGD(DMIWI340}!~L+{nej1pq5G1N{I1 delta 19 ZcmbOvGD(DMIWI340}wbL+Q`Mh1pq4s1M~m@ diff --git a/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-311.pyc index 4bf44169b83c47e711ee1487bd8cd3142cf8e6e4..2477568644b438f3ef6f647ef3f282425eb90386 100644 GIT binary patch delta 19 ZcmaFM`<9n$IWI340}!~L+{pEq4FEXB1$+Pi delta 19 ZcmaFM`<9n$IWI340}wbL+Q{{o4FEWn1#>++1jGOU delta 19 Zcmca6bWMnBIWI340}wbL+Q{X@2>>+N1iJtL diff --git a/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-311.pyc index ab80db5fb685c8300363230b15284e72bdbdcc20..002eae17b1a7bde0c7510791c760310aecbf8eb1 100644 GIT binary patch delta 19 ZcmZ3>vzCWzIWI340}!~L+{mTO1^_N21Udi! delta 19 ZcmZ3>vzCWzIWI340}wbL+Q_BM1^_Me1Tg>r diff --git a/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/retry.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/retry.cpython-311.pyc index f4e133f18d0881535f289b0e257e3e5398a9710b..248c3d787c19692bf312ed5067a20d4cdf18650e 100644 GIT binary patch delta 19 ZcmcawbG3$RIWI340}!~L+{oo^2LMAW1CW0su1R1o!{| diff --git a/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-311.pyc index f87cbcf02007827eb1ff7206bebf47414dccaa06..d16c0aabafe37e7798cb1a6f56e83bfc1026d181 100644 GIT binary patch delta 19 ZcmaDa_Fjx@IWI340}!~L+{l&64FEYv1sMPU delta 19 ZcmaDa_Fjx@IWI340}wbL+Q^m44FEYA1rPuL diff --git a/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-311.pyc index f70d2b65dcaba76d3a14f91d3839de73692a8359..7be757fbbb334f9cfd093dff9c5ed6f10fc9a3d3 100644 GIT binary patch delta 19 ZcmZq4XvyGO&dbZi00gclH*) diff --git a/myenv/Lib/site-packages/pip/_vendor/tomli/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tomli/__pycache__/__init__.cpython-311.pyc index b6a886c58021d78ba037ca45bcc380c0a48f6fb2..46e426cdcf66620c5b9cdf0f9f385673e0b99194 100644 GIT binary patch delta 19 ZcmZ3*yo#A?IWI340}!~L+{m?n5dbZE1eyQ< delta 19 ZcmZ3*yo#A?IWI340}wbL+Q_wl5dbYq1d#v$ diff --git a/myenv/Lib/site-packages/pip/_vendor/tomli/__pycache__/_parser.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tomli/__pycache__/_parser.cpython-311.pyc index 874aefed53655abfbe1654c374ab1d50f1c6890d..85fa945350ff16b6efd89cbe186fa0b62e922d29 100644 GIT binary patch delta 21 bcmbREk#XWjMy}<&yj%=G;CgZ+S9=8jPJ#xc delta 21 bcmbREk#XWjMy}<&yj%=G;CyH!S9=8jPE!V( diff --git a/myenv/Lib/site-packages/pip/_vendor/tomli/__pycache__/_re.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tomli/__pycache__/_re.cpython-311.pyc index e04c17162f541a8e82449e034915e4d247865a4d..b806c132168275689beffd473c6d5aac44f4584a 100644 GIT binary patch delta 19 ZcmbQKJX4u#IWI340}!~L+{o202mmic1h)VH delta 19 ZcmbQKJX4u#IWI340}wbL+Q`)}2mmh?1g-!8 diff --git a/myenv/Lib/site-packages/pip/_vendor/tomli/__pycache__/_types.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/tomli/__pycache__/_types.cpython-311.pyc index bdc629eaab112e3a1ea0c0ff6ee37b35a9b08afe..32d6945d30c2a673cb57f69ce67d8385676f65a9 100644 GIT binary patch delta 19 ZcmZ3)yoi}=IWI340}!~L+{iV95dbVo1cCqn delta 19 ZcmZ3)yoi}=IWI340}wbL+Q>D75dbV31bF}e diff --git a/myenv/Lib/site-packages/pip/_vendor/truststore/__init__.py b/myenv/Lib/site-packages/pip/_vendor/truststore/__init__.py index 59930f4..8636814 100644 --- a/myenv/Lib/site-packages/pip/_vendor/truststore/__init__.py +++ b/myenv/Lib/site-packages/pip/_vendor/truststore/__init__.py @@ -10,4 +10,4 @@ del _api, _sys # type: ignore[name-defined] # noqa: F821 __all__ = ["SSLContext", "inject_into_ssl", "extract_from_ssl"] -__version__ = "0.8.0" +__version__ = "0.9.1" diff --git a/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/__init__.cpython-311.pyc index c921a2f63d265165e548943c4648dc56d1d5f7ab..9333f84ae79ca47570d1945d045ffe6f5c408915 100644 GIT binary patch delta 28 icmZ3^x}243IWI340}!~L+{op~$ZV-+xY>^}k`Vx0O$IOk delta 28 icmZ3^x}243IWI340}wbL+Q{X|$ZVl!u-T6>k`Vw~zXl}$ diff --git a/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_api.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_api.cpython-311.pyc index 0868e3ad505339f400f5c300b0d33e10b8ba0231..dd0dd302f40a0b486e986af22ee8a7954d305211 100644 GIT binary patch delta 3045 zcmb7G3s79u89wLUyUXtK*adcZWN{zB5(omJp)oOpjDV!m0c{|!?u@fV?ge+Vk9h7i zCa`gd!4|bmWKJE?s)L#kD5;IzOdDS@w(6v|W)^10FgwxW*mlNFo!Ly|Om%ehKlcJ5 z3Ceip-v9oO@Bi*O|9RZ|uLtq5M{v%G>}(T)cKctC^nOq|l2gR}gd3^6#e+l~)O+8$F$Q7;ur8P#%JJre%w97_;qt4n zk$258%aV{m1?OJ%NV-5CqhXEcMI>ef^Fvmz6(h+e74&ByB%wf|76;u{yr7~RVg=X6 zyhXqbu1YOKS|u79L0zQP1?&r4eX5rZVq2_4OIpk^vK+BM%p4NDH^DOto(>LeMPl|4 z5_6=?aUP*5xV7eWN#Jzga200!PccH4nxP@EKV^@5u?hB0T;>{U-2D~}`TXPSG z+i6bTi+C%2J?|CV8sDFPn8RK1FKs{Na3sF7XcFT?e^_P5_)%J7|1W-=8cROLPti|H zKE%(^zu$BTkI_lT%lHM_<9rp5Q>W{Xc#^*FI$C%Vx+xn$45G9il{iP&kqWTr*Den= zmo^l<#Nq}uKD&KaV*9RZ!j{u441u7uFKI5OjCVmj~qcv?bx6FkVdZEmL zU!mK|d=41`lN@37A^SkcY@xbbq=Y#%;92@<*{|>b9VoBHf2JqOcNg}v;Qs5;8sZ(= z>^bC)L9l;SS66#WB&^ z>N1?B_g3#NJi?f6sJw=_LWP@;;Qv#4^8lvQT;ni)$~(K9t8 z?#EZ?nT8eUFKVB}qtsnz$0oYDZp1yhLY{`riD#~T5XTe%r}Qu{ibTi&%VblWGHq|~ z+9?qk>O|P&5jFv-j61c;5w&PXRiF}DU;^u zh=>wVI~Zi(iXtY}^_81%!(!Ms$gE?o+9`5~R zAZaX4>lPp??lO<`wjp1dV_pN&XASvggz6>u+S+4Kp(nB+4|Biu>^N_!a z^_;ChIHm3Gi}v+1_Vv@X_6iwLHmoYh97G9or*@sOJ|uHq@|&6F|1abyahSro$LF+Dy5dIjPcg0yjRP0O|@pV*WI=ah^Nh+NiYqa zq=J6Fu@;}FmA4LbD(s^;-=f?&Fiyd(wS&CEzPR%(iUR6y2s5L66rbd-{b|8SD6eK>=X7pEGPi+#yt%caf*c1(%CI-st@K7nh&;>E*xpU?@&TEgVCGr+ zqo#*5$C!GIiE(?XTya z^E>Jc~g8TN7OH2 zlWAE^VE$CBW7^x!J-L7w9KW{F0)Y98C8QSAeaE2AfM9eTVZ znw{a}@Ef$xd=fX(GRt{fAH8FFm&2>08?x7NxHEcr-Z6{^qrv&P7=J*w<=(@)X?NZ) zcpqJte+%!YH3c{EL7HVhhd-g;+b`fz`eET2JWlHzyK;`R+GGQRL6p!VL+Uo3xY^9d z(bE-H`p~h`@)s+bMQ`gBXo#NBkvS%ANw zUpu`83JV_Nhzp4CFp%Ne6c&;^a3qNrX`AaK9HD=>%JCJNTij~vhhXn)c9Ly;(N>m@aF3aCl= z23=ix0B@&>QoC?#TEMX#%=ZB1PF52PKLg=?25fs8sdGUN-a(fxu;Jh6ngt_{9si?| zcgFiv{9*) zC0{r3E4|*J)FTBSf=mwswYWq@0p3H?EAuc%7gmlq_CWL*518Z%^xw*T`TJm@?8g@B zk%+&&*Bc6pQYtRgl|A&>|vpE zB*!L=0v+Vhh@gOW+SWwy3C$R5jx!AsBT>tmoj{Mhx+yzu?O-omcc*$s{F3PPZD{j% z(ltv7?OR-g%jki{E>E#n4flGxB#HPWqR5p?f?;1X^BDI!fHMbXn!Vd6q-qPcg3ZCEtxQEjbI$3UCUt z91O1y#4~1B88<>L-u1nTB+Kx~g)oxWq6*RhY*5t&X0ZNhLiy!`jR{VpP5aTDv)4UQ zR5NK_M88_LqKd@~>DTqnYkKFTzBr~Yp3s+%n-e_JX0Zb`ufb4seKW(!%$8VY3(Z{K z;3y(+4sm@~uuW+XlMp!wt6BiY0luXD%eSW-26GhPC{3@c(~(cXUPQa=#ZFke5`Xfz~*5?yEI2u-7bzOR0 TwQp+;2`%#_*nZ3j>YvVkxy3HU diff --git a/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_macos.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_macos.cpython-311.pyc index eeaa02f61a1816c6694629a873f185897d360073..695b9528daf376ab7e8efa7cfea47af6b2201446 100644 GIT binary patch delta 1372 zcmZ`$T})eb6u;+wx6sy=mP={7+tC62xNSGE%b+mp+}M!fVE8f0X4$-#nvURBh>2Rl zz7n_j5x0|&7>U8B`J$2B2Te>gF+PYfT3i!-(HI|mQe)z~@&CVgVdDHJ_uTXQIOl)P zy{}z|4_^lN9hb|=kaKkX^_ee@+;X>pd#(Et$L%ize!?k2uMw&o!e%~*e{vd5@FB?K z1zsU>n)BfbAHe7M6#mR7I}hvL;v+_^3`V$egtnxoba3;{FuKKKp7*s|mZP??Z85qr zEhuW-kc~*0BW;H6<4NJPpx}FgjF$zUAQRUy{8~`qIQ}juB(91+CuyKs4TkY2*3X42 z!#F1fFe>^4l@vT`p(hA(5i~+d_WKL>xhjn-VjKP?I&gz{GsHWJ5h>XF*nhp&cH4ZP z?J&~TvL|p(QgA}@N626-X*6aV?%AFWGlsuP0enZ=9CX}5cL_=n?IhieU7fhK(Spb1 zR?p*h50)`pl?j}c!+1t^;B9#jp2WJGS$fKL=xqjH*+xzGq8V8aT;q$Uj8o)S=k1Ep zq@7v(fQ@$Wga5-nOnH%p(j?A0_AC|kkTIn<8QKi5hskxP|G^yu?Tha6^#(&6g4b8RrnyS|fqzLk4E$bQthA?F)% zzAop@o7rzzm@$h73jm9Fr|$|}!9@Sb)@qIPug=qOfrb}oxQd_kzbP)!^fI2!y#mYl zTQ2NeCj^jZe%%LSe^YFT(%}d*@OtX}NT1q1-G|7HG9dyCC!LCM#01yV$e= zSu06tjVAV_CMGpDeb5IJ1DOX&e6Si{^rcWqT8%b7_@)m&`QU@`pKWKU;GfKy^PTTI z=RarWpZVe%yt@XDPwn;t3|+n7yqBu(d*4w7T^qrI3D0mIh~ok$NpYRlSF-)dongqK zG~i=Xv$dKurdi_49LLX15}x2(Xy<%*k!!@WoEv)dd}^mnB7Ve0_+GVQ@+AJlc?1=R zoaw_qIJeku6ipsAJQBoFUMdR{3#mz)sB!@BnI(C^;Gb!vkt$fK7{mo$f~rLQa+;}X1b-5|;_3aY3fN_?5{es+V!0q;&g_z#h*BIXu|I*>@vixhqPIR) zVs~4Q7AuYGj|-^fUF@9+taZAOwTO*pj0Bb;_RNHVh^)FkVHxH#dOcZ0PM*b+mOgk1 zZ&;dFUN+)t72z_wsO(vkvZ(G=Zt@&CM~}k^BO^I!c*S^^f%e3E_QzRffKffGjOxWv ztF!hM)kmh(G7?L1s!aDe{}k6zTut!>ELg>3Nwt!Y7nZQ zm@=~^q)(#a18caQSQ#~}HvEST?5PIEICA0_Cv8s?5!x zjN4%meGwVW5fMisogmh{(ds$9h$-j8>qQK&as;g+5GQ}|c3 z5dy^%=!-aUAm%`SOrOY&Z^vQ~!u6Qq3>zhv97`3+i1s-40SH+;jrQY}rYVSO51Zyd zOSQOI{uYg9w3XH&7Hs(4;egv}Jr0k&%G&UsEN}1pMd{e=*jD;?lzz0dO-lk}7a!VM zAJ|&g+cxXBZQVPz?k!ulw$gT=g|v41=rF(%-fq7NZ=upLhCMCyb>-t^b|Sl&%lEx8 zGq*UCC)pg`G`pai%euLW*E&8F-qhU!20Gsf=}l$z|5#T4MP+@|{B7xa{i3=!N8;J< zDFk}ue$#&Jyw1X9oQ+>^h_tO=TEDc_o!CAywsT}`D?DBp+~MRMF7PPS^3-k6evglu UwEmtHlnqxV4l>&ZD-wRwzk2m8SO5S3 diff --git a/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_openssl.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_openssl.cpython-311.pyc index c100994a7070ca4f8dc9fe2b324fcb4098417f9a..ecc1a6069bc70e46b862258a71bcc8cd9914a048 100644 GIT binary patch delta 19 ZcmdlXv_pt%IWI340}!~L+{mTJ2>>vZ1Zn^P delta 19 ZcmdlXv_pt%IWI340}wbL+Q_BH2>>u<1YrOG diff --git a/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_ssl_constants.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_ssl_constants.cpython-311.pyc index 0fb5f4d691471e721d9f2d77b633dae66e8a5856..e445c08b4327d1bcaf5622d82d2f4c63aed4f5a5 100644 GIT binary patch delta 19 ZcmaFQ@t%WgIWI340}!~L+{l&60suE<1oi*` delta 19 ZcmaFQ@t%WgIWI340}wbL+Q^m40suEQ1nmF- diff --git a/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_windows.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_windows.cpython-311.pyc index f3a3bc9800cd8d220527fc3355ff8351698388c8..15e04a3128e9a419b395211a869ca27a69ba9fd4 100644 GIT binary patch delta 1769 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 QWT~!PeV3xz8*eB70l{iYA^-pY diff --git a/myenv/Lib/site-packages/pip/_vendor/truststore/_api.py b/myenv/Lib/site-packages/pip/_vendor/truststore/_api.py index 829aff7..b1ea3b0 100644 --- a/myenv/Lib/site-packages/pip/_vendor/truststore/_api.py +++ b/myenv/Lib/site-packages/pip/_vendor/truststore/_api.py @@ -2,9 +2,10 @@ import platform import socket import ssl +import sys import typing -import _ssl # type: ignore[import] +import _ssl # type: ignore[import-not-found] from ._ssl_constants import ( _original_SSLContext, @@ -49,7 +50,7 @@ def extract_from_ssl() -> None: try: import pip._vendor.urllib3.util.ssl_ as urllib3_ssl - urllib3_ssl.SSLContext = _original_SSLContext + urllib3_ssl.SSLContext = _original_SSLContext # type: ignore[assignment] except ImportError: pass @@ -171,16 +172,13 @@ def cert_store_stats(self) -> dict[str, int]: @typing.overload def get_ca_certs( self, binary_form: typing.Literal[False] = ... - ) -> list[typing.Any]: - ... + ) -> list[typing.Any]: ... @typing.overload - def get_ca_certs(self, binary_form: typing.Literal[True] = ...) -> list[bytes]: - ... + def get_ca_certs(self, binary_form: typing.Literal[True] = ...) -> list[bytes]: ... @typing.overload - def get_ca_certs(self, binary_form: bool = ...) -> typing.Any: - ... + def get_ca_certs(self, binary_form: bool = ...) -> typing.Any: ... def get_ca_certs(self, binary_form: bool = False) -> list[typing.Any] | list[bytes]: raise NotImplementedError() @@ -276,6 +274,25 @@ def verify_mode(self, value: ssl.VerifyMode) -> None: ) +# Python 3.13+ makes get_unverified_chain() a public API that only returns DER +# encoded certificates. We detect whether we need to call public_bytes() for 3.10->3.12 +# Pre-3.13 returned None instead of an empty list from get_unverified_chain() +if sys.version_info >= (3, 13): + + def _get_unverified_chain_bytes(sslobj: ssl.SSLObject) -> list[bytes]: + unverified_chain = sslobj.get_unverified_chain() or () # type: ignore[attr-defined] + return [ + cert if isinstance(cert, bytes) else cert.public_bytes(_ssl.ENCODING_DER) + for cert in unverified_chain + ] + +else: + + def _get_unverified_chain_bytes(sslobj: ssl.SSLObject) -> list[bytes]: + unverified_chain = sslobj.get_unverified_chain() or () # type: ignore[attr-defined] + return [cert.public_bytes(_ssl.ENCODING_DER) for cert in unverified_chain] + + def _verify_peercerts( sock_or_sslobj: ssl.SSLSocket | ssl.SSLObject, server_hostname: str | None ) -> None: @@ -290,13 +307,7 @@ def _verify_peercerts( except AttributeError: pass - # SSLObject.get_unverified_chain() returns 'None' - # if the peer sends no certificates. This is common - # for the server-side scenario. - unverified_chain: typing.Sequence[_ssl.Certificate] = ( - sslobj.get_unverified_chain() or () # type: ignore[attr-defined] - ) - cert_bytes = [cert.public_bytes(_ssl.ENCODING_DER) for cert in unverified_chain] + cert_bytes = _get_unverified_chain_bytes(sslobj) _verify_peercerts_impl( sock_or_sslobj.context, cert_bytes, server_hostname=server_hostname ) diff --git a/myenv/Lib/site-packages/pip/_vendor/truststore/_macos.py b/myenv/Lib/site-packages/pip/_vendor/truststore/_macos.py index 7dc440b..b234ffe 100644 --- a/myenv/Lib/site-packages/pip/_vendor/truststore/_macos.py +++ b/myenv/Lib/site-packages/pip/_vendor/truststore/_macos.py @@ -96,9 +96,6 @@ def _load_cdll(name: str, macos10_16_path: str) -> CDLL: Security.SecTrustSetAnchorCertificatesOnly.argtypes = [SecTrustRef, Boolean] Security.SecTrustSetAnchorCertificatesOnly.restype = OSStatus - Security.SecTrustEvaluate.argtypes = [SecTrustRef, POINTER(SecTrustResultType)] - Security.SecTrustEvaluate.restype = OSStatus - Security.SecPolicyCreateRevocation.argtypes = [CFOptionFlags] Security.SecPolicyCreateRevocation.restype = SecPolicyRef @@ -259,6 +256,7 @@ def _handle_osstatus(result: OSStatus, _: typing.Any, args: typing.Any) -> typin Security.SecTrustCreateWithCertificates.errcheck = _handle_osstatus # type: ignore[assignment] Security.SecTrustSetAnchorCertificates.errcheck = _handle_osstatus # type: ignore[assignment] +Security.SecTrustSetAnchorCertificatesOnly.errcheck = _handle_osstatus # type: ignore[assignment] Security.SecTrustGetTrustResult.errcheck = _handle_osstatus # type: ignore[assignment] @@ -417,21 +415,21 @@ def _verify_peercerts_impl( CoreFoundation.CFRelease(certs) # If there are additional trust anchors to load we need to transform - # the list of DER-encoded certificates into a CFArray. Otherwise - # pass 'None' to signal that we only want system / fetched certificates. + # the list of DER-encoded certificates into a CFArray. ctx_ca_certs_der: list[bytes] | None = ssl_context.get_ca_certs( binary_form=True ) if ctx_ca_certs_der: ctx_ca_certs = None try: - ctx_ca_certs = _der_certs_to_cf_cert_array(cert_chain) + ctx_ca_certs = _der_certs_to_cf_cert_array(ctx_ca_certs_der) Security.SecTrustSetAnchorCertificates(trust, ctx_ca_certs) finally: if ctx_ca_certs: CoreFoundation.CFRelease(ctx_ca_certs) - else: - Security.SecTrustSetAnchorCertificates(trust, None) + + # We always want system certificates. + Security.SecTrustSetAnchorCertificatesOnly(trust, False) cf_error = CoreFoundation.CFErrorRef() sec_trust_eval_result = Security.SecTrustEvaluateWithError( diff --git a/myenv/Lib/site-packages/pip/_vendor/truststore/_windows.py b/myenv/Lib/site-packages/pip/_vendor/truststore/_windows.py index 3de4960..3d00d46 100644 --- a/myenv/Lib/site-packages/pip/_vendor/truststore/_windows.py +++ b/myenv/Lib/site-packages/pip/_vendor/truststore/_windows.py @@ -325,6 +325,12 @@ def _verify_peercerts_impl( server_hostname: str | None = None, ) -> None: """Verify the cert_chain from the server using Windows APIs.""" + + # If the peer didn't send any certificates then + # we can't do verification. Raise an error. + if not cert_chain: + raise ssl.SSLCertVerificationError("Peer sent no certificates to verify") + pCertContext = None hIntermediateCertStore = CertOpenStore(CERT_STORE_PROV_MEMORY, 0, None, 0, None) try: @@ -375,7 +381,7 @@ def _verify_peercerts_impl( server_hostname, chain_flags=chain_flags, ) - except ssl.SSLCertVerificationError: + except ssl.SSLCertVerificationError as e: # If that fails but custom CA certs have been added # to the SSLContext using load_verify_locations, # try verifying using a custom chain engine @@ -384,15 +390,19 @@ def _verify_peercerts_impl( binary_form=True ) if custom_ca_certs: - _verify_using_custom_ca_certs( - ssl_context, - custom_ca_certs, - hIntermediateCertStore, - pCertContext, - pChainPara, - server_hostname, - chain_flags=chain_flags, - ) + try: + _verify_using_custom_ca_certs( + ssl_context, + custom_ca_certs, + hIntermediateCertStore, + pCertContext, + pChainPara, + server_hostname, + chain_flags=chain_flags, + ) + # Raise the original error, not the new error. + except ssl.SSLCertVerificationError: + raise e from None else: raise finally: diff --git a/myenv/Lib/site-packages/pip/_vendor/typing_extensions.py b/myenv/Lib/site-packages/pip/_vendor/typing_extensions.py index 4f93acf..d60315a 100644 --- a/myenv/Lib/site-packages/pip/_vendor/typing_extensions.py +++ b/myenv/Lib/site-packages/pip/_vendor/typing_extensions.py @@ -60,6 +60,7 @@ 'clear_overloads', 'dataclass_transform', 'deprecated', + 'Doc', 'get_overloads', 'final', 'get_args', @@ -82,9 +83,11 @@ 'TypeAlias', 'TypeAliasType', 'TypeGuard', + 'TypeIs', 'TYPE_CHECKING', 'Never', 'NoReturn', + 'ReadOnly', 'Required', 'NotRequired', @@ -144,27 +147,6 @@ def __repr__(self): _marker = _Sentinel() -def _check_generic(cls, parameters, elen=_marker): - """Check correct count for parameters of a generic cls (internal helper). - This gives a nice error message in case of count mismatch. - """ - if not elen: - raise TypeError(f"{cls} is not a generic class") - if elen is _marker: - if not hasattr(cls, "__parameters__") or not cls.__parameters__: - raise TypeError(f"{cls} is not a generic class") - elen = len(cls.__parameters__) - alen = len(parameters) - if alen != elen: - if hasattr(cls, "__parameters__"): - parameters = [p for p in cls.__parameters__ if not _is_unpack(p)] - num_tv_tuples = sum(isinstance(p, TypeVarTuple) for p in parameters) - if (num_tv_tuples > 0) and (alen >= elen - num_tv_tuples): - return - raise TypeError(f"Too {'many' if alen > elen else 'few'} parameters for {cls};" - f" actual {alen}, expected {elen}") - - if sys.version_info >= (3, 10): def _should_collect_from_parameters(t): return isinstance( @@ -178,27 +160,6 @@ def _should_collect_from_parameters(t): return isinstance(t, typing._GenericAlias) and not t._special -def _collect_type_vars(types, typevar_types=None): - """Collect all type variable contained in types in order of - first appearance (lexicographic order). For example:: - - _collect_type_vars((T, List[S, T])) == (T, S) - """ - if typevar_types is None: - typevar_types = typing.TypeVar - tvars = [] - for t in types: - if ( - isinstance(t, typevar_types) and - t not in tvars and - not _is_unpack(t) - ): - tvars.append(t) - if _should_collect_from_parameters(t): - tvars.extend([t for t in t.__parameters__ if t not in tvars]) - return tuple(tvars) - - NoReturn = typing.NoReturn # Some unconstrained type variables. These are used by the container types. @@ -248,32 +209,7 @@ def __repr__(self): return 'typing_extensions.' + self._name -# On older versions of typing there is an internal class named "Final". -# 3.8+ -if hasattr(typing, 'Final') and sys.version_info[:2] >= (3, 7): - Final = typing.Final -# 3.7 -else: - class _FinalForm(_ExtensionsSpecialForm, _root=True): - def __getitem__(self, parameters): - item = typing._type_check(parameters, - f'{self._name} accepts only a single type.') - return typing._GenericAlias(self, (item,)) - - Final = _FinalForm('Final', - doc="""A special typing construct to indicate that a name - cannot be re-assigned or overridden in a subclass. - For example: - - MAX_SIZE: Final = 9000 - MAX_SIZE += 1 # Error reported by type checker - - class Connection: - TIMEOUT: Final[int] = 10 - class FastConnector(Connection): - TIMEOUT = 1 # Error reported by type checker - - There is no runtime checking of these properties.""") +Final = typing.Final if sys.version_info >= (3, 11): final = typing.final @@ -465,8 +401,6 @@ def clear_overloads(): # Various ABCs mimicking those in collections.abc. # A few are simply re-exported for completeness. - - Awaitable = typing.Awaitable Coroutine = typing.Coroutine AsyncIterable = typing.AsyncIterable @@ -475,14 +409,7 @@ def clear_overloads(): ContextManager = typing.ContextManager AsyncContextManager = typing.AsyncContextManager DefaultDict = typing.DefaultDict - -# 3.7.2+ -if hasattr(typing, 'OrderedDict'): - OrderedDict = typing.OrderedDict -# 3.7.0-3.7.2 -else: - OrderedDict = typing._alias(collections.OrderedDict, (KT, VT)) - +OrderedDict = typing.OrderedDict Counter = typing.Counter ChainMap = typing.ChainMap AsyncGenerator = typing.AsyncGenerator @@ -505,15 +432,10 @@ def clear_overloads(): "_is_runtime_protocol", "__dict__", "__slots__", "__parameters__", "__orig_bases__", "__module__", "_MutableMapping__marker", "__doc__", "__subclasshook__", "__orig_class__", "__init__", "__new__", - "__protocol_attrs__", "__callable_proto_members_only__", + "__protocol_attrs__", "__non_callable_proto_members__", + "__match_args__", } -if sys.version_info < (3, 8): - _EXCLUDED_ATTRS |= { - "_gorg", "__next_in_mro__", "__extra__", "__tree_hash__", "__args__", - "__origin__" - } - if sys.version_info >= (3, 9): _EXCLUDED_ATTRS.add("__class_getitem__") @@ -535,46 +457,6 @@ def _get_protocol_attrs(cls): return attrs -def _maybe_adjust_parameters(cls): - """Helper function used in Protocol.__init_subclass__ and _TypedDictMeta.__new__. - - The contents of this function are very similar - to logic found in typing.Generic.__init_subclass__ - on the CPython main branch. - """ - tvars = [] - if '__orig_bases__' in cls.__dict__: - tvars = _collect_type_vars(cls.__orig_bases__) - # Look for Generic[T1, ..., Tn] or Protocol[T1, ..., Tn]. - # If found, tvars must be a subset of it. - # If not found, tvars is it. - # Also check for and reject plain Generic, - # and reject multiple Generic[...] and/or Protocol[...]. - gvars = None - for base in cls.__orig_bases__: - if (isinstance(base, typing._GenericAlias) and - base.__origin__ in (typing.Generic, Protocol)): - # for error messages - the_base = base.__origin__.__name__ - if gvars is not None: - raise TypeError( - "Cannot inherit from Generic[...]" - " and/or Protocol[...] multiple types.") - gvars = base.__parameters__ - if gvars is None: - gvars = tvars - else: - tvarset = set(tvars) - gvarset = set(gvars) - if not tvarset <= gvarset: - s_vars = ', '.join(str(t) for t in tvars if t not in gvarset) - s_args = ', '.join(str(g) for g in gvars) - raise TypeError(f"Some type variables ({s_vars}) are" - f" not listed in {the_base}[{s_args}]") - tvars = gvars - cls.__parameters__ = tuple(tvars) - - def _caller(depth=2): try: return sys._getframe(depth).f_globals.get('__name__', '__main__') @@ -582,9 +464,9 @@ def _caller(depth=2): return None -# The performance of runtime-checkable protocols is significantly improved on Python 3.12, -# so we backport the 3.12 version of Protocol to Python <=3.11 -if sys.version_info >= (3, 12): +# `__match_args__` attribute was removed from protocol members in 3.13, +# we want to backport this change to older Python versions. +if sys.version_info >= (3, 13): Protocol = typing.Protocol else: def _allow_reckless_class_checks(depth=3): @@ -598,17 +480,26 @@ def _no_init(self, *args, **kwargs): if type(self)._is_protocol: raise TypeError('Protocols cannot be instantiated') - if sys.version_info >= (3, 8): - # Inheriting from typing._ProtocolMeta isn't actually desirable, - # but is necessary to allow typing.Protocol and typing_extensions.Protocol - # to mix without getting TypeErrors about "metaclass conflict" - _typing_Protocol = typing.Protocol - _ProtocolMetaBase = type(_typing_Protocol) - else: - _typing_Protocol = _marker - _ProtocolMetaBase = abc.ABCMeta + def _type_check_issubclass_arg_1(arg): + """Raise TypeError if `arg` is not an instance of `type` + in `issubclass(arg, )`. - class _ProtocolMeta(_ProtocolMetaBase): + In most cases, this is verified by type.__subclasscheck__. + Checking it again unnecessarily would slow down issubclass() checks, + so, we don't perform this check unless we absolutely have to. + + For various error paths, however, + we want to ensure that *this* error message is shown to the user + where relevant, rather than a typing.py-specific error message. + """ + if not isinstance(arg, type): + # Same error message as for issubclass(1, int). + raise TypeError('issubclass() arg 1 must be a class') + + # Inheriting from typing._ProtocolMeta isn't actually desirable, + # but is necessary to allow typing.Protocol and typing_extensions.Protocol + # to mix without getting TypeErrors about "metaclass conflict" + class _ProtocolMeta(type(typing.Protocol)): # This metaclass is somewhat unfortunate, # but is necessary for several reasons... # @@ -618,10 +509,10 @@ class _ProtocolMeta(_ProtocolMetaBase): def __new__(mcls, name, bases, namespace, **kwargs): if name == "Protocol" and len(bases) < 2: pass - elif {Protocol, _typing_Protocol} & set(bases): + elif {Protocol, typing.Protocol} & set(bases): for base in bases: if not ( - base in {object, typing.Generic, Protocol, _typing_Protocol} + base in {object, typing.Generic, Protocol, typing.Protocol} or base.__name__ in _PROTO_ALLOWLIST.get(base.__module__, []) or is_protocol(base) ): @@ -635,11 +526,6 @@ def __init__(cls, *args, **kwargs): abc.ABCMeta.__init__(cls, *args, **kwargs) if getattr(cls, "_is_protocol", False): cls.__protocol_attrs__ = _get_protocol_attrs(cls) - # PEP 544 prohibits using issubclass() - # with protocols that have non-method members. - cls.__callable_proto_members_only__ = all( - callable(getattr(cls, attr, None)) for attr in cls.__protocol_attrs__ - ) def __subclasscheck__(cls, other): if cls is Protocol: @@ -648,21 +534,23 @@ def __subclasscheck__(cls, other): getattr(cls, '_is_protocol', False) and not _allow_reckless_class_checks() ): - if not isinstance(other, type): - # Same error message as for issubclass(1, int). - raise TypeError('issubclass() arg 1 must be a class') - if ( - not cls.__callable_proto_members_only__ - and cls.__dict__.get("__subclasshook__") is _proto_hook - ): - raise TypeError( - "Protocols with non-method members don't support issubclass()" - ) if not getattr(cls, '_is_runtime_protocol', False): + _type_check_issubclass_arg_1(other) raise TypeError( "Instance and class checks can only be used with " "@runtime_checkable protocols" ) + if ( + # this attribute is set by @runtime_checkable: + cls.__non_callable_proto_members__ + and cls.__dict__.get("__subclasshook__") is _proto_hook + ): + _type_check_issubclass_arg_1(other) + non_method_attrs = sorted(cls.__non_callable_proto_members__) + raise TypeError( + "Protocols with non-method members don't support issubclass()." + f" Non-method members: {str(non_method_attrs)[1:-1]}." + ) return abc.ABCMeta.__subclasscheck__(cls, other) def __instancecheck__(cls, instance): @@ -689,7 +577,8 @@ def __instancecheck__(cls, instance): val = inspect.getattr_static(instance, attr) except AttributeError: break - if val is None and callable(getattr(cls, attr, None)): + # this attribute is set by @runtime_checkable: + if val is None and attr not in cls.__non_callable_proto_members__: break else: return True @@ -699,12 +588,10 @@ def __instancecheck__(cls, instance): def __eq__(cls, other): # Hack so that typing.Generic.__class_getitem__ # treats typing_extensions.Protocol - # as equivalent to typing.Protocol on Python 3.8+ + # as equivalent to typing.Protocol if abc.ABCMeta.__eq__(cls, other) is True: return True - return ( - cls is Protocol and other is getattr(typing, "Protocol", object()) - ) + return cls is Protocol and other is typing.Protocol # This has to be defined, or the abc-module cache # complains about classes with this metaclass being unhashable, @@ -737,146 +624,83 @@ def _proto_hook(cls, other): return NotImplemented return True - if sys.version_info >= (3, 8): - class Protocol(typing.Generic, metaclass=_ProtocolMeta): - __doc__ = typing.Protocol.__doc__ - __slots__ = () - _is_protocol = True - _is_runtime_protocol = False - - def __init_subclass__(cls, *args, **kwargs): - super().__init_subclass__(*args, **kwargs) + class Protocol(typing.Generic, metaclass=_ProtocolMeta): + __doc__ = typing.Protocol.__doc__ + __slots__ = () + _is_protocol = True + _is_runtime_protocol = False - # Determine if this is a protocol or a concrete subclass. - if not cls.__dict__.get('_is_protocol', False): - cls._is_protocol = any(b is Protocol for b in cls.__bases__) + def __init_subclass__(cls, *args, **kwargs): + super().__init_subclass__(*args, **kwargs) - # Set (or override) the protocol subclass hook. - if '__subclasshook__' not in cls.__dict__: - cls.__subclasshook__ = _proto_hook + # Determine if this is a protocol or a concrete subclass. + if not cls.__dict__.get('_is_protocol', False): + cls._is_protocol = any(b is Protocol for b in cls.__bases__) - # Prohibit instantiation for protocol classes - if cls._is_protocol and cls.__init__ is Protocol.__init__: - cls.__init__ = _no_init + # Set (or override) the protocol subclass hook. + if '__subclasshook__' not in cls.__dict__: + cls.__subclasshook__ = _proto_hook - else: - class Protocol(metaclass=_ProtocolMeta): - # There is quite a lot of overlapping code with typing.Generic. - # Unfortunately it is hard to avoid this on Python <3.8, - # as the typing module on Python 3.7 doesn't let us subclass typing.Generic! - """Base class for protocol classes. Protocol classes are defined as:: + # Prohibit instantiation for protocol classes + if cls._is_protocol and cls.__init__ is Protocol.__init__: + cls.__init__ = _no_init - class Proto(Protocol): - def meth(self) -> int: - ... - Such classes are primarily used with static type checkers that recognize - structural subtyping (static duck-typing), for example:: +if sys.version_info >= (3, 13): + runtime_checkable = typing.runtime_checkable +else: + def runtime_checkable(cls): + """Mark a protocol class as a runtime protocol. - class C: - def meth(self) -> int: - return 0 + Such protocol can be used with isinstance() and issubclass(). + Raise TypeError if applied to a non-protocol class. + This allows a simple-minded structural check very similar to + one trick ponies in collections.abc such as Iterable. - def func(x: Proto) -> int: - return x.meth() + For example:: - func(C()) # Passes static type check + @runtime_checkable + class Closable(Protocol): + def close(self): ... - See PEP 544 for details. Protocol classes decorated with - @typing_extensions.runtime_checkable act - as simple-minded runtime-checkable protocols that check - only the presence of given attributes, ignoring their type signatures. + assert isinstance(open('/some/file'), Closable) - Protocol classes can be generic, they are defined as:: + Warning: this will check only the presence of the required methods, + not their type signatures! + """ + if not issubclass(cls, typing.Generic) or not getattr(cls, '_is_protocol', False): + raise TypeError('@runtime_checkable can be only applied to protocol classes,' + ' got %r' % cls) + cls._is_runtime_protocol = True - class GenProto(Protocol[T]): - def meth(self) -> T: - ... - """ - __slots__ = () - _is_protocol = True - _is_runtime_protocol = False - - def __new__(cls, *args, **kwds): - if cls is Protocol: - raise TypeError("Type Protocol cannot be instantiated; " - "it can only be used as a base class") - return super().__new__(cls) - - @typing._tp_cache - def __class_getitem__(cls, params): - if not isinstance(params, tuple): - params = (params,) - if not params and cls is not typing.Tuple: + # Only execute the following block if it's a typing_extensions.Protocol class. + # typing.Protocol classes don't need it. + if isinstance(cls, _ProtocolMeta): + # PEP 544 prohibits using issubclass() + # with protocols that have non-method members. + # See gh-113320 for why we compute this attribute here, + # rather than in `_ProtocolMeta.__init__` + cls.__non_callable_proto_members__ = set() + for attr in cls.__protocol_attrs__: + try: + is_callable = callable(getattr(cls, attr, None)) + except Exception as e: raise TypeError( - f"Parameter list to {cls.__qualname__}[...] cannot be empty") - msg = "Parameters to generic types must be types." - params = tuple(typing._type_check(p, msg) for p in params) - if cls is Protocol: - # Generic can only be subscripted with unique type variables. - if not all(isinstance(p, typing.TypeVar) for p in params): - i = 0 - while isinstance(params[i], typing.TypeVar): - i += 1 - raise TypeError( - "Parameters to Protocol[...] must all be type variables." - f" Parameter {i + 1} is {params[i]}") - if len(set(params)) != len(params): - raise TypeError( - "Parameters to Protocol[...] must all be unique") + f"Failed to determine whether protocol member {attr!r} " + "is a method member" + ) from e else: - # Subscripting a regular Generic subclass. - _check_generic(cls, params, len(cls.__parameters__)) - return typing._GenericAlias(cls, params) - - def __init_subclass__(cls, *args, **kwargs): - if '__orig_bases__' in cls.__dict__: - error = typing.Generic in cls.__orig_bases__ - else: - error = typing.Generic in cls.__bases__ - if error: - raise TypeError("Cannot inherit from plain Generic") - _maybe_adjust_parameters(cls) - - # Determine if this is a protocol or a concrete subclass. - if not cls.__dict__.get('_is_protocol', None): - cls._is_protocol = any(b is Protocol for b in cls.__bases__) - - # Set (or override) the protocol subclass hook. - if '__subclasshook__' not in cls.__dict__: - cls.__subclasshook__ = _proto_hook + if not is_callable: + cls.__non_callable_proto_members__.add(attr) - # Prohibit instantiation for protocol classes - if cls._is_protocol and cls.__init__ is Protocol.__init__: - cls.__init__ = _no_init - - -if sys.version_info >= (3, 8): - runtime_checkable = typing.runtime_checkable -else: - def runtime_checkable(cls): - """Mark a protocol class as a runtime protocol, so that it - can be used with isinstance() and issubclass(). Raise TypeError - if applied to a non-protocol class. - - This allows a simple-minded structural check very similar to the - one-offs in collections.abc such as Hashable. - """ - if not ( - (isinstance(cls, _ProtocolMeta) or issubclass(cls, typing.Generic)) - and getattr(cls, "_is_protocol", False) - ): - raise TypeError('@runtime_checkable can be only applied to protocol classes,' - f' got {cls!r}') - cls._is_runtime_protocol = True return cls -# Exists for backwards compatibility. +# The "runtime" alias exists for backwards compatibility. runtime = runtime_checkable -# Our version of runtime-checkable protocols is faster on Python 3.7-3.11 +# Our version of runtime-checkable protocols is faster on Python 3.8-3.11 if sys.version_info >= (3, 12): SupportsInt = typing.SupportsInt SupportsFloat = typing.SupportsFloat @@ -968,7 +792,11 @@ def inner(func): return inner -if sys.version_info >= (3, 13): +# Update this to something like >=3.13.0b1 if and when +# PEP 728 is implemented in CPython +_PEP_728_IMPLEMENTED = False + +if _PEP_728_IMPLEMENTED: # The standard library TypedDict in Python 3.8 does not store runtime information # about which (if any) keys are optional. See https://bugs.python.org/issue38834 # The standard library TypedDict in Python 3.9.0/1 does not honour the "total" @@ -979,6 +807,8 @@ def inner(func): # Aaaand on 3.12 we add __orig_bases__ to TypedDict # to enable better runtime introspection. # On 3.13 we deprecate some odd ways of creating TypedDicts. + # Also on 3.13, PEP 705 adds the ReadOnly[] qualifier. + # PEP 728 (still pending) makes more changes. TypedDict = typing.TypedDict _TypedDictMeta = typing._TypedDictMeta is_typeddict = typing.is_typeddict @@ -986,13 +816,29 @@ def inner(func): # 3.10.0 and later _TAKES_MODULE = "module" in inspect.signature(typing._type_check).parameters - if sys.version_info >= (3, 8): - _fake_name = "Protocol" - else: - _fake_name = "_Protocol" + def _get_typeddict_qualifiers(annotation_type): + while True: + annotation_origin = get_origin(annotation_type) + if annotation_origin is Annotated: + annotation_args = get_args(annotation_type) + if annotation_args: + annotation_type = annotation_args[0] + else: + break + elif annotation_origin is Required: + yield Required + annotation_type, = get_args(annotation_type) + elif annotation_origin is NotRequired: + yield NotRequired + annotation_type, = get_args(annotation_type) + elif annotation_origin is ReadOnly: + yield ReadOnly + annotation_type, = get_args(annotation_type) + else: + break class _TypedDictMeta(type): - def __new__(cls, name, bases, ns, total=True): + def __new__(cls, name, bases, ns, *, total=True, closed=False): """Create new typed dict class object. This method is called when TypedDict is subclassed, @@ -1011,10 +857,10 @@ def __new__(cls, name, bases, ns, total=True): generic_base = () # typing.py generally doesn't let you inherit from plain Generic, unless - # the name of the class happens to be "Protocol" (or "_Protocol" on 3.7). - tp_dict = type.__new__(_TypedDictMeta, _fake_name, (*generic_base, dict), ns) + # the name of the class happens to be "Protocol" + tp_dict = type.__new__(_TypedDictMeta, "Protocol", (*generic_base, dict), ns) tp_dict.__name__ = name - if tp_dict.__qualname__ == _fake_name: + if tp_dict.__qualname__ == "Protocol": tp_dict.__qualname__ = name if not hasattr(tp_dict, '__orig_bases__'): @@ -1035,35 +881,67 @@ def __new__(cls, name, bases, ns, total=True): } required_keys = set() optional_keys = set() + readonly_keys = set() + mutable_keys = set() + extra_items_type = None for base in bases: - annotations.update(base.__dict__.get('__annotations__', {})) - required_keys.update(base.__dict__.get('__required_keys__', ())) - optional_keys.update(base.__dict__.get('__optional_keys__', ())) + base_dict = base.__dict__ + + annotations.update(base_dict.get('__annotations__', {})) + required_keys.update(base_dict.get('__required_keys__', ())) + optional_keys.update(base_dict.get('__optional_keys__', ())) + readonly_keys.update(base_dict.get('__readonly_keys__', ())) + mutable_keys.update(base_dict.get('__mutable_keys__', ())) + base_extra_items_type = base_dict.get('__extra_items__', None) + if base_extra_items_type is not None: + extra_items_type = base_extra_items_type + + if closed and extra_items_type is None: + extra_items_type = Never + if closed and "__extra_items__" in own_annotations: + annotation_type = own_annotations.pop("__extra_items__") + qualifiers = set(_get_typeddict_qualifiers(annotation_type)) + if Required in qualifiers: + raise TypeError( + "Special key __extra_items__ does not support " + "Required" + ) + if NotRequired in qualifiers: + raise TypeError( + "Special key __extra_items__ does not support " + "NotRequired" + ) + extra_items_type = annotation_type annotations.update(own_annotations) for annotation_key, annotation_type in own_annotations.items(): - annotation_origin = get_origin(annotation_type) - if annotation_origin is Annotated: - annotation_args = get_args(annotation_type) - if annotation_args: - annotation_type = annotation_args[0] - annotation_origin = get_origin(annotation_type) - - if annotation_origin is Required: + qualifiers = set(_get_typeddict_qualifiers(annotation_type)) + + if Required in qualifiers: required_keys.add(annotation_key) - elif annotation_origin is NotRequired: + elif NotRequired in qualifiers: optional_keys.add(annotation_key) elif total: required_keys.add(annotation_key) else: optional_keys.add(annotation_key) + if ReadOnly in qualifiers: + mutable_keys.discard(annotation_key) + readonly_keys.add(annotation_key) + else: + mutable_keys.add(annotation_key) + readonly_keys.discard(annotation_key) tp_dict.__annotations__ = annotations tp_dict.__required_keys__ = frozenset(required_keys) tp_dict.__optional_keys__ = frozenset(optional_keys) + tp_dict.__readonly_keys__ = frozenset(readonly_keys) + tp_dict.__mutable_keys__ = frozenset(mutable_keys) if not hasattr(tp_dict, '__total__'): tp_dict.__total__ = total + tp_dict.__closed__ = closed + tp_dict.__extra_items__ = extra_items_type return tp_dict __call__ = dict # static method @@ -1077,7 +955,7 @@ def __subclasscheck__(cls, other): _TypedDict = type.__new__(_TypedDictMeta, 'TypedDict', (), {}) @_ensure_subclassable(lambda bases: (_TypedDict,)) - def TypedDict(__typename, __fields=_marker, *, total=True, **kwargs): + def TypedDict(typename, fields=_marker, /, *, total=True, closed=False, **kwargs): """A simple typed namespace. At runtime it is equivalent to a plain dict. TypedDict creates a dictionary type such that a type checker will expect all @@ -1124,24 +1002,29 @@ class Point2D(TypedDict): See PEP 655 for more details on Required and NotRequired. """ - if __fields is _marker or __fields is None: - if __fields is _marker: + if fields is _marker or fields is None: + if fields is _marker: deprecated_thing = "Failing to pass a value for the 'fields' parameter" else: deprecated_thing = "Passing `None` as the 'fields' parameter" - example = f"`{__typename} = TypedDict({__typename!r}, {{}})`" + example = f"`{typename} = TypedDict({typename!r}, {{}})`" deprecation_msg = ( f"{deprecated_thing} is deprecated and will be disallowed in " "Python 3.15. To create a TypedDict class with 0 fields " "using the functional syntax, pass an empty dictionary, e.g. " ) + example + "." warnings.warn(deprecation_msg, DeprecationWarning, stacklevel=2) - __fields = kwargs + if closed is not False and closed is not True: + kwargs["closed"] = closed + closed = False + fields = kwargs elif kwargs: raise TypeError("TypedDict takes either a dict or keyword arguments," " but not both") if kwargs: + if sys.version_info >= (3, 13): + raise TypeError("TypedDict takes no keyword arguments") warnings.warn( "The kwargs-based syntax for TypedDict definitions is deprecated " "in Python 3.11, will be removed in Python 3.13, and may not be " @@ -1150,13 +1033,13 @@ class Point2D(TypedDict): stacklevel=2, ) - ns = {'__annotations__': dict(__fields)} + ns = {'__annotations__': dict(fields)} module = _caller() if module is not None: # Setting correct module is necessary to make typed dict classes pickleable. ns['__module__'] = module - td = _TypedDictMeta(__typename, (), ns, total=total) + td = _TypedDictMeta(typename, (), ns, total=total, closed=closed) td.__orig_bases__ = (TypedDict,) return td @@ -1186,7 +1069,7 @@ class Film(TypedDict): assert_type = typing.assert_type else: - def assert_type(__val, __typ): + def assert_type(val, typ, /): """Assert (to the type checker) that the value is of the given type. When the type checker encounters a call to assert_type(), it @@ -1199,18 +1082,18 @@ def greet(name: str) -> None: At runtime this returns the first argument unchanged and otherwise does nothing. """ - return __val + return val -if hasattr(typing, "Required"): +if hasattr(typing, "ReadOnly"): # 3.13+ get_type_hints = typing.get_type_hints -else: +else: # <=3.13 # replaces _strip_annotations() def _strip_extras(t): """Strips Annotated, Required and NotRequired from a given type.""" if isinstance(t, _AnnotatedAlias): return _strip_extras(t.__origin__) - if hasattr(t, "__origin__") and t.__origin__ in (Required, NotRequired): + if hasattr(t, "__origin__") and t.__origin__ in (Required, NotRequired, ReadOnly): return _strip_extras(t.__args__[0]) if isinstance(t, typing._GenericAlias): stripped_args = tuple(_strip_extras(a) for a in t.__args__) @@ -1262,11 +1145,11 @@ def get_type_hints(obj, globalns=None, localns=None, include_extras=False): - If two dict arguments are passed, they specify globals and locals, respectively. """ - if hasattr(typing, "Annotated"): + if hasattr(typing, "Annotated"): # 3.9+ hint = typing.get_type_hints( obj, globalns=globalns, localns=localns, include_extras=True ) - else: + else: # 3.8 hint = typing.get_type_hints(obj, globalns=globalns, localns=localns) if include_extras: return hint @@ -1279,7 +1162,7 @@ def get_type_hints(obj, globalns=None, localns=None, include_extras=False): # Not exported and not a public API, but needed for get_origin() and get_args() # to work. _AnnotatedAlias = typing._AnnotatedAlias -# 3.7-3.8 +# 3.8 else: class _AnnotatedAlias(typing._GenericAlias, _root=True): """Runtime representation of an annotated type. @@ -1384,7 +1267,7 @@ def __init_subclass__(cls, *args, **kwargs): if sys.version_info[:2] >= (3, 10): get_origin = typing.get_origin get_args = typing.get_args -# 3.7-3.9 +# 3.8-3.9 else: try: # 3.9+ @@ -1462,7 +1345,7 @@ def TypeAlias(self, parameters): It's invalid when used anywhere except as in the example above. """ raise TypeError(f"{self} is not subscriptable") -# 3.7-3.8 +# 3.8 else: TypeAlias = _ExtensionsSpecialForm( 'TypeAlias', @@ -1484,7 +1367,10 @@ def _set_default(type_param, default): type_param.__default__ = tuple((typing._type_check(d, "Default must be a type") for d in default)) elif default != _marker: - type_param.__default__ = typing._type_check(default, "Default must be a type") + if isinstance(type_param, ParamSpec) and default is ...: # ... not valid <3.11 + type_param.__default__ = default + else: + type_param.__default__ = typing._type_check(default, "Default must be a type") else: type_param.__default__ = None @@ -1519,7 +1405,7 @@ def __new__(cls, name, *constraints, bound=None, covariant=False, contravariant=False, default=_marker, infer_variance=False): if hasattr(typing, "TypeAliasType"): - # PEP 695 implemented, can pass infer_variance to typing.TypeVar + # PEP 695 implemented (3.12+), can pass infer_variance to typing.TypeVar typevar = typing.TypeVar(name, *constraints, bound=bound, covariant=covariant, contravariant=contravariant, infer_variance=infer_variance) @@ -1541,7 +1427,7 @@ def __init_subclass__(cls) -> None: if hasattr(typing, 'ParamSpecArgs'): ParamSpecArgs = typing.ParamSpecArgs ParamSpecKwargs = typing.ParamSpecKwargs -# 3.7-3.9 +# 3.8-3.9 else: class _Immutable: """Mixin to indicate that object should not be copied.""" @@ -1630,7 +1516,7 @@ def __new__(cls, name, *, bound=None, def __init_subclass__(cls) -> None: raise TypeError(f"type '{__name__}.ParamSpec' is not an acceptable base type") -# 3.7-3.9 +# 3.8-3.9 else: # Inherits from list as a workaround for Callable checks in Python < 3.9.2. @@ -1735,7 +1621,7 @@ def __call__(self, *args, **kwargs): pass -# 3.7-3.9 +# 3.8-3.9 if not hasattr(typing, 'Concatenate'): # Inherits from list as a workaround for Callable checks in Python < 3.9.2. class _ConcatenateGenericAlias(list): @@ -1770,7 +1656,7 @@ def __parameters__(self): ) -# 3.7-3.9 +# 3.8-3.9 @typing._tp_cache def _concatenate_getitem(self, parameters): if parameters == (): @@ -1804,7 +1690,7 @@ def Concatenate(self, parameters): See PEP 612 for detailed information. """ return _concatenate_getitem(self, parameters) -# 3.7-8 +# 3.8 else: class _ConcatenateForm(_ExtensionsSpecialForm, _root=True): def __getitem__(self, parameters): @@ -1874,7 +1760,7 @@ def is_str(val: Union[str, float]): """ item = typing._type_check(parameters, f'{self} accepts only a single type.') return typing._GenericAlias(self, (item,)) -# 3.7-3.8 +# 3.8 else: class _TypeGuardForm(_ExtensionsSpecialForm, _root=True): def __getitem__(self, parameters): @@ -1927,6 +1813,98 @@ def is_str(val: Union[str, float]): PEP 647 (User-Defined Type Guards). """) +# 3.13+ +if hasattr(typing, 'TypeIs'): + TypeIs = typing.TypeIs +# 3.9 +elif sys.version_info[:2] >= (3, 9): + @_ExtensionsSpecialForm + def TypeIs(self, parameters): + """Special typing form used to annotate the return type of a user-defined + type narrower function. ``TypeIs`` only accepts a single type argument. + At runtime, functions marked this way should return a boolean. + + ``TypeIs`` aims to benefit *type narrowing* -- a technique used by static + type checkers to determine a more precise type of an expression within a + program's code flow. Usually type narrowing is done by analyzing + conditional code flow and applying the narrowing to a block of code. The + conditional expression here is sometimes referred to as a "type guard". + + Sometimes it would be convenient to use a user-defined boolean function + as a type guard. Such a function should use ``TypeIs[...]`` as its + return type to alert static type checkers to this intention. + + Using ``-> TypeIs`` tells the static type checker that for a given + function: + + 1. The return value is a boolean. + 2. If the return value is ``True``, the type of its argument + is the intersection of the type inside ``TypeGuard`` and the argument's + previously known type. + + For example:: + + def is_awaitable(val: object) -> TypeIs[Awaitable[Any]]: + return hasattr(val, '__await__') + + def f(val: Union[int, Awaitable[int]]) -> int: + if is_awaitable(val): + assert_type(val, Awaitable[int]) + else: + assert_type(val, int) + + ``TypeIs`` also works with type variables. For more information, see + PEP 742 (Narrowing types with TypeIs). + """ + item = typing._type_check(parameters, f'{self} accepts only a single type.') + return typing._GenericAlias(self, (item,)) +# 3.8 +else: + class _TypeIsForm(_ExtensionsSpecialForm, _root=True): + def __getitem__(self, parameters): + item = typing._type_check(parameters, + f'{self._name} accepts only a single type') + return typing._GenericAlias(self, (item,)) + + TypeIs = _TypeIsForm( + 'TypeIs', + doc="""Special typing form used to annotate the return type of a user-defined + type narrower function. ``TypeIs`` only accepts a single type argument. + At runtime, functions marked this way should return a boolean. + + ``TypeIs`` aims to benefit *type narrowing* -- a technique used by static + type checkers to determine a more precise type of an expression within a + program's code flow. Usually type narrowing is done by analyzing + conditional code flow and applying the narrowing to a block of code. The + conditional expression here is sometimes referred to as a "type guard". + + Sometimes it would be convenient to use a user-defined boolean function + as a type guard. Such a function should use ``TypeIs[...]`` as its + return type to alert static type checkers to this intention. + + Using ``-> TypeIs`` tells the static type checker that for a given + function: + + 1. The return value is a boolean. + 2. If the return value is ``True``, the type of its argument + is the intersection of the type inside ``TypeGuard`` and the argument's + previously known type. + + For example:: + + def is_awaitable(val: object) -> TypeIs[Awaitable[Any]]: + return hasattr(val, '__await__') + + def f(val: Union[int, Awaitable[int]]) -> int: + if is_awaitable(val): + assert_type(val, Awaitable[int]) + else: + assert_type(val, int) + + ``TypeIs`` also works with type variables. For more information, see + PEP 742 (Narrowing types with TypeIs). + """) + # Vendored from cpython typing._SpecialFrom class _SpecialForm(typing._Final, _root=True): @@ -1972,7 +1950,7 @@ def __getitem__(self, parameters): return self._getitem(self, parameters) -if hasattr(typing, "LiteralString"): +if hasattr(typing, "LiteralString"): # 3.11+ LiteralString = typing.LiteralString else: @_SpecialForm @@ -1995,7 +1973,7 @@ def query(sql: LiteralString) -> ...: raise TypeError(f"{self} is not subscriptable") -if hasattr(typing, "Self"): +if hasattr(typing, "Self"): # 3.11+ Self = typing.Self else: @_SpecialForm @@ -2016,7 +1994,7 @@ def parse(self, data: bytes) -> Self: raise TypeError(f"{self} is not subscriptable") -if hasattr(typing, "Never"): +if hasattr(typing, "Never"): # 3.11+ Never = typing.Never else: @_SpecialForm @@ -2046,10 +2024,10 @@ def int_or_str(arg: int | str) -> None: raise TypeError(f"{self} is not subscriptable") -if hasattr(typing, 'Required'): +if hasattr(typing, 'Required'): # 3.11+ Required = typing.Required NotRequired = typing.NotRequired -elif sys.version_info[:2] >= (3, 9): +elif sys.version_info[:2] >= (3, 9): # 3.9-3.10 @_ExtensionsSpecialForm def Required(self, parameters): """A special typing construct to mark a key of a total=False TypedDict @@ -2087,7 +2065,7 @@ class Movie(TypedDict): item = typing._type_check(parameters, f'{self._name} accepts only a single type.') return typing._GenericAlias(self, (item,)) -else: +else: # 3.8 class _RequiredForm(_ExtensionsSpecialForm, _root=True): def __getitem__(self, parameters): item = typing._type_check(parameters, @@ -2127,6 +2105,53 @@ class Movie(TypedDict): """) +if hasattr(typing, 'ReadOnly'): + ReadOnly = typing.ReadOnly +elif sys.version_info[:2] >= (3, 9): # 3.9-3.12 + @_ExtensionsSpecialForm + def ReadOnly(self, parameters): + """A special typing construct to mark an item of a TypedDict as read-only. + + For example: + + class Movie(TypedDict): + title: ReadOnly[str] + year: int + + def mutate_movie(m: Movie) -> None: + m["year"] = 1992 # allowed + m["title"] = "The Matrix" # typechecker error + + There is no runtime checking for this property. + """ + item = typing._type_check(parameters, f'{self._name} accepts only a single type.') + return typing._GenericAlias(self, (item,)) + +else: # 3.8 + class _ReadOnlyForm(_ExtensionsSpecialForm, _root=True): + def __getitem__(self, parameters): + item = typing._type_check(parameters, + f'{self._name} accepts only a single type.') + return typing._GenericAlias(self, (item,)) + + ReadOnly = _ReadOnlyForm( + 'ReadOnly', + doc="""A special typing construct to mark a key of a TypedDict as read-only. + + For example: + + class Movie(TypedDict): + title: ReadOnly[str] + year: int + + def mutate_movie(m: Movie) -> None: + m["year"] = 1992 # allowed + m["title"] = "The Matrix" # typechecker error + + There is no runtime checking for this propery. + """) + + _UNPACK_DOC = """\ Type unpack operator. @@ -2175,7 +2200,7 @@ def foo(**kwargs: Unpack[Movie]): ... def _is_unpack(obj): return get_origin(obj) is Unpack -elif sys.version_info[:2] >= (3, 9): +elif sys.version_info[:2] >= (3, 9): # 3.9+ class _UnpackSpecialForm(_ExtensionsSpecialForm, _root=True): def __init__(self, getitem): super().__init__(getitem) @@ -2192,7 +2217,7 @@ def Unpack(self, parameters): def _is_unpack(obj): return isinstance(obj, _UnpackAlias) -else: +else: # 3.8 class _UnpackAlias(typing._GenericAlias, _root=True): __class__ = typing.TypeVar @@ -2225,7 +2250,7 @@ def __new__(cls, name, *, default=_marker): def __init_subclass__(self, *args, **kwds): raise TypeError("Cannot subclass special typing classes") -else: +else: # <=3.10 class TypeVarTuple(_DefaultMixin): """Type variable tuple. @@ -2304,10 +2329,10 @@ def __init_subclass__(self, *args, **kwds): raise TypeError("Cannot subclass special typing classes") -if hasattr(typing, "reveal_type"): +if hasattr(typing, "reveal_type"): # 3.11+ reveal_type = typing.reveal_type -else: - def reveal_type(__obj: T) -> T: +else: # <=3.10 + def reveal_type(obj: T, /) -> T: """Reveal the inferred type of a variable. When a static type checker encounters a call to ``reveal_type()``, @@ -2323,14 +2348,14 @@ def reveal_type(__obj: T) -> T: argument and returns it unchanged. """ - print(f"Runtime type is {type(__obj).__name__!r}", file=sys.stderr) - return __obj + print(f"Runtime type is {type(obj).__name__!r}", file=sys.stderr) + return obj -if hasattr(typing, "assert_never"): +if hasattr(typing, "assert_never"): # 3.11+ assert_never = typing.assert_never -else: - def assert_never(__arg: Never) -> Never: +else: # <=3.10 + def assert_never(arg: Never, /) -> Never: """Assert to the type checker that a line of code is unreachable. Example:: @@ -2353,10 +2378,10 @@ def int_or_str(arg: int | str) -> None: raise AssertionError("Expected code to be unreachable") -if sys.version_info >= (3, 12): +if sys.version_info >= (3, 12): # 3.12+ # dataclass_transform exists in 3.11 but lacks the frozen_default parameter dataclass_transform = typing.dataclass_transform -else: +else: # <=3.11 def dataclass_transform( *, eq_default: bool = True, @@ -2443,18 +2468,18 @@ def decorator(cls_or_fn): return decorator -if hasattr(typing, "override"): +if hasattr(typing, "override"): # 3.12+ override = typing.override -else: +else: # <=3.11 _F = typing.TypeVar("_F", bound=typing.Callable[..., typing.Any]) - def override(__arg: _F) -> _F: + def override(arg: _F, /) -> _F: """Indicate that a method is intended to override a method in a base class. Usage: class Base: - def method(self) -> None: ... + def method(self) -> None: pass class Child(Base): @@ -2475,28 +2500,26 @@ def method(self) -> None: """ try: - __arg.__override__ = True + arg.__override__ = True except (AttributeError, TypeError): # Skip the attribute silently if it is not writable. # AttributeError happens if the object has __slots__ or a # read-only property, TypeError if it's a builtin class. pass - return __arg + return arg -if hasattr(typing, "deprecated"): - deprecated = typing.deprecated +if hasattr(warnings, "deprecated"): + deprecated = warnings.deprecated else: _T = typing.TypeVar("_T") - def deprecated( - __msg: str, - *, - category: typing.Optional[typing.Type[Warning]] = DeprecationWarning, - stacklevel: int = 1, - ) -> typing.Callable[[_T], _T]: + class deprecated: """Indicate that a class, function or overload is deprecated. + When this decorator is applied to an object, the type checker + will generate a diagnostic on usage of the deprecated object. + Usage: @deprecated("Use B instead") @@ -2513,64 +2536,113 @@ def g(x: int) -> int: ... @overload def g(x: str) -> int: ... - When this decorator is applied to an object, the type checker - will generate a diagnostic on usage of the deprecated object. - - The warning specified by ``category`` will be emitted on use - of deprecated objects. For functions, that happens on calls; - for classes, on instantiation. If the ``category`` is ``None``, - no warning is emitted. The ``stacklevel`` determines where the + The warning specified by *category* will be emitted at runtime + on use of deprecated objects. For functions, that happens on calls; + for classes, on instantiation and on creation of subclasses. + If the *category* is ``None``, no warning is emitted at runtime. + The *stacklevel* determines where the warning is emitted. If it is ``1`` (the default), the warning is emitted at the direct caller of the deprecated object; if it is higher, it is emitted further up the stack. + Static type checker behavior is not affected by the *category* + and *stacklevel* arguments. - The decorator sets the ``__deprecated__`` - attribute on the decorated object to the deprecation message - passed to the decorator. If applied to an overload, the decorator + The deprecation message passed to the decorator is saved in the + ``__deprecated__`` attribute on the decorated object. + If applied to an overload, the decorator must be after the ``@overload`` decorator for the attribute to exist on the overload as returned by ``get_overloads()``. See PEP 702 for details. """ - def decorator(__arg: _T) -> _T: + def __init__( + self, + message: str, + /, + *, + category: typing.Optional[typing.Type[Warning]] = DeprecationWarning, + stacklevel: int = 1, + ) -> None: + if not isinstance(message, str): + raise TypeError( + "Expected an object of type str for 'message', not " + f"{type(message).__name__!r}" + ) + self.message = message + self.category = category + self.stacklevel = stacklevel + + def __call__(self, arg: _T, /) -> _T: + # Make sure the inner functions created below don't + # retain a reference to self. + msg = self.message + category = self.category + stacklevel = self.stacklevel if category is None: - __arg.__deprecated__ = __msg - return __arg - elif isinstance(__arg, type): - original_new = __arg.__new__ - has_init = __arg.__init__ is not object.__init__ + arg.__deprecated__ = msg + return arg + elif isinstance(arg, type): + import functools + from types import MethodType + + original_new = arg.__new__ @functools.wraps(original_new) def __new__(cls, *args, **kwargs): - warnings.warn(__msg, category=category, stacklevel=stacklevel + 1) + if cls is arg: + warnings.warn(msg, category=category, stacklevel=stacklevel + 1) if original_new is not object.__new__: return original_new(cls, *args, **kwargs) # Mirrors a similar check in object.__new__. - elif not has_init and (args or kwargs): + elif cls.__init__ is object.__init__ and (args or kwargs): raise TypeError(f"{cls.__name__}() takes no arguments") else: return original_new(cls) - __arg.__new__ = staticmethod(__new__) - __arg.__deprecated__ = __new__.__deprecated__ = __msg - return __arg - elif callable(__arg): - @functools.wraps(__arg) + arg.__new__ = staticmethod(__new__) + + original_init_subclass = arg.__init_subclass__ + # We need slightly different behavior if __init_subclass__ + # is a bound method (likely if it was implemented in Python) + if isinstance(original_init_subclass, MethodType): + original_init_subclass = original_init_subclass.__func__ + + @functools.wraps(original_init_subclass) + def __init_subclass__(*args, **kwargs): + warnings.warn(msg, category=category, stacklevel=stacklevel + 1) + return original_init_subclass(*args, **kwargs) + + arg.__init_subclass__ = classmethod(__init_subclass__) + # Or otherwise, which likely means it's a builtin such as + # object's implementation of __init_subclass__. + else: + @functools.wraps(original_init_subclass) + def __init_subclass__(*args, **kwargs): + warnings.warn(msg, category=category, stacklevel=stacklevel + 1) + return original_init_subclass(*args, **kwargs) + + arg.__init_subclass__ = __init_subclass__ + + arg.__deprecated__ = __new__.__deprecated__ = msg + __init_subclass__.__deprecated__ = msg + return arg + elif callable(arg): + import functools + + @functools.wraps(arg) def wrapper(*args, **kwargs): - warnings.warn(__msg, category=category, stacklevel=stacklevel + 1) - return __arg(*args, **kwargs) + warnings.warn(msg, category=category, stacklevel=stacklevel + 1) + return arg(*args, **kwargs) - __arg.__deprecated__ = wrapper.__deprecated__ = __msg + arg.__deprecated__ = wrapper.__deprecated__ = msg return wrapper else: raise TypeError( "@deprecated decorator with non-None category must be applied to " - f"a class or callable, not {__arg!r}" + f"a class or callable, not {arg!r}" ) - return decorator - # We have to do some monkey patching to deal with the dual nature of # Unpack/TypeVarTuple: @@ -2580,11 +2652,153 @@ def wrapper(*args, **kwargs): # counting generic parameters, so that when we subscript a generic, # the runtime doesn't try to substitute the Unpack with the subscripted type. if not hasattr(typing, "TypeVarTuple"): + def _check_generic(cls, parameters, elen=_marker): + """Check correct count for parameters of a generic cls (internal helper). + + This gives a nice error message in case of count mismatch. + """ + if not elen: + raise TypeError(f"{cls} is not a generic class") + if elen is _marker: + if not hasattr(cls, "__parameters__") or not cls.__parameters__: + raise TypeError(f"{cls} is not a generic class") + elen = len(cls.__parameters__) + alen = len(parameters) + if alen != elen: + expect_val = elen + if hasattr(cls, "__parameters__"): + parameters = [p for p in cls.__parameters__ if not _is_unpack(p)] + num_tv_tuples = sum(isinstance(p, TypeVarTuple) for p in parameters) + if (num_tv_tuples > 0) and (alen >= elen - num_tv_tuples): + return + + # deal with TypeVarLike defaults + # required TypeVarLikes cannot appear after a defaulted one. + if alen < elen: + # since we validate TypeVarLike default in _collect_type_vars + # or _collect_parameters we can safely check parameters[alen] + if getattr(parameters[alen], '__default__', None) is not None: + return + + num_default_tv = sum(getattr(p, '__default__', None) + is not None for p in parameters) + + elen -= num_default_tv + + expect_val = f"at least {elen}" + + things = "arguments" if sys.version_info >= (3, 10) else "parameters" + raise TypeError(f"Too {'many' if alen > elen else 'few'} {things}" + f" for {cls}; actual {alen}, expected {expect_val}") +else: + # Python 3.11+ + + def _check_generic(cls, parameters, elen): + """Check correct count for parameters of a generic cls (internal helper). + + This gives a nice error message in case of count mismatch. + """ + if not elen: + raise TypeError(f"{cls} is not a generic class") + alen = len(parameters) + if alen != elen: + expect_val = elen + if hasattr(cls, "__parameters__"): + parameters = [p for p in cls.__parameters__ if not _is_unpack(p)] + + # deal with TypeVarLike defaults + # required TypeVarLikes cannot appear after a defaulted one. + if alen < elen: + # since we validate TypeVarLike default in _collect_type_vars + # or _collect_parameters we can safely check parameters[alen] + if getattr(parameters[alen], '__default__', None) is not None: + return + + num_default_tv = sum(getattr(p, '__default__', None) + is not None for p in parameters) + + elen -= num_default_tv + + expect_val = f"at least {elen}" + + raise TypeError(f"Too {'many' if alen > elen else 'few'} arguments" + f" for {cls}; actual {alen}, expected {expect_val}") + +typing._check_generic = _check_generic + +# Python 3.11+ _collect_type_vars was renamed to _collect_parameters +if hasattr(typing, '_collect_type_vars'): + def _collect_type_vars(types, typevar_types=None): + """Collect all type variable contained in types in order of + first appearance (lexicographic order). For example:: + + _collect_type_vars((T, List[S, T])) == (T, S) + """ + if typevar_types is None: + typevar_types = typing.TypeVar + tvars = [] + # required TypeVarLike cannot appear after TypeVarLike with default + default_encountered = False + for t in types: + if ( + isinstance(t, typevar_types) and + t not in tvars and + not _is_unpack(t) + ): + if getattr(t, '__default__', None) is not None: + default_encountered = True + elif default_encountered: + raise TypeError(f'Type parameter {t!r} without a default' + ' follows type parameter with a default') + + tvars.append(t) + if _should_collect_from_parameters(t): + tvars.extend([t for t in t.__parameters__ if t not in tvars]) + return tuple(tvars) + typing._collect_type_vars = _collect_type_vars - typing._check_generic = _check_generic +else: + def _collect_parameters(args): + """Collect all type variables and parameter specifications in args + in order of first appearance (lexicographic order). + + For example:: + + assert _collect_parameters((T, Callable[P, T])) == (T, P) + """ + parameters = [] + # required TypeVarLike cannot appear after TypeVarLike with default + default_encountered = False + for t in args: + if isinstance(t, type): + # We don't want __parameters__ descriptor of a bare Python class. + pass + elif isinstance(t, tuple): + # `t` might be a tuple, when `ParamSpec` is substituted with + # `[T, int]`, or `[int, *Ts]`, etc. + for x in t: + for collected in _collect_parameters([x]): + if collected not in parameters: + parameters.append(collected) + elif hasattr(t, '__typing_subst__'): + if t not in parameters: + if getattr(t, '__default__', None) is not None: + default_encountered = True + elif default_encountered: + raise TypeError(f'Type parameter {t!r} without a default' + ' follows type parameter with a default') + + parameters.append(t) + else: + for x in getattr(t, '__parameters__', ()): + if x not in parameters: + parameters.append(x) + return tuple(parameters) -# Backport typing.NamedTuple as it exists in Python 3.12. + typing._collect_parameters = _collect_parameters + +# Backport typing.NamedTuple as it exists in Python 3.13. # In 3.11, the ability to define generic `NamedTuple`s was supported. # This was explicitly disallowed in 3.9-3.10, and only half-worked in <=3.8. # On 3.12, we added __orig_bases__ to call-based NamedTuples @@ -2639,11 +2853,35 @@ def __new__(cls, typename, bases, ns): class_getitem = typing.Generic.__class_getitem__.__func__ nm_tpl.__class_getitem__ = classmethod(class_getitem) # update from user namespace without overriding special namedtuple attributes - for key in ns: + for key, val in ns.items(): if key in _prohibited_namedtuple_fields: raise AttributeError("Cannot overwrite NamedTuple attribute " + key) - elif key not in _special_namedtuple_fields and key not in nm_tpl._fields: - setattr(nm_tpl, key, ns[key]) + elif key not in _special_namedtuple_fields: + if key not in nm_tpl._fields: + setattr(nm_tpl, key, ns[key]) + try: + set_name = type(val).__set_name__ + except AttributeError: + pass + else: + try: + set_name(val, nm_tpl, key) + except BaseException as e: + msg = ( + f"Error calling __set_name__ on {type(val).__name__!r} " + f"instance {key!r} in {typename!r}" + ) + # BaseException.add_note() existed on py311, + # but the __set_name__ machinery didn't start + # using add_note() until py312. + # Making sure exceptions are raised in the same way + # as in "normal" classes seems most important here. + if sys.version_info >= (3, 12): + e.add_note(msg) + raise + else: + raise RuntimeError(msg) from e + if typing.Generic in bases: nm_tpl.__init_subclass__() return nm_tpl @@ -2655,7 +2893,7 @@ def _namedtuple_mro_entries(bases): return (_NamedTuple,) @_ensure_subclassable(_namedtuple_mro_entries) - def NamedTuple(__typename, __fields=_marker, **kwargs): + def NamedTuple(typename, fields=_marker, /, **kwargs): """Typed version of namedtuple. Usage:: @@ -2675,7 +2913,7 @@ class Employee(NamedTuple): Employee = NamedTuple('Employee', [('name', str), ('id', int)]) """ - if __fields is _marker: + if fields is _marker: if kwargs: deprecated_thing = "Creating NamedTuple classes using keyword arguments" deprecation_msg = ( @@ -2684,14 +2922,14 @@ class Employee(NamedTuple): ) else: deprecated_thing = "Failing to pass a value for the 'fields' parameter" - example = f"`{__typename} = NamedTuple({__typename!r}, [])`" + example = f"`{typename} = NamedTuple({typename!r}, [])`" deprecation_msg = ( "{name} is deprecated and will be disallowed in Python {remove}. " "To create a NamedTuple class with 0 fields " "using the functional syntax, " "pass an empty list, e.g. " ) + example + "." - elif __fields is None: + elif fields is None: if kwargs: raise TypeError( "Cannot pass `None` as the 'fields' parameter " @@ -2699,7 +2937,7 @@ class Employee(NamedTuple): ) else: deprecated_thing = "Passing `None` as the 'fields' parameter" - example = f"`{__typename} = NamedTuple({__typename!r}, [])`" + example = f"`{typename} = NamedTuple({typename!r}, [])`" deprecation_msg = ( "{name} is deprecated and will be disallowed in Python {remove}. " "To create a NamedTuple class with 0 fields " @@ -2709,27 +2947,17 @@ class Employee(NamedTuple): elif kwargs: raise TypeError("Either list of fields or keywords" " can be provided to NamedTuple, not both") - if __fields is _marker or __fields is None: + if fields is _marker or fields is None: warnings.warn( deprecation_msg.format(name=deprecated_thing, remove="3.15"), DeprecationWarning, stacklevel=2, ) - __fields = kwargs.items() - nt = _make_nmtuple(__typename, __fields, module=_caller()) + fields = kwargs.items() + nt = _make_nmtuple(typename, fields, module=_caller()) nt.__orig_bases__ = (NamedTuple,) return nt - # On 3.8+, alter the signature so that it matches typing.NamedTuple. - # The signature of typing.NamedTuple on >=3.8 is invalid syntax in Python 3.7, - # so just leave the signature as it is on 3.7. - if sys.version_info >= (3, 8): - _new_signature = '(typename, fields=None, /, **kwargs)' - if isinstance(NamedTuple, _types.FunctionType): - NamedTuple.__text_signature__ = _new_signature - else: - NamedTuple.__call__.__text_signature__ = _new_signature - if hasattr(collections.abc, "Buffer"): Buffer = collections.abc.Buffer @@ -2764,7 +2992,7 @@ class Buffer(abc.ABC): if hasattr(_types, "get_original_bases"): get_original_bases = _types.get_original_bases else: - def get_original_bases(__cls): + def get_original_bases(cls, /): """Return the class's "original" bases prior to modification by `__mro_entries__`. Examples:: @@ -2786,14 +3014,11 @@ class Baz(list[str]): ... assert get_original_bases(int) == (object,) """ try: - return __cls.__orig_bases__ + return cls.__dict__.get("__orig_bases__", cls.__bases__) except AttributeError: - try: - return __cls.__bases__ - except AttributeError: - raise TypeError( - f'Expected an instance of type, not {type(__cls).__name__!r}' - ) from None + raise TypeError( + f'Expected an instance of type, not {type(cls).__name__!r}' + ) from None # NewType is a class on Python 3.10+, making it pickleable @@ -2815,7 +3040,7 @@ def name_by_id(user_id: UserId) -> str: num = UserId(5) + 1 # type: int """ - def __call__(self, obj): + def __call__(self, obj, /): return obj def __init__(self, name, tp): @@ -2920,13 +3145,13 @@ def __init__(self, name: str, value, *, type_params=()): # Setting this attribute closes the TypeAliasType from further modification self.__name__ = name - def __setattr__(self, __name: str, __value: object) -> None: + def __setattr__(self, name: str, value: object, /) -> None: if hasattr(self, "__name__"): - self._raise_attribute_error(__name) - super().__setattr__(__name, __value) + self._raise_attribute_error(name) + super().__setattr__(name, value) - def __delattr__(self, __name: str) -> Never: - self._raise_attribute_error(__name) + def __delattr__(self, name: str, /) -> Never: + self._raise_attribute_error(name) def _raise_attribute_error(self, name: str) -> Never: # Match the Python 3.12 error messages exactly @@ -2987,7 +3212,7 @@ def __ror__(self, left): is_protocol = typing.is_protocol get_protocol_members = typing.get_protocol_members else: - def is_protocol(__tp: type) -> bool: + def is_protocol(tp: type, /) -> bool: """Return True if the given type is a Protocol. Example:: @@ -3002,13 +3227,13 @@ def is_protocol(__tp: type) -> bool: False """ return ( - isinstance(__tp, type) - and getattr(__tp, '_is_protocol', False) - and __tp is not Protocol - and __tp is not getattr(typing, "Protocol", object()) + isinstance(tp, type) + and getattr(tp, '_is_protocol', False) + and tp is not Protocol + and tp is not typing.Protocol ) - def get_protocol_members(__tp: type) -> typing.FrozenSet[str]: + def get_protocol_members(tp: type, /) -> typing.FrozenSet[str]: """Return the set of members defined in a Protocol. Example:: @@ -3022,11 +3247,46 @@ def get_protocol_members(__tp: type) -> typing.FrozenSet[str]: Raise a TypeError for arguments that are not Protocols. """ - if not is_protocol(__tp): - raise TypeError(f'{__tp!r} is not a Protocol') - if hasattr(__tp, '__protocol_attrs__'): - return frozenset(__tp.__protocol_attrs__) - return frozenset(_get_protocol_attrs(__tp)) + if not is_protocol(tp): + raise TypeError(f'{tp!r} is not a Protocol') + if hasattr(tp, '__protocol_attrs__'): + return frozenset(tp.__protocol_attrs__) + return frozenset(_get_protocol_attrs(tp)) + + +if hasattr(typing, "Doc"): + Doc = typing.Doc +else: + class Doc: + """Define the documentation of a type annotation using ``Annotated``, to be + used in class attributes, function and method parameters, return values, + and variables. + + The value should be a positional-only string literal to allow static tools + like editors and documentation generators to use it. + + This complements docstrings. + + The string value passed is available in the attribute ``documentation``. + + Example:: + + >>> from typing_extensions import Annotated, Doc + >>> def hi(to: Annotated[str, Doc("Who to say hi to")]) -> None: ... + """ + def __init__(self, documentation: str, /) -> None: + self.documentation = documentation + + def __repr__(self) -> str: + return f"Doc({self.documentation!r})" + + def __hash__(self) -> int: + return hash(self.documentation) + + def __eq__(self, other: object) -> bool: + if not isinstance(other, Doc): + return NotImplemented + return self.documentation == other.documentation # Aliases for items that have always been in typing. diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-311.pyc index 274b9a4f29e222374ad7c7b05bf84d98ff9b1300..cab550cb240937b853bf9a2c697b483534185c9a 100644 GIT binary patch delta 19 ZcmeB??UChL&dbZi00gclH*z)c0RSwA1c3km delta 19 ZcmeB??UChL&dbZi00hp5HgYxb0RSvm1b6@d diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-311.pyc index 609c4062611fe48520c8e79fad29044afc586b06..d833c1f66fe3ede27b5ee7b5a78f797929196420 100644 GIT binary patch delta 836 zcmZuvU279T6rG!B+NMd9YRy**jT_knmjFNSa&DMLc1F`TdAQX z5h?}+D-77;gAa-dTJU4>NB99&5Gi@`LG;Ck2;!?wwn-H1W#`Q9z2~02bC}8+e4^0x z*lxEX7O~g2GV{R~UB3>v+5w^KXdMy6frvPh2%K5;QlINykJ!D6I4|*VKDK(<>LVWd z&V~J=n-%)WfaqC8kC@!kx~37_;R;#;&Ywg9pKfzsJ4iRjJ6sV~TSr+W!hKkQWr(8l z?iCY#=J(R)6At>hdrxT@u@+PDjukgzjw~pb2^JJtBeFJF$P+=zNCM6gUL-2cNMv3t z;EN=qsEn24<*X!Uv6drPC6^XSL2D^35G|*OSX1z9EQJ*n$754b%nO2|ibjuu=Snlv zcr+9`7Q{&+Xp$o1(D9*>p_WFVt>~O?j1rRtrQY~AlVE>eA|~y<tGk7aGD90QO(*u zV6CAhY_;RsKIA@HL(p-^fXd9a&AFDik=Ss3u;Gt3yk$Jwj{TKR`rg?~?}pz%Kqn`z z0tEGMCqn=ux_2xCFsheNy#$!lhsP}dGy2$s#{?TRIjO@L+BWqCj?nK@Ws`c7N|A8q z8XHGV)Pd3`5eyIL+sH6{)qh9A;Pg26_S8@d{CYSV2Y5(Ju^_zCH)CZOT{1&o4egG% PFZ?hnKXb*sECs~UKrE9Y*upURjF^H#s&a~W3&S#?L90QgfkBi?2SWv8lxi@8rsQTJ z@mBfCHk_Q3uUMR76yH4GvXPNdYO|uXAtR&G=3tvNMn?6`yKFZxGU{#4wP#~wG}&C@ zAi=~qd2+AQW=8YLj?PaQ)h4UCG)!LYV$9tIG{49PMD$I5>7u|mZ!(vwG2`{kcCKb1 tQ(N3T7#SB#KI^W-xMA}z_XbAGG-gJb4-DAJ32`66GGDOCPu}dQ3;-uEQ2GD> diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_version.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_version.cpython-311.pyc index 43a2dec98ee29650319922854fa5daa34fc57e15..e333565ca46200e00e71a44c42fdd76ca2ced4b7 100644 GIT binary patch delta 23 dcmaFG_==HhIWI340}!~LoXBOuXfe@#H2_M&20Z`( delta 23 dcmaFG_==HhIWI340}wbLn#g6sXg<+?H2_L$1~UKv diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-311.pyc index 5567b4fddee9f443be40cc09f7db5072893f2e6e..0e1b90ffe8bc89a0d98fd605a2752ae74b983b4b 100644 GIT binary patch delta 21 bcmX@GhVj4}My}<&yj%=G;CgZ+msuD9O6~>) delta 21 bcmX@GhVj4}My}<&yj%=G;CyH!msuD9O1}mC diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-311.pyc index 053288c9753ec0a98d0106eba0b74432b39e120b..58fd1fdb9e86e42e8eb858cfbdb6b86356046dc0 100644 GIT binary patch delta 5034 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 E503)GApigX delta 4845 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-311.pyc index 4e0fc0ac3a57c3685daba5bf151373f2e8270c4b..7ec59cd0a46a74088743d476310873e0c0365b70 100644 GIT binary patch delta 18 YcmeCG>#E~g&dbZi00gcl7joGH05fj{-T(jq delta 18 YcmeCG>#E~g&dbZi00hp57IN7G05eGh)c^nh diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-311.pyc index abfb7ce82ca12ebcd3c2daa79a7ceabb359e11e5..0609b2e265fa1ed549b1c50b6764517ebcd70515 100644 GIT binary patch delta 19 ZcmZ1;xjd3O delta 19 ZcmZ1;xjd3Cm2LL#51z!LF diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-311.pyc index 586481fa755de4595794797535172737237f5410..391b1fb1d86cee3d5d4cd9d85da820cdc794934a 100644 GIT binary patch delta 19 ZcmZ3Wyg-?2IWI340}!~L+{iUe5CAYv1k3;c delta 19 ZcmZ3Wyg-?2IWI340}wbL+Q>Cc5CAYA1j7IT diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-311.pyc index efe17b9b1ecc7e1659adc258ed930c6c1a608a0e..2f0cc0e7f91c6db482d86ee477b252e0b2b314a2 100644 GIT binary patch delta 3541 zcmaJ@eQZwpR;ATOVP!&-x3!wIuI!JpR+|Kfb<@+N zs#o@T_nxnN?z!jw?*05G`S54N|7JynSAaI~!7CHBBiH$Hd%;eDT4uQiAbykD+HwU`(q!sMJFSG+;QMw_5GrkXH5Y)bPDA_#B6-)dru z>=#$amEua!vrWZIe7QF3KvnR9q)V zAf68Pn5?R{nf_g4W23v2q^!`L>6B4)+C)2PEGEm|cao#Uw(=*0go-u(atEnqO*Jcs zlkKSa+J+%;m2j92T~Q}YPbRNPxolR|X+QAkDImH7NHa8g1X)RTvqmT5EEc_gC08?*bFMK29A*l_DP_P9AUv=KN&9`4t{K#>qV(2T{?DK}#u!dklxR>9e{UIv6%K z9=hp~GRj$r6~p%+lnZs$q#=b4R3vF2rSLhEy&2i=9LMgl;wO0;QXkHukj&iL_5eYE)%k}3qDjq!e{cc_07#bJ`*a?UUsax!^t=50(-Uj4OnPb%c$-2 zvYgGKGY7@xn+`Rbnzp>1LAJ}v@{8z>=N5J;t1ipB?gFtD_Cj4;1jhL|n~p_`&iME2 z`*?o%v;~kr_I~#1}potD{h;wWUmKT zlmovE`31*(75haX7?-_E(QVdatOWT&D|igRH}?A8+CIJ3SXE*R!c?HtFL(;}+rFhp zHR~yOrf_F?qvs0F`4D>$46zToY9i}Oe2A{|S%0by;_M|64AX(;Ox)N&>e0;Zlilo< zjbYM&qkdAb6n(uo?{&T=R`M1#8?C ziFtV{?2r@(PuBL5o*>LOV|wc43Yg5jh>%2y{%OgB~JG*wat2f%bEAew0(8WU1(Q zsqm9&deeG30~VQ-LIcdTWo!FBoQ)TtJ8dX*TA9%;aNxk{NoP`2(UgoqeJs6YeH%Yw zPRldBgtizy%_F%C#B@OQXXtC}?v}9g$H?txA8(0SP%_WR))@J1v1zN5Yb8rmdFvQNj@OfeY~fGdd_`cqU#Vb$OJAmna{~dLqU|siFh^RT21$9{`%1+dJp|Rhxkk%-b%h;w}%gdNBiD9nd8a9 zGXU8`?-XwW`mEyk)y3~vuK6KK-$TOFJ`cUpd*lvsc@RsFl$C$J!sp&13u|mZ59fnR zat<4p%_$i_s~NdEhqVeT3tYRMI;UEz-XMiNOZCbqXX-y6S$@yaR%@;oz3ufg$wmDKfLr!uW~M> zPI7YE}5E!y3}bUt2(eMRfSA|;%~#fZqRBRdGkhE?XXTCZsh_4;d+MR z9ca3_2A&RHO)g1FVn$5Qq+;yNPD0gNIsG{(Q=MHu5Sw}d?Se~=u{4oZR9UC|I37j0 z3xL~5CspfN#-FhqUU*)4I+lXZXYOrUR?e%+cKT1S$DPo>#hMQGgnRD`U-J7a%N?vQ lUOK3ejpGgiSoP)fYRA90j8LRVt)}#8}qD zscNNKj7#;JR78o0u}`l})hTsi?APm44N3!%<|M7`wH2Z?Iwb0v--f>7Lz}J=NqPf* z_Mv!bo=zvs2k%MK+*y;K&Xc84?~Y2jxit(sO}b%JB?vmd2H%+lvhC{EH?$hqJ1kQ0S||3`#`3atUZi&XI5;CABX)4{zx!(ce(vRnq$ zXDvCMOR3pRMmN|X$XOh~Z~-*K!=_O*!`}%SQ7y@{mFbe++Of~3ny=ot* ze5>j-q5QL|HZslILPtC&VK(9Buew8pr$aw?tQ>}SHUMC`vKeMF1%@#Y7Yz7nNs+y_Vkc}dY09ZANOgc>yW-^mjXIUnt!n;WqP0+`ri453QFd)k(B3L*dXLE*#$?$+! zc#o;o8b1K14{rM#*@o(nd5jyu`PBsB4kjU1iDtzUv8yBHi{^ z(y&oCpGQ6KLv(3~u?z$2lxN$U$rQib9`=YlEETS|e?odIQPH1enZ+eMn%U%>h$QB) zH!aP^nL#xb_BN0pu!#5{?t9TLX9xf3XsGbz-93by=I?f^cYz<=3WPa?R|>C;ND?5QEO!p!bH-UGg? z5Z)ViLcAcSJ9kLto(+R75{nXWe!jjaW8r+sYJ=F|R-}T1y+&_8Oy-?=m*&Ee`9M)u zl2*52YHIy?N8Y=M9VM`Ox1Gq|CQ?@D+dEA>b{X=o?Ta=If~8~^!E+lKdc=Y{H(8Pz zF~YtMGvnOa*WS@&m+6Zju+Mo*!J-YDxvuc8{XI?P@NRhwGj8S#(L+{g(nzL3kWNq* zs26Y2q-=pM8FoJl@{^P41fwaMHd!fm^mPx3X7Hq_c{Zc5FX38rkC_P1 z0$47j9QHB}D;d?24CqINCXOQsv2UW@AV1&NX!pS@{2P6ZC`m%NPAHT=(2?;o}2Ola}{7YDe7Cn!9bJ+qu?70HKo4fUR++0>17XX9|Dy;QkrW z0;1+;aHk|f1_8;#W?7LlwRCgH;ShekZ)OriSdZpYjyG_wc*2aBg~c~sH<>3=8O`c(INFQ++HmV6R;VBV%WdScl(8@hW&mP7n_y&{dXU>@ac&Ud z2EscCf;R-MiM*cU(UGR8;IA2&UJg$naXlPQ$LA>PRMliUX{ze43h|LvQoOdFf3T4} zb{e!H-pBD@340g**{+DA5T>_~?me$3v7Y?|R&QKOPuho*=l;=F@=xA7`Yf>VjnM;S z5DDG#q^SwDXL)j2EpAd|V%%KR?I0?6&(gR?nW3_q@M^dL#JvGLyJxJAe8N*>(_r!D zSdOgV0#WUdJ#k$ir?HKS6W58j0EOln&ThntHC6n2xQ;YoAzdW`jG zVL7xZ=WuYDEKU3PZ^tjKV68%gqAkY9huQaW7Zu@6oRQfNa9lw6A;OOkW)Q?V2!C-8 zs6zOPi5o_O>bk1J!3mFmnxsKH-J*^Vz70a-Z5aILNs0gI*jx6ghxzKnK<|%1ESd-m zpe}T*2pOs3&TWP|)kTQ#;AD$15$ojrlSAEBVB`BmT=O1O#mik(y;VvV6Eus&VlWw` z{LRUbAHKuli3KQ0g9Z2plRFdTFoS%0E=LWMRp47`&P?i^cH`kGt_zTJml$3|mRD$C zV~9d3QPnsm!;%m+9PGCa&eYyj%=G;CgZ+*O5K|Ok4)b delta 21 bcmX>%m+9PGCa&eYyj%=G;CyH!*O5K|Of3e& diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/_collections.py b/myenv/Lib/site-packages/pip/_vendor/urllib3/_collections.py index da9857e..bceb845 100644 --- a/myenv/Lib/site-packages/pip/_vendor/urllib3/_collections.py +++ b/myenv/Lib/site-packages/pip/_vendor/urllib3/_collections.py @@ -268,6 +268,24 @@ def getlist(self, key, default=__marker): else: return vals[1:] + def _prepare_for_method_change(self): + """ + Remove content-specific header fields before changing the request + method to GET or HEAD according to RFC 9110, Section 15.4. + """ + content_specific_headers = [ + "Content-Encoding", + "Content-Language", + "Content-Location", + "Content-Type", + "Content-Length", + "Digest", + "Last-Modified", + ] + for header in content_specific_headers: + self.discard(header) + return self + # Backwards compatibility for httplib getheaders = getlist getallmatchingheaders = getlist diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/_version.py b/myenv/Lib/site-packages/pip/_vendor/urllib3/_version.py index cad75fb..85e725e 100644 --- a/myenv/Lib/site-packages/pip/_vendor/urllib3/_version.py +++ b/myenv/Lib/site-packages/pip/_vendor/urllib3/_version.py @@ -1,2 +1,2 @@ # This file is protected via CODEOWNERS -__version__ = "1.26.17" +__version__ = "1.26.18" diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py b/myenv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py index 96844d9..5a6adcb 100644 --- a/myenv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py +++ b/myenv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py @@ -9,6 +9,7 @@ from socket import error as SocketError from socket import timeout as SocketTimeout +from ._collections import HTTPHeaderDict from .connection import ( BaseSSLError, BrokenPipeError, @@ -843,7 +844,11 @@ def _is_ssl_error_message_from_http_proxy(ssl_error): redirect_location = redirect and response.get_redirect_location() if redirect_location: if response.status == 303: + # Change the method according to RFC 9110, Section 15.4.4. method = "GET" + # And lose the body not to transfer anything sensitive. + body = None + headers = HTTPHeaderDict(headers)._prepare_for_method_change() try: retries = retries.increment(method, url, response=response, _pool=self) diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-311.pyc index c19a4816ace68883e967c9ae8267fa1b1c3c3c46..e71e0045751fda32f7dca9d50b366ae11a6165e9 100644 GIT binary patch delta 18 Ycmcb^c!!Z|IWI340}!~LoXB+v0528=3jhEB delta 18 Ycmcb^c!!Z|IWI340}wbLn#gqt050$a0ssI2 diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-311.pyc index fa786f4fb832bfc6ddb516d799581a2131944ea1..01e3a279f4b7bb0224affedc2369c26a0c224ea8 100644 GIT binary patch delta 19 ZcmZ3^znq_IIWI340}!~L+{iVT9RMz-1g`)9 delta 19 ZcmZ3^znq_IIWI340}wbL+Q>DR9RMzO1f~E0 diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-311.pyc index a3020519ef54874d99755194f7f556169a34d79b..3c2002e9cf7f72d43a3d7dca00e16cbdfa6b55ea 100644 GIT binary patch delta 19 ZcmZpRZ;R(z&dbZi00gclH*(eJ0{}FL1rz`P delta 19 ZcmZpRZ;R(z&dbZi00hp5HgeVI0{}Ex1q%QG diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-311.pyc index 6860c3730aba6938354f5253e70b58d80ad8391f..adfa7bba72ddf941b706126071148a966c82017f 100644 GIT binary patch delta 19 ZcmaEC@YsNBIWI340}!~L+{hIv0RTGz1vUTx delta 19 ZcmaEC@YsNBIWI340}wbL+Q=0t0RTGE1uXyo diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-311.pyc index 38c1c05bad32c03d59db61077066d4522603afc7..7044d7e9c9b4e72421d83ea57e24e87af28c86ad 100644 GIT binary patch delta 21 bcmbPnl5xgKMy}<&yj%=G;CgZ+S6>PMNyP?L delta 21 bcmbPnl5xgKMy}<&yj%=G;CyH!S6>PMNtOmo diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-311.pyc index 0713a7517ef485770173234a2f410536c55e069c..aa64ad491a30588f2ee0f8114d61dc1c6528e40c 100644 GIT binary patch delta 501 zcmY*VO-NK>6n*D=-+N5i^u}pQbP;Gt8AQ0qg#$L=FQtokX*o>DqwP~BsoU|3^(ZIu}%#++Ht&J$5R^g->bko`rBc0G?95~ zFVIYOw+RI3MbEs74(dI<4orv^^O_7ip{J(d7rE4D1jNMURkVrb^b>T6@9AeaBOYX4%f?oA7-y-FT>wI4U%3ldRJ!^B z(8b&9aiqn`$tA?-&!meXOZv_IfQRaDeS=4dYx3Vk*QM~_Xn1%iL3LB(x_CI__0$xU K|AuI$lm7!qUZtJ@ delta 518 zcmY*VOGs2<7`^Ae|Gil{P1l(o78FfMB~%bp(1ayZP7e#>GNOZGkFn<3JnW96*Ir%> zkqCVBFBF1?7U@>zqgA=6Byu;K2&Mw5jXf8EBm+_ZEIl0f4jjG%=lsdBQjU41J)Sj+ zMCjGX)v1ji1q(Y3SuQbx44)1X6m4H#5n z(JKEQ6xEF7d}Y#`Z;FvzQ>R{=MQ0?zW5yuo!V+#;2nM1d`Xwq zvF&rHA|80C;XF<3DllB6c-=-7S#tLtXBecH`@gEu`eQIt=LT1gi?p7h_XWI`AQ&hbC zRKo(fap^6IU)G|&EDL3VBGt5kes?jTk(REXl2_EH=CO(@(xWOi(WKo01jKS?7k~H%m%>M(Psj8L$ diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-311.pyc index d3e511c05147d22e075a5d4ca568e401cde51aba..77c64052060b8a856e8b39a294ec05c099752f71 100644 GIT binary patch delta 19 ZcmZ2szrvntIWI340}!~L+{iUg9so5&1u6gl delta 19 ZcmZ2szrvntIWI340}wbL+Q>Ce9so5J1t9v$dNa_XY delta 21 bcmcc7!g!;Fk!v|GFBbz4I3L=`<>v$dNV^5# diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-311.pyc index 37fcb3bbdd60c148c510d1e1d3e175cc345dbd43..bd4c6564db0986b75e2fb3949e389ea4f3be16a7 100644 GIT binary patch delta 19 ZcmZpzYOUg0&dbZi00gclH*)>90RTA#1=Iil delta 19 ZcmZpzYOUg0&dbZi00hp5Hgf&80RTAG1c diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py b/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py index 4a06bc6..722ee4e 100644 --- a/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py +++ b/myenv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py @@ -64,9 +64,8 @@ import threading import weakref -from pip._vendor import six - from .. import util +from ..packages import six from ..util.ssl_ import PROTOCOL_TLS_CLIENT from ._securetransport.bindings import CoreFoundation, Security, SecurityConst from ._securetransport.low_level import ( diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-311.pyc index 47b04d07ef7c4c84ce1651e8e02e3a4f4e89cd21..9c2385106a62a8eff80e236020d6194392e626a9 100644 GIT binary patch delta 18 Ycmcc1c$blDIWI340}!~LoXB+<053TO4gdfE delta 18 Ycmcc1c$blDIWI340}wbLn#gq-051~-1poj5 diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-311.pyc index b2e385cc955f87e38ccca6bb980e6192d47e7e30..74d2bdabb957ce81e09d02d8cce559552bb37fef 100644 GIT binary patch delta 21 bcmezWis}C=Ca&eYyj%=G;CgZ+SLs#&UVR6j delta 21 bcmezWis}C=Ca&eYyj%=G;CyH!SLs#&UQP#= diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-311.pyc index 9a4c237749e21cd2082f9728d368724418f7aaf3..adf0bf6119aeaf6e73d941e797951d3721b029dd 100644 GIT binary patch delta 18 YcmaFP_?(ezIWI340}!~LoXB+-05F#YEC2ui delta 18 YcmaFP_?(ezIWI340}wbLn#gq*05EX{BLDyZ diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-311.pyc index 83e1660e0a72ef9044add5f11520ba31ed51dbdb..162a4ad7321ef897474f28ef2f1eba391b07c9cf 100644 GIT binary patch delta 19 ZcmdnRzl)!1IWI340}!~L+{m?o9RM+S1n2+& delta 19 ZcmdnRzl)!1IWI340}wbL+Q_wm9RM*&1m6Gv diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/weakref_finalize.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/weakref_finalize.cpython-311.pyc index 8874083a7e2dad26f6847f5934752748f532b70c..1dc640ad9d61b09f68a445c9803f9904795c35b2 100644 GIT binary patch delta 19 ZcmX?Rcg&7!IWI340}!~L+{k4k4*)op1p)v7 delta 19 ZcmX?Rcg&7!IWI340}wbL+Q?-i4*)o41o;2} diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py b/myenv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py index 14b10da..fb51bf7 100644 --- a/myenv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py +++ b/myenv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py @@ -4,7 +4,7 @@ import functools import logging -from ._collections import RecentlyUsedContainer +from ._collections import HTTPHeaderDict, RecentlyUsedContainer from .connectionpool import HTTPConnectionPool, HTTPSConnectionPool, port_by_scheme from .exceptions import ( LocationValueError, @@ -382,9 +382,12 @@ def urlopen(self, method, url, redirect=True, **kw): # Support relative URLs for redirecting. redirect_location = urljoin(url, redirect_location) - # RFC 7231, Section 6.4.4 if response.status == 303: + # Change the method according to RFC 9110, Section 15.4.4. method = "GET" + # And lose the body not to transfer anything sensitive. + kw["body"] = None + kw["headers"] = HTTPHeaderDict(kw["headers"])._prepare_for_method_change() retries = kw.get("retries") if not isinstance(retries, Retry): diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-311.pyc index 7fbbffc9db4582af9f584943479e70c14b262e93..ff53378820137184fc67762fb9d15482c2a85f61 100644 GIT binary patch delta 19 ZcmeC@?&s!O&dbZi00gclH*&SI0stzE1YH0C delta 19 ZcmeC@?&s!O&dbZi00hp5HgdJH0styq1XKV3 diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-311.pyc index c56f6595ccbd3ed2d095adc156103cade3285034..af0f7f0801060412662289ad22afcfc011f1d4a0 100644 GIT binary patch delta 19 ZcmbQIF;9bQIWI340}!~L+{h&&0st?s1XBP2 delta 19 ZcmbQIF;9bQIWI340}wbL+Q=m$0st?71WEt^ diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-311.pyc index 332536051ddae1978d78ff45072eda47b1f18ef9..414488118374656d0f9e6c9d5f4b6fe538868c8e 100644 GIT binary patch delta 19 ZcmX@YdxV#3IWI340}!~L+{m?y4FEE)1pxp6 delta 19 ZcmX@YdxV#3IWI340}wbL+Q_ww4FEEL1o!{| diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-311.pyc index 8d51db5427f5f5f79d59fff01b8ba8c7c4148bc6..655a9f26feda6eddae50e4bbd63958cc67f1cf93 100644 GIT binary patch delta 19 ZcmaFO{hFI=IWI340}!~L+{pEi6#zIi1#tiX delta 19 ZcmaFO{hFI=IWI340}wbL+Q{{g6#zH|1!w>O diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-311.pyc index ef28d8e830c136c60592a038c196af42ce462c79..253ea534b4cbcc9376cb87aa436da1517bfe2e19 100644 GIT binary patch delta 19 ZcmbQOGFydfIWI340}!~L+{h&;1OP6x1V8`) delta 19 ZcmbQOGFydfIWI340}wbL+Q=m+1OP6C1UCQx diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-311.pyc index 2f10150da514d6d1e21592a69a45447ded479874..cede339d1f5ef89e24b68278f94d432bb5343f0e 100644 GIT binary patch delta 19 ZcmdlWy+N95IWI340}!~L+{m?z7XUGu1n2+& delta 19 ZcmdlWy+N95IWI340}wbL+Q_wx7XUG91m6Gv diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-311.pyc index 53d60fcdb7de7b4aba515716393b6161a6fc3e45..cde93ac4907a1a6f2115a2c982b1cddce0b00d13 100644 GIT binary patch delta 21 bcmZqJ#MrQjk!v|GFBbz4xSrg|^(_JbLyiVh delta 21 bcmZqJ#MrQjk!v|GFBbz4I3L=`^(_JbLth3; diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-311.pyc index d92010c68b5211cabdb549fb1233860084ccf17a..dbf45642a084f6135929576ae660c4698e6c57d7 100644 GIT binary patch delta 21 bcmX@y%y_t&k!v|GFBbz4xSrg|wbKy*MrQ^m delta 21 bcmX@y%y_t&k!v|GFBbz4I3L=`wbKy*MmPo@ diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_match_hostname.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_match_hostname.cpython-311.pyc index c4a7b62c27b94df41f9752f7474b44d81149f1d1..8882a2f8a14448c22be2159422fd6d8bd294ea02 100644 GIT binary patch delta 19 Zcmdm{yG@sCIWI340}!~L+{m>?3;;Ci1t$Oi delta 19 Zcmdm{yG@sCIWI340}wbL+Q_v=3;;B|1s(tZ diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-311.pyc index ca290b332844a9780236cdda93cbb45c92cbfc47..2a5199f44decbc1f727963e3753c9dc9dac0a5c5 100644 GIT binary patch delta 19 Zcmewz^*f4dIWI340}!~L+{jg^3jjnq1?K<& delta 19 Zcmewz^*f4dIWI340}wbL+Q?O?3jjn51>OJv diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-311.pyc index ac46b970c673f05e4858406c6bb413302d3dd167..bd2557d00313c4870197fecd6dfeda2409593645 100644 GIT binary patch delta 19 ZcmcZ`aW{f%IWI340}!~L+{hKI0{}mP1&9Cu delta 19 ZcmcZ`aW{f%IWI340}wbL+Q=2G0{}l#1%Chl diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-311.pyc index 1170ed75d142d02acca572dc6daa8ce510636004..0f0fc0665b42cf204e137be1afe58bf9e2f1e573 100644 GIT binary patch delta 21 bcmdnj$+)kRk!v|GFBbz4xSrg|wZ#PhMtcS) delta 21 bcmdnj$+)kRk!v|GFBbz4I3L=`wZ#PhMob1C diff --git a/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-311.pyc index 15549467939af5df541a52ac650520f5de9630b1..5d2df2f6509ded19e8203178d6a2b4017cc6b2f4 100644 GIT binary patch delta 19 ZcmbQKK2x1*IWI340}!~L+{o203;-|A1i=6R delta 19 ZcmbQKK2x1*IWI340}wbL+Q`)}3;-{m1h@bI diff --git a/myenv/Lib/site-packages/pip/_vendor/vendor.txt b/myenv/Lib/site-packages/pip/_vendor/vendor.txt index 5554c38..e50d946 100644 --- a/myenv/Lib/site-packages/pip/_vendor/vendor.txt +++ b/myenv/Lib/site-packages/pip/_vendor/vendor.txt @@ -1,24 +1,19 @@ -CacheControl==0.13.1 # Make sure to update the license in pyproject.toml for this. -colorama==0.4.6 +CacheControl==0.14.0 distlib==0.3.8 -distro==1.8.0 -msgpack==1.0.5 -packaging==21.3 -platformdirs==3.8.1 -pyparsing==3.1.0 +distro==1.9.0 +msgpack==1.0.8 +packaging==24.1 +platformdirs==4.2.1 pyproject-hooks==1.0.0 -requests==2.31.0 - certifi==2023.7.22 - chardet==5.1.0 - idna==3.4 - urllib3==1.26.17 -rich==13.4.2 - pygments==2.15.1 - typing_extensions==4.7.1 +requests==2.32.3 + certifi==2024.2.2 + idna==3.7 + urllib3==1.26.18 +rich==13.7.1 + pygments==2.17.2 + typing_extensions==4.11.0 resolvelib==1.0.1 -setuptools==68.0.0 -six==1.16.0 -tenacity==8.2.2 +setuptools==69.5.1 +tenacity==8.2.3 tomli==2.0.1 -truststore==0.8.0 -webencodings==0.5.1 +truststore==0.9.1 diff --git a/myenv/Lib/site-packages/pip/_vendor/webencodings/__init__.py b/myenv/Lib/site-packages/pip/_vendor/webencodings/__init__.py deleted file mode 100644 index d21d697..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/webencodings/__init__.py +++ /dev/null @@ -1,342 +0,0 @@ -# coding: utf-8 -""" - - webencodings - ~~~~~~~~~~~~ - - This is a Python implementation of the `WHATWG Encoding standard - `. See README for details. - - :copyright: Copyright 2012 by Simon Sapin - :license: BSD, see LICENSE for details. - -""" - -from __future__ import unicode_literals - -import codecs - -from .labels import LABELS - - -VERSION = '0.5.1' - - -# Some names in Encoding are not valid Python aliases. Remap these. -PYTHON_NAMES = { - 'iso-8859-8-i': 'iso-8859-8', - 'x-mac-cyrillic': 'mac-cyrillic', - 'macintosh': 'mac-roman', - 'windows-874': 'cp874'} - -CACHE = {} - - -def ascii_lower(string): - r"""Transform (only) ASCII letters to lower case: A-Z is mapped to a-z. - - :param string: An Unicode string. - :returns: A new Unicode string. - - This is used for `ASCII case-insensitive - `_ - matching of encoding labels. - The same matching is also used, among other things, - for `CSS keywords `_. - - This is different from the :meth:`~py:str.lower` method of Unicode strings - which also affect non-ASCII characters, - sometimes mapping them into the ASCII range: - - >>> keyword = u'Bac\N{KELVIN SIGN}ground' - >>> assert keyword.lower() == u'background' - >>> assert ascii_lower(keyword) != keyword.lower() - >>> assert ascii_lower(keyword) == u'bac\N{KELVIN SIGN}ground' - - """ - # This turns out to be faster than unicode.translate() - return string.encode('utf8').lower().decode('utf8') - - -def lookup(label): - """ - Look for an encoding by its label. - This is the spec’s `get an encoding - `_ algorithm. - Supported labels are listed there. - - :param label: A string. - :returns: - An :class:`Encoding` object, or :obj:`None` for an unknown label. - - """ - # Only strip ASCII whitespace: U+0009, U+000A, U+000C, U+000D, and U+0020. - label = ascii_lower(label.strip('\t\n\f\r ')) - name = LABELS.get(label) - if name is None: - return None - encoding = CACHE.get(name) - if encoding is None: - if name == 'x-user-defined': - from .x_user_defined import codec_info - else: - python_name = PYTHON_NAMES.get(name, name) - # Any python_name value that gets to here should be valid. - codec_info = codecs.lookup(python_name) - encoding = Encoding(name, codec_info) - CACHE[name] = encoding - return encoding - - -def _get_encoding(encoding_or_label): - """ - Accept either an encoding object or label. - - :param encoding: An :class:`Encoding` object or a label string. - :returns: An :class:`Encoding` object. - :raises: :exc:`~exceptions.LookupError` for an unknown label. - - """ - if hasattr(encoding_or_label, 'codec_info'): - return encoding_or_label - - encoding = lookup(encoding_or_label) - if encoding is None: - raise LookupError('Unknown encoding label: %r' % encoding_or_label) - return encoding - - -class Encoding(object): - """Reresents a character encoding such as UTF-8, - that can be used for decoding or encoding. - - .. attribute:: name - - Canonical name of the encoding - - .. attribute:: codec_info - - The actual implementation of the encoding, - a stdlib :class:`~codecs.CodecInfo` object. - See :func:`codecs.register`. - - """ - def __init__(self, name, codec_info): - self.name = name - self.codec_info = codec_info - - def __repr__(self): - return '' % self.name - - -#: The UTF-8 encoding. Should be used for new content and formats. -UTF8 = lookup('utf-8') - -_UTF16LE = lookup('utf-16le') -_UTF16BE = lookup('utf-16be') - - -def decode(input, fallback_encoding, errors='replace'): - """ - Decode a single string. - - :param input: A byte string - :param fallback_encoding: - An :class:`Encoding` object or a label string. - The encoding to use if :obj:`input` does note have a BOM. - :param errors: Type of error handling. See :func:`codecs.register`. - :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. - :return: - A ``(output, encoding)`` tuple of an Unicode string - and an :obj:`Encoding`. - - """ - # Fail early if `encoding` is an invalid label. - fallback_encoding = _get_encoding(fallback_encoding) - bom_encoding, input = _detect_bom(input) - encoding = bom_encoding or fallback_encoding - return encoding.codec_info.decode(input, errors)[0], encoding - - -def _detect_bom(input): - """Return (bom_encoding, input), with any BOM removed from the input.""" - if input.startswith(b'\xFF\xFE'): - return _UTF16LE, input[2:] - if input.startswith(b'\xFE\xFF'): - return _UTF16BE, input[2:] - if input.startswith(b'\xEF\xBB\xBF'): - return UTF8, input[3:] - return None, input - - -def encode(input, encoding=UTF8, errors='strict'): - """ - Encode a single string. - - :param input: An Unicode string. - :param encoding: An :class:`Encoding` object or a label string. - :param errors: Type of error handling. See :func:`codecs.register`. - :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. - :return: A byte string. - - """ - return _get_encoding(encoding).codec_info.encode(input, errors)[0] - - -def iter_decode(input, fallback_encoding, errors='replace'): - """ - "Pull"-based decoder. - - :param input: - An iterable of byte strings. - - The input is first consumed just enough to determine the encoding - based on the precense of a BOM, - then consumed on demand when the return value is. - :param fallback_encoding: - An :class:`Encoding` object or a label string. - The encoding to use if :obj:`input` does note have a BOM. - :param errors: Type of error handling. See :func:`codecs.register`. - :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. - :returns: - An ``(output, encoding)`` tuple. - :obj:`output` is an iterable of Unicode strings, - :obj:`encoding` is the :obj:`Encoding` that is being used. - - """ - - decoder = IncrementalDecoder(fallback_encoding, errors) - generator = _iter_decode_generator(input, decoder) - encoding = next(generator) - return generator, encoding - - -def _iter_decode_generator(input, decoder): - """Return a generator that first yields the :obj:`Encoding`, - then yields output chukns as Unicode strings. - - """ - decode = decoder.decode - input = iter(input) - for chunck in input: - output = decode(chunck) - if output: - assert decoder.encoding is not None - yield decoder.encoding - yield output - break - else: - # Input exhausted without determining the encoding - output = decode(b'', final=True) - assert decoder.encoding is not None - yield decoder.encoding - if output: - yield output - return - - for chunck in input: - output = decode(chunck) - if output: - yield output - output = decode(b'', final=True) - if output: - yield output - - -def iter_encode(input, encoding=UTF8, errors='strict'): - """ - “Pull”-based encoder. - - :param input: An iterable of Unicode strings. - :param encoding: An :class:`Encoding` object or a label string. - :param errors: Type of error handling. See :func:`codecs.register`. - :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. - :returns: An iterable of byte strings. - - """ - # Fail early if `encoding` is an invalid label. - encode = IncrementalEncoder(encoding, errors).encode - return _iter_encode_generator(input, encode) - - -def _iter_encode_generator(input, encode): - for chunck in input: - output = encode(chunck) - if output: - yield output - output = encode('', final=True) - if output: - yield output - - -class IncrementalDecoder(object): - """ - “Push”-based decoder. - - :param fallback_encoding: - An :class:`Encoding` object or a label string. - The encoding to use if :obj:`input` does note have a BOM. - :param errors: Type of error handling. See :func:`codecs.register`. - :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. - - """ - def __init__(self, fallback_encoding, errors='replace'): - # Fail early if `encoding` is an invalid label. - self._fallback_encoding = _get_encoding(fallback_encoding) - self._errors = errors - self._buffer = b'' - self._decoder = None - #: The actual :class:`Encoding` that is being used, - #: or :obj:`None` if that is not determined yet. - #: (Ie. if there is not enough input yet to determine - #: if there is a BOM.) - self.encoding = None # Not known yet. - - def decode(self, input, final=False): - """Decode one chunk of the input. - - :param input: A byte string. - :param final: - Indicate that no more input is available. - Must be :obj:`True` if this is the last call. - :returns: An Unicode string. - - """ - decoder = self._decoder - if decoder is not None: - return decoder(input, final) - - input = self._buffer + input - encoding, input = _detect_bom(input) - if encoding is None: - if len(input) < 3 and not final: # Not enough data yet. - self._buffer = input - return '' - else: # No BOM - encoding = self._fallback_encoding - decoder = encoding.codec_info.incrementaldecoder(self._errors).decode - self._decoder = decoder - self.encoding = encoding - return decoder(input, final) - - -class IncrementalEncoder(object): - """ - “Push”-based encoder. - - :param encoding: An :class:`Encoding` object or a label string. - :param errors: Type of error handling. See :func:`codecs.register`. - :raises: :exc:`~exceptions.LookupError` for an unknown encoding label. - - .. method:: encode(input, final=False) - - :param input: An Unicode string. - :param final: - Indicate that no more input is available. - Must be :obj:`True` if this is the last call. - :returns: A byte string. - - """ - def __init__(self, encoding=UTF8, errors='strict'): - encoding = _get_encoding(encoding) - self.encode = encoding.codec_info.incrementalencoder(errors).encode diff --git a/myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-311.pyc deleted file mode 100644 index 9ff257a15b28b2e5fa6f8c71e53458206992e800..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12897 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-311.pyc deleted file mode 100644 index 4f436cba25229a577597e700f79476e75a444fdc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7297 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 lk8AtR_qOd=`+4ZSZTPu=?Pqr-MoRI(k diff --git a/myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-311.pyc deleted file mode 100644 index b948d1d7c4b79184ef7c5d5efba107872d16af49..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3225 zcmcIm-*4PR9-pzjKkOvSrM;A-rNzxw4NKb%S4tyAX@Dl%s$AL!mZCP=vU1jwjj7i* zW2b4B4O$^20?HjJ0;SS%(xN-KR=nIvhr|O9h`(SrS}BnwB+$KZZ;L{us89DDJKn@i z)Vr4(d%pg9X1?F?_w)TR{##d8=;wO2GjP4{N!ZAce?2kwM@$1MC=Fn~aI-0|(@E)3ssu7?u5?7-)Ii{N);1Cg^ z$JE%D7@@DA`z`zidbzCEQ}Ocmk|aZ$BU8jEn5t$J?R4p;u1pc#_GaGMtNB8&k|Hq_ zsyIY;W=L3vuR$)E>a0%E{`%p9Y0XouIO7bcpDGv zT7eig8J5py$4|;OA@anfvCNfhMxHjQtP)4jbQ@Ivn;Cf}h27XJ)lCcRXd4a_{8rx> z24)3S;Hm+)yL|~mU$uvQNNw&F^e(QTEV_@`4iVj)BNUjZ?NEjl+evEKS63rII?O?)2U6aR6*)ScMsG4(BO3JUzXtq49=|qO7GV7Qn#nB3iuFuO*HV7*lD$DyF zp)E-hFQ3m$WaV@6+fpb@S(NXGzVS1V6;y=KyJ0Ti3RY2H8|iU$LtWr1oQgwZ*BAJm zq3rAk(#m7QuI821w)!nb<-$(fsT=m@xAzXO``@%pb9aQL$tAL6L2wAJ7`WDUqrP)p zJnIU~uPNRYD6yzl0brI@Bnw2i^mA^!0O%G?I`75<1yH-ZqR!HfReZ`K^r1AOYqnD` zOV()lslYAi5#0nw*`vS&vnOG-{TCor)IyO&Y6pp;uAcQ?xpt`8d#WY2=i+R*=kVQ` zX3s#YqdhF4u6++gBqjc!-+iHxIND4cZHWC%v42fWt%|98$%dG2is>K3uEm+gZ+asy^I$FUPEj_8iSwL9{ypLU8Cq{~=EH3E*Mt%dtX5rPwR~%uW z-nQsy`OqHl29u|mAcOd4xT>h$Jp}jXhiX0dgin*p5HBErnDr+{qwkhBojo%G00olh=imd`Ao zY4PYt^6u5US8HSUhQ7{z)ANtXe@-?|yx2JQQr)}1JI1bh{9=m_gtygfbAGts1sA16 zS9sGl4R+2es!f?IS&}KL8&wJX9ub!Zd)z3w?Z6@JMimQwH&hTZH3L$QhaV6(Vky+I zX#!-a3?#7pCC_p<9)tls1(U2;*lR#GA+NaZgwR6WU6E?0bu5VO2T{~__%rE?p?lAN zKJwR*wd9%Aq*zCR7ihp9bF#{eK@rI!Uv;EqjjOr$2OkNmlVy&=ga9C$FYV72ZO4Vwk=Xf z&&?>#Trq9ZVtc|)Ge@K(HZjB<$I>%Qpqx@lcCh4Zo;2QQ}Wg< zfm+CN!GqX^-C4cN=fO4b)8^bq-dFhrFh1h{qK?wDAixTM{VfnEFc`Nu34=oz=|#A+ z+QF_C$K!!@;YfYgy}2IS*FqQ%Y?F22czv&%sUO(f+-$`;3^HvZ9l-}%s7=meBy=v8 zSNXm=-v_R$W)`1We5SsCtRamzrSXQ4X$qNoa6>)_2VtSz2?i`ipFkgV9Ogg6hxz{i D&qD~2P&nZWX2RJ%utrC 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 diff --git a/myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-311.pyc b/myenv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-311.pyc deleted file mode 100644 index c5ab8cb4704f094b4d630a35c5de29e4cf991214..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3577 zcmcguX>b(B74F$ft7Q*KHivM)6B}dJMj|0ma1;jzR>&yGo5X8;Y&My!c1CE#Uhdfi zq!3%Su`O&F;}d*!<4Yh5-^Mp~Ret3sR5n%ARHZ6a`ITR9De=p{(yvFmT3tUtBHKN|axqngzHEskx60Gblt9GP;W_wzL87gre+vXuQ4SgdMm|%}&HO&A z^N?1y465nIpqV#xIsU-%#Zj;$ubR1H*2o$8Qo3Xo@@ipFEe#p!p$=5mF{@0it&_I4Bh=hCRO(h^wW_-H2S41Z4veS?Gba=!(nT{bt?16086$5Q-RjOn&t}y!47I;6 zwkw|4r4AOTsvD)WnYD!Kf8kd~6}zRJH^o;OTGlKXG@Z5LnOO(Omut2$vtCqA5Q8KY zK|7c3)m=xFq+7h*;_cBr!c{)o8xxu`w$Cb2GgHdc*(T;9!>~Pbi&Rvq`AdOpqxh9(CJ3v^Qhf;mlB)=F&w?dd#rHHP30K^gz~_a@!uu$PU_GGhZy1 zY@b1Cfm#+?A>#QRjdiE?3ddWi#8CQRI-BY-to@}zG1YfR&rUTVqGV#I)E)VBcEmER zRBpt`A4v6^11U@Rs-u|B>`(7AtW?n~ZqW`HdA&flG_qvNe3o<;M}!SXA!9Ts9o6Zy zR-;=`jFG=bR#qY#PVGI@doF%4601aF7yPjqF+~3N&ZM~gqHc=&Y|fX$v%)|-EZ>6b zjxT9YfNGwjA}qmC{?mZ`WE#p!bl6H;-v|{O03jC zc+V{1F(-KKw!VCZIy*VLONNy8E*+t`RI@DI$#89lky1UqE+oFLvxzXNP7SOf<@7vwMZd@ok$_Ms4B$#*dY1m#b(yrPG@&*z**O!kh_asFRF|E zk4oqQ|8K-T6gY)SJu*1hHP559R6K+HX`sI%Xz#Lvi4rx^xqB#{6>&ke1)*QCY7`ek zu}M5LNYS~dU-J0JdYrH#;y*XyP9v=gBj`ud5i2UY|_;Ydqs z+f`SuT(x>l``T;1w{HEl>i4g^e!~qLZ`>5U>E_KHom<42{-Ymv{bbuMKkfe6tv}y> z+b?$PjP>m5y?uAzFZcA{5&zY%e{*NzuDy5PbMJl0-===|d+iVDfsD8{>>DzN_h)nY zLh*iTmC6SW9vT__od9+c*h|1(2KEZDSAo3-i~-}oP62xz*c-s!1ojrN zw}DLpI}Pj%uqj~g0GkGO7TCMM-UIeNun&NJ2<#(Z9|QXY*g0UI0{aZu=fJ)I_9d{d zfPD?@Jg{$oeG7aH_(Q-S2L1@}BfuX8{uuDbfsX?}3j7J+PXeC+{uJ{u1z)fxiO$Rp74yXTUk|Q@~#b{s!yUgN+Y7prC>T=TAo~0Y2SKT4qj=51eS(7YL=a(D9z#u zut*&5I=Qj3w&OAmU6~vAFGkAQ%fN#qyng)dN@(4s=Jrb~TE@GMZkyOPvAwanI(kX` zTi1zyHR2DuE)yZHpco5O)d$_)P}NP8NOiZLv~4`Ts?vJHsr<#(u1agySQvjYH~kxb CSGpGf diff --git a/myenv/Lib/site-packages/pip/_vendor/webencodings/labels.py b/myenv/Lib/site-packages/pip/_vendor/webencodings/labels.py deleted file mode 100644 index 29cbf91..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/webencodings/labels.py +++ /dev/null @@ -1,231 +0,0 @@ -""" - - webencodings.labels - ~~~~~~~~~~~~~~~~~~~ - - Map encoding labels to their name. - - :copyright: Copyright 2012 by Simon Sapin - :license: BSD, see LICENSE for details. - -""" - -# XXX Do not edit! -# This file is automatically generated by mklabels.py - -LABELS = { - 'unicode-1-1-utf-8': 'utf-8', - 'utf-8': 'utf-8', - 'utf8': 'utf-8', - '866': 'ibm866', - 'cp866': 'ibm866', - 'csibm866': 'ibm866', - 'ibm866': 'ibm866', - 'csisolatin2': 'iso-8859-2', - 'iso-8859-2': 'iso-8859-2', - 'iso-ir-101': 'iso-8859-2', - 'iso8859-2': 'iso-8859-2', - 'iso88592': 'iso-8859-2', - 'iso_8859-2': 'iso-8859-2', - 'iso_8859-2:1987': 'iso-8859-2', - 'l2': 'iso-8859-2', - 'latin2': 'iso-8859-2', - 'csisolatin3': 'iso-8859-3', - 'iso-8859-3': 'iso-8859-3', - 'iso-ir-109': 'iso-8859-3', - 'iso8859-3': 'iso-8859-3', - 'iso88593': 'iso-8859-3', - 'iso_8859-3': 'iso-8859-3', - 'iso_8859-3:1988': 'iso-8859-3', - 'l3': 'iso-8859-3', - 'latin3': 'iso-8859-3', - 'csisolatin4': 'iso-8859-4', - 'iso-8859-4': 'iso-8859-4', - 'iso-ir-110': 'iso-8859-4', - 'iso8859-4': 'iso-8859-4', - 'iso88594': 'iso-8859-4', - 'iso_8859-4': 'iso-8859-4', - 'iso_8859-4:1988': 'iso-8859-4', - 'l4': 'iso-8859-4', - 'latin4': 'iso-8859-4', - 'csisolatincyrillic': 'iso-8859-5', - 'cyrillic': 'iso-8859-5', - 'iso-8859-5': 'iso-8859-5', - 'iso-ir-144': 'iso-8859-5', - 'iso8859-5': 'iso-8859-5', - 'iso88595': 'iso-8859-5', - 'iso_8859-5': 'iso-8859-5', - 'iso_8859-5:1988': 'iso-8859-5', - 'arabic': 'iso-8859-6', - 'asmo-708': 'iso-8859-6', - 'csiso88596e': 'iso-8859-6', - 'csiso88596i': 'iso-8859-6', - 'csisolatinarabic': 'iso-8859-6', - 'ecma-114': 'iso-8859-6', - 'iso-8859-6': 'iso-8859-6', - 'iso-8859-6-e': 'iso-8859-6', - 'iso-8859-6-i': 'iso-8859-6', - 'iso-ir-127': 'iso-8859-6', - 'iso8859-6': 'iso-8859-6', - 'iso88596': 'iso-8859-6', - 'iso_8859-6': 'iso-8859-6', - 'iso_8859-6:1987': 'iso-8859-6', - 'csisolatingreek': 'iso-8859-7', - 'ecma-118': 'iso-8859-7', - 'elot_928': 'iso-8859-7', - 'greek': 'iso-8859-7', - 'greek8': 'iso-8859-7', - 'iso-8859-7': 'iso-8859-7', - 'iso-ir-126': 'iso-8859-7', - 'iso8859-7': 'iso-8859-7', - 'iso88597': 'iso-8859-7', - 'iso_8859-7': 'iso-8859-7', - 'iso_8859-7:1987': 'iso-8859-7', - 'sun_eu_greek': 'iso-8859-7', - 'csiso88598e': 'iso-8859-8', - 'csisolatinhebrew': 'iso-8859-8', - 'hebrew': 'iso-8859-8', - 'iso-8859-8': 'iso-8859-8', - 'iso-8859-8-e': 'iso-8859-8', - 'iso-ir-138': 'iso-8859-8', - 'iso8859-8': 'iso-8859-8', - 'iso88598': 'iso-8859-8', - 'iso_8859-8': 'iso-8859-8', - 'iso_8859-8:1988': 'iso-8859-8', - 'visual': 'iso-8859-8', - 'csiso88598i': 'iso-8859-8-i', - 'iso-8859-8-i': 'iso-8859-8-i', - 'logical': 'iso-8859-8-i', - 'csisolatin6': 'iso-8859-10', - 'iso-8859-10': 'iso-8859-10', - 'iso-ir-157': 'iso-8859-10', - 'iso8859-10': 'iso-8859-10', - 'iso885910': 'iso-8859-10', - 'l6': 'iso-8859-10', - 'latin6': 'iso-8859-10', - 'iso-8859-13': 'iso-8859-13', - 'iso8859-13': 'iso-8859-13', - 'iso885913': 'iso-8859-13', - 'iso-8859-14': 'iso-8859-14', - 'iso8859-14': 'iso-8859-14', - 'iso885914': 'iso-8859-14', - 'csisolatin9': 'iso-8859-15', - 'iso-8859-15': 'iso-8859-15', - 'iso8859-15': 'iso-8859-15', - 'iso885915': 'iso-8859-15', - 'iso_8859-15': 'iso-8859-15', - 'l9': 'iso-8859-15', - 'iso-8859-16': 'iso-8859-16', - 'cskoi8r': 'koi8-r', - 'koi': 'koi8-r', - 'koi8': 'koi8-r', - 'koi8-r': 'koi8-r', - 'koi8_r': 'koi8-r', - 'koi8-u': 'koi8-u', - 'csmacintosh': 'macintosh', - 'mac': 'macintosh', - 'macintosh': 'macintosh', - 'x-mac-roman': 'macintosh', - 'dos-874': 'windows-874', - 'iso-8859-11': 'windows-874', - 'iso8859-11': 'windows-874', - 'iso885911': 'windows-874', - 'tis-620': 'windows-874', - 'windows-874': 'windows-874', - 'cp1250': 'windows-1250', - 'windows-1250': 'windows-1250', - 'x-cp1250': 'windows-1250', - 'cp1251': 'windows-1251', - 'windows-1251': 'windows-1251', - 'x-cp1251': 'windows-1251', - 'ansi_x3.4-1968': 'windows-1252', - 'ascii': 'windows-1252', - 'cp1252': 'windows-1252', - 'cp819': 'windows-1252', - 'csisolatin1': 'windows-1252', - 'ibm819': 'windows-1252', - 'iso-8859-1': 'windows-1252', - 'iso-ir-100': 'windows-1252', - 'iso8859-1': 'windows-1252', - 'iso88591': 'windows-1252', - 'iso_8859-1': 'windows-1252', - 'iso_8859-1:1987': 'windows-1252', - 'l1': 'windows-1252', - 'latin1': 'windows-1252', - 'us-ascii': 'windows-1252', - 'windows-1252': 'windows-1252', - 'x-cp1252': 'windows-1252', - 'cp1253': 'windows-1253', - 'windows-1253': 'windows-1253', - 'x-cp1253': 'windows-1253', - 'cp1254': 'windows-1254', - 'csisolatin5': 'windows-1254', - 'iso-8859-9': 'windows-1254', - 'iso-ir-148': 'windows-1254', - 'iso8859-9': 'windows-1254', - 'iso88599': 'windows-1254', - 'iso_8859-9': 'windows-1254', - 'iso_8859-9:1989': 'windows-1254', - 'l5': 'windows-1254', - 'latin5': 'windows-1254', - 'windows-1254': 'windows-1254', - 'x-cp1254': 'windows-1254', - 'cp1255': 'windows-1255', - 'windows-1255': 'windows-1255', - 'x-cp1255': 'windows-1255', - 'cp1256': 'windows-1256', - 'windows-1256': 'windows-1256', - 'x-cp1256': 'windows-1256', - 'cp1257': 'windows-1257', - 'windows-1257': 'windows-1257', - 'x-cp1257': 'windows-1257', - 'cp1258': 'windows-1258', - 'windows-1258': 'windows-1258', - 'x-cp1258': 'windows-1258', - 'x-mac-cyrillic': 'x-mac-cyrillic', - 'x-mac-ukrainian': 'x-mac-cyrillic', - 'chinese': 'gbk', - 'csgb2312': 'gbk', - 'csiso58gb231280': 'gbk', - 'gb2312': 'gbk', - 'gb_2312': 'gbk', - 'gb_2312-80': 'gbk', - 'gbk': 'gbk', - 'iso-ir-58': 'gbk', - 'x-gbk': 'gbk', - 'gb18030': 'gb18030', - 'hz-gb-2312': 'hz-gb-2312', - 'big5': 'big5', - 'big5-hkscs': 'big5', - 'cn-big5': 'big5', - 'csbig5': 'big5', - 'x-x-big5': 'big5', - 'cseucpkdfmtjapanese': 'euc-jp', - 'euc-jp': 'euc-jp', - 'x-euc-jp': 'euc-jp', - 'csiso2022jp': 'iso-2022-jp', - 'iso-2022-jp': 'iso-2022-jp', - 'csshiftjis': 'shift_jis', - 'ms_kanji': 'shift_jis', - 'shift-jis': 'shift_jis', - 'shift_jis': 'shift_jis', - 'sjis': 'shift_jis', - 'windows-31j': 'shift_jis', - 'x-sjis': 'shift_jis', - 'cseuckr': 'euc-kr', - 'csksc56011987': 'euc-kr', - 'euc-kr': 'euc-kr', - 'iso-ir-149': 'euc-kr', - 'korean': 'euc-kr', - 'ks_c_5601-1987': 'euc-kr', - 'ks_c_5601-1989': 'euc-kr', - 'ksc5601': 'euc-kr', - 'ksc_5601': 'euc-kr', - 'windows-949': 'euc-kr', - 'csiso2022kr': 'iso-2022-kr', - 'iso-2022-kr': 'iso-2022-kr', - 'utf-16be': 'utf-16be', - 'utf-16': 'utf-16le', - 'utf-16le': 'utf-16le', - 'x-user-defined': 'x-user-defined', -} diff --git a/myenv/Lib/site-packages/pip/_vendor/webencodings/mklabels.py b/myenv/Lib/site-packages/pip/_vendor/webencodings/mklabels.py deleted file mode 100644 index 295dc92..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/webencodings/mklabels.py +++ /dev/null @@ -1,59 +0,0 @@ -""" - - webencodings.mklabels - ~~~~~~~~~~~~~~~~~~~~~ - - Regenarate the webencodings.labels module. - - :copyright: Copyright 2012 by Simon Sapin - :license: BSD, see LICENSE for details. - -""" - -import json -try: - from urllib import urlopen -except ImportError: - from urllib.request import urlopen - - -def assert_lower(string): - assert string == string.lower() - return string - - -def generate(url): - parts = ['''\ -""" - - webencodings.labels - ~~~~~~~~~~~~~~~~~~~ - - Map encoding labels to their name. - - :copyright: Copyright 2012 by Simon Sapin - :license: BSD, see LICENSE for details. - -""" - -# XXX Do not edit! -# This file is automatically generated by mklabels.py - -LABELS = { -'''] - labels = [ - (repr(assert_lower(label)).lstrip('u'), - repr(encoding['name']).lstrip('u')) - for category in json.loads(urlopen(url).read().decode('ascii')) - for encoding in category['encodings'] - for label in encoding['labels']] - max_len = max(len(label) for label, name in labels) - parts.extend( - ' %s:%s %s,\n' % (label, ' ' * (max_len - len(label)), name) - for label, name in labels) - parts.append('}') - return ''.join(parts) - - -if __name__ == '__main__': - print(generate('http://encoding.spec.whatwg.org/encodings.json')) diff --git a/myenv/Lib/site-packages/pip/_vendor/webencodings/tests.py b/myenv/Lib/site-packages/pip/_vendor/webencodings/tests.py deleted file mode 100644 index e12c10d..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/webencodings/tests.py +++ /dev/null @@ -1,153 +0,0 @@ -# coding: utf-8 -""" - - webencodings.tests - ~~~~~~~~~~~~~~~~~~ - - A basic test suite for Encoding. - - :copyright: Copyright 2012 by Simon Sapin - :license: BSD, see LICENSE for details. - -""" - -from __future__ import unicode_literals - -from . import (lookup, LABELS, decode, encode, iter_decode, iter_encode, - IncrementalDecoder, IncrementalEncoder, UTF8) - - -def assert_raises(exception, function, *args, **kwargs): - try: - function(*args, **kwargs) - except exception: - return - else: # pragma: no cover - raise AssertionError('Did not raise %s.' % exception) - - -def test_labels(): - assert lookup('utf-8').name == 'utf-8' - assert lookup('Utf-8').name == 'utf-8' - assert lookup('UTF-8').name == 'utf-8' - assert lookup('utf8').name == 'utf-8' - assert lookup('utf8').name == 'utf-8' - assert lookup('utf8 ').name == 'utf-8' - assert lookup(' \r\nutf8\t').name == 'utf-8' - assert lookup('u8') is None # Python label. - assert lookup('utf-8 ') is None # Non-ASCII white space. - - assert lookup('US-ASCII').name == 'windows-1252' - assert lookup('iso-8859-1').name == 'windows-1252' - assert lookup('latin1').name == 'windows-1252' - assert lookup('LATIN1').name == 'windows-1252' - assert lookup('latin-1') is None - assert lookup('LATİN1') is None # ASCII-only case insensitivity. - - -def test_all_labels(): - for label in LABELS: - assert decode(b'', label) == ('', lookup(label)) - assert encode('', label) == b'' - for repeat in [0, 1, 12]: - output, _ = iter_decode([b''] * repeat, label) - assert list(output) == [] - assert list(iter_encode([''] * repeat, label)) == [] - decoder = IncrementalDecoder(label) - assert decoder.decode(b'') == '' - assert decoder.decode(b'', final=True) == '' - encoder = IncrementalEncoder(label) - assert encoder.encode('') == b'' - assert encoder.encode('', final=True) == b'' - # All encoding names are valid labels too: - for name in set(LABELS.values()): - assert lookup(name).name == name - - -def test_invalid_label(): - assert_raises(LookupError, decode, b'\xEF\xBB\xBF\xc3\xa9', 'invalid') - assert_raises(LookupError, encode, 'é', 'invalid') - assert_raises(LookupError, iter_decode, [], 'invalid') - assert_raises(LookupError, iter_encode, [], 'invalid') - assert_raises(LookupError, IncrementalDecoder, 'invalid') - assert_raises(LookupError, IncrementalEncoder, 'invalid') - - -def test_decode(): - assert decode(b'\x80', 'latin1') == ('€', lookup('latin1')) - assert decode(b'\x80', lookup('latin1')) == ('€', lookup('latin1')) - assert decode(b'\xc3\xa9', 'utf8') == ('é', lookup('utf8')) - assert decode(b'\xc3\xa9', UTF8) == ('é', lookup('utf8')) - assert decode(b'\xc3\xa9', 'ascii') == ('é', lookup('ascii')) - assert decode(b'\xEF\xBB\xBF\xc3\xa9', 'ascii') == ('é', lookup('utf8')) # UTF-8 with BOM - - assert decode(b'\xFE\xFF\x00\xe9', 'ascii') == ('é', lookup('utf-16be')) # UTF-16-BE with BOM - assert decode(b'\xFF\xFE\xe9\x00', 'ascii') == ('é', lookup('utf-16le')) # UTF-16-LE with BOM - assert decode(b'\xFE\xFF\xe9\x00', 'ascii') == ('\ue900', lookup('utf-16be')) - assert decode(b'\xFF\xFE\x00\xe9', 'ascii') == ('\ue900', lookup('utf-16le')) - - assert decode(b'\x00\xe9', 'UTF-16BE') == ('é', lookup('utf-16be')) - assert decode(b'\xe9\x00', 'UTF-16LE') == ('é', lookup('utf-16le')) - assert decode(b'\xe9\x00', 'UTF-16') == ('é', lookup('utf-16le')) - - assert decode(b'\xe9\x00', 'UTF-16BE') == ('\ue900', lookup('utf-16be')) - assert decode(b'\x00\xe9', 'UTF-16LE') == ('\ue900', lookup('utf-16le')) - assert decode(b'\x00\xe9', 'UTF-16') == ('\ue900', lookup('utf-16le')) - - -def test_encode(): - assert encode('é', 'latin1') == b'\xe9' - assert encode('é', 'utf8') == b'\xc3\xa9' - assert encode('é', 'utf8') == b'\xc3\xa9' - assert encode('é', 'utf-16') == b'\xe9\x00' - assert encode('é', 'utf-16le') == b'\xe9\x00' - assert encode('é', 'utf-16be') == b'\x00\xe9' - - -def test_iter_decode(): - def iter_decode_to_string(input, fallback_encoding): - output, _encoding = iter_decode(input, fallback_encoding) - return ''.join(output) - assert iter_decode_to_string([], 'latin1') == '' - assert iter_decode_to_string([b''], 'latin1') == '' - assert iter_decode_to_string([b'\xe9'], 'latin1') == 'é' - assert iter_decode_to_string([b'hello'], 'latin1') == 'hello' - assert iter_decode_to_string([b'he', b'llo'], 'latin1') == 'hello' - assert iter_decode_to_string([b'hell', b'o'], 'latin1') == 'hello' - assert iter_decode_to_string([b'\xc3\xa9'], 'latin1') == 'é' - assert iter_decode_to_string([b'\xEF\xBB\xBF\xc3\xa9'], 'latin1') == 'é' - assert iter_decode_to_string([ - b'\xEF\xBB\xBF', b'\xc3', b'\xa9'], 'latin1') == 'é' - assert iter_decode_to_string([ - b'\xEF\xBB\xBF', b'a', b'\xc3'], 'latin1') == 'a\uFFFD' - assert iter_decode_to_string([ - b'', b'\xEF', b'', b'', b'\xBB\xBF\xc3', b'\xa9'], 'latin1') == 'é' - assert iter_decode_to_string([b'\xEF\xBB\xBF'], 'latin1') == '' - assert iter_decode_to_string([b'\xEF\xBB'], 'latin1') == 'ï»' - assert iter_decode_to_string([b'\xFE\xFF\x00\xe9'], 'latin1') == 'é' - assert iter_decode_to_string([b'\xFF\xFE\xe9\x00'], 'latin1') == 'é' - assert iter_decode_to_string([ - b'', b'\xFF', b'', b'', b'\xFE\xe9', b'\x00'], 'latin1') == 'é' - assert iter_decode_to_string([ - b'', b'h\xe9', b'llo'], 'x-user-defined') == 'h\uF7E9llo' - - -def test_iter_encode(): - assert b''.join(iter_encode([], 'latin1')) == b'' - assert b''.join(iter_encode([''], 'latin1')) == b'' - assert b''.join(iter_encode(['é'], 'latin1')) == b'\xe9' - assert b''.join(iter_encode(['', 'é', '', ''], 'latin1')) == b'\xe9' - assert b''.join(iter_encode(['', 'é', '', ''], 'utf-16')) == b'\xe9\x00' - assert b''.join(iter_encode(['', 'é', '', ''], 'utf-16le')) == b'\xe9\x00' - assert b''.join(iter_encode(['', 'é', '', ''], 'utf-16be')) == b'\x00\xe9' - assert b''.join(iter_encode([ - '', 'h\uF7E9', '', 'llo'], 'x-user-defined')) == b'h\xe9llo' - - -def test_x_user_defined(): - encoded = b'2,\x0c\x0b\x1aO\xd9#\xcb\x0f\xc9\xbbt\xcf\xa8\xca' - decoded = '2,\x0c\x0b\x1aO\uf7d9#\uf7cb\x0f\uf7c9\uf7bbt\uf7cf\uf7a8\uf7ca' - encoded = b'aa' - decoded = 'aa' - assert decode(encoded, 'x-user-defined') == (decoded, lookup('x-user-defined')) - assert encode(decoded, 'x-user-defined') == encoded diff --git a/myenv/Lib/site-packages/pip/_vendor/webencodings/x_user_defined.py b/myenv/Lib/site-packages/pip/_vendor/webencodings/x_user_defined.py deleted file mode 100644 index d16e326..0000000 --- a/myenv/Lib/site-packages/pip/_vendor/webencodings/x_user_defined.py +++ /dev/null @@ -1,325 +0,0 @@ -# coding: utf-8 -""" - - webencodings.x_user_defined - ~~~~~~~~~~~~~~~~~~~~~~~~~~~ - - An implementation of the x-user-defined encoding. - - :copyright: Copyright 2012 by Simon Sapin - :license: BSD, see LICENSE for details. - -""" - -from __future__ import unicode_literals - -import codecs - - -### Codec APIs - -class Codec(codecs.Codec): - - def encode(self, input, errors='strict'): - return codecs.charmap_encode(input, errors, encoding_table) - - def decode(self, input, errors='strict'): - return codecs.charmap_decode(input, errors, decoding_table) - - -class IncrementalEncoder(codecs.IncrementalEncoder): - def encode(self, input, final=False): - return codecs.charmap_encode(input, self.errors, encoding_table)[0] - - -class IncrementalDecoder(codecs.IncrementalDecoder): - def decode(self, input, final=False): - return codecs.charmap_decode(input, self.errors, decoding_table)[0] - - -class StreamWriter(Codec, codecs.StreamWriter): - pass - - -class StreamReader(Codec, codecs.StreamReader): - pass - - -### encodings module API - -codec_info = codecs.CodecInfo( - name='x-user-defined', - encode=Codec().encode, - decode=Codec().decode, - incrementalencoder=IncrementalEncoder, - incrementaldecoder=IncrementalDecoder, - streamreader=StreamReader, - streamwriter=StreamWriter, -) - - -### Decoding Table - -# Python 3: -# for c in range(256): print(' %r' % chr(c if c < 128 else c + 0xF700)) -decoding_table = ( - '\x00' - '\x01' - '\x02' - '\x03' - '\x04' - '\x05' - '\x06' - '\x07' - '\x08' - '\t' - '\n' - '\x0b' - '\x0c' - '\r' - '\x0e' - '\x0f' - '\x10' - '\x11' - '\x12' - '\x13' - '\x14' - '\x15' - '\x16' - '\x17' - '\x18' - '\x19' - '\x1a' - '\x1b' - '\x1c' - '\x1d' - '\x1e' - '\x1f' - ' ' - '!' - '"' - '#' - '$' - '%' - '&' - "'" - '(' - ')' - '*' - '+' - ',' - '-' - '.' - '/' - '0' - '1' - '2' - '3' - '4' - '5' - '6' - '7' - '8' - '9' - ':' - ';' - '<' - '=' - '>' - '?' - '@' - 'A' - 'B' - 'C' - 'D' - 'E' - 'F' - 'G' - 'H' - 'I' - 'J' - 'K' - 'L' - 'M' - 'N' - 'O' - 'P' - 'Q' - 'R' - 'S' - 'T' - 'U' - 'V' - 'W' - 'X' - 'Y' - 'Z' - '[' - '\\' - ']' - '^' - '_' - '`' - 'a' - 'b' - 'c' - 'd' - 'e' - 'f' - 'g' - 'h' - 'i' - 'j' - 'k' - 'l' - 'm' - 'n' - 'o' - 'p' - 'q' - 'r' - 's' - 't' - 'u' - 'v' - 'w' - 'x' - 'y' - 'z' - '{' - '|' - '}' - '~' - '\x7f' - '\uf780' - '\uf781' - '\uf782' - '\uf783' - '\uf784' - '\uf785' - '\uf786' - '\uf787' - '\uf788' - '\uf789' - '\uf78a' - '\uf78b' - '\uf78c' - '\uf78d' - '\uf78e' - '\uf78f' - '\uf790' - '\uf791' - '\uf792' - '\uf793' - '\uf794' - '\uf795' - '\uf796' - '\uf797' - '\uf798' - '\uf799' - '\uf79a' - '\uf79b' - '\uf79c' - '\uf79d' - '\uf79e' - '\uf79f' - '\uf7a0' - '\uf7a1' - '\uf7a2' - '\uf7a3' - '\uf7a4' - '\uf7a5' - '\uf7a6' - '\uf7a7' - '\uf7a8' - '\uf7a9' - '\uf7aa' - '\uf7ab' - '\uf7ac' - '\uf7ad' - '\uf7ae' - '\uf7af' - '\uf7b0' - '\uf7b1' - '\uf7b2' - '\uf7b3' - '\uf7b4' - '\uf7b5' - '\uf7b6' - '\uf7b7' - '\uf7b8' - '\uf7b9' - '\uf7ba' - '\uf7bb' - '\uf7bc' - '\uf7bd' - '\uf7be' - '\uf7bf' - '\uf7c0' - '\uf7c1' - '\uf7c2' - '\uf7c3' - '\uf7c4' - '\uf7c5' - '\uf7c6' - '\uf7c7' - '\uf7c8' - '\uf7c9' - '\uf7ca' - '\uf7cb' - '\uf7cc' - '\uf7cd' - '\uf7ce' - '\uf7cf' - '\uf7d0' - '\uf7d1' - '\uf7d2' - '\uf7d3' - '\uf7d4' - '\uf7d5' - '\uf7d6' - '\uf7d7' - '\uf7d8' - '\uf7d9' - '\uf7da' - '\uf7db' - '\uf7dc' - '\uf7dd' - '\uf7de' - '\uf7df' - '\uf7e0' - '\uf7e1' - '\uf7e2' - '\uf7e3' - '\uf7e4' - '\uf7e5' - '\uf7e6' - '\uf7e7' - '\uf7e8' - '\uf7e9' - '\uf7ea' - '\uf7eb' - '\uf7ec' - '\uf7ed' - '\uf7ee' - '\uf7ef' - '\uf7f0' - '\uf7f1' - '\uf7f2' - '\uf7f3' - '\uf7f4' - '\uf7f5' - '\uf7f6' - '\uf7f7' - '\uf7f8' - '\uf7f9' - '\uf7fa' - '\uf7fb' - '\uf7fc' - '\uf7fd' - '\uf7fe' - '\uf7ff' -) - -### Encoding table -encoding_table = codecs.charmap_build(decoding_table) diff --git a/myenv/Scripts/pip.exe b/myenv/Scripts/pip.exe index 01bc0dfb458b7b40d6fb39785b55b08dcfb86536..1c082eb130fe7c352b7de78ea5f2767201af346b 100644 GIT binary patch delta 27 hcmbPuo^9fJwuUW?k;|BV?VTRIjPWyw4p`3U2mrPt49@@n delta 27 hcmbPuo^9fJwuUW?k;|AIcTJC8#`qaT2P|iF1OTQ13s(RD diff --git a/myenv/Scripts/pip3.11.exe b/myenv/Scripts/pip3.11.exe index 01bc0dfb458b7b40d6fb39785b55b08dcfb86536..1c082eb130fe7c352b7de78ea5f2767201af346b 100644 GIT binary patch delta 27 hcmbPuo^9fJwuUW?k;|BV?VTRIjPWyw4p`3U2mrPt49@@n delta 27 hcmbPuo^9fJwuUW?k;|AIcTJC8#`qaT2P|iF1OTQ13s(RD diff --git a/myenv/Scripts/pip3.exe b/myenv/Scripts/pip3.exe index 01bc0dfb458b7b40d6fb39785b55b08dcfb86536..1c082eb130fe7c352b7de78ea5f2767201af346b 100644 GIT binary patch delta 27 hcmbPuo^9fJwuUW?k;|BV?VTRIjPWyw4p`3U2mrPt49@@n delta 27 hcmbPuo^9fJwuUW?k;|AIcTJC8#`qaT2P|iF1OTQ13s(RD