From bbf677bfc3a7b4bb5de322611d189e80dee2382c Mon Sep 17 00:00:00 2001 From: Wesley Henriques Date: Mon, 22 Jul 2024 13:56:28 -0300 Subject: [PATCH] $Adding initial documentation files --- .../Como-usar/01-conhecendo-a-interface.md | 58 +- docs/assets/images/Display-Library-Sound.png | Bin 61442 -> 0 bytes ...io => nordest-sampler-presentation.drawio} | 70 +- .../images/nordest-sampler-presentation.html | 11 - mkdocs.yml | 11 +- .../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 - venv/Lib/site-packages/pip/__init__.py | 2 +- venv/Lib/site-packages/pip/__pip-runner__.py | 4 +- .../pip/__pycache__/__init__.cpython-312.pyc | Bin 671 -> 673 bytes .../pip/__pycache__/__main__.cpython-312.pyc | Bin 827 -> 827 bytes .../__pip-runner__.cpython-312.pyc | Bin 2190 -> 2190 bytes .../site-packages/pip/_internal/__init__.py | 2 +- .../__pycache__/__init__.cpython-312.pyc | Bin 773 -> 773 bytes .../__pycache__/build_env.cpython-312.pyc | Bin 14280 -> 14469 bytes .../__pycache__/cache.cpython-312.pyc | Bin 12651 -> 12651 bytes .../__pycache__/configuration.cpython-312.pyc | Bin 17652 -> 17652 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 33270 -> 35565 bytes .../__pycache__/main.cpython-312.pyc | Bin 656 -> 656 bytes .../__pycache__/pyproject.cpython-312.pyc | Bin 4957 -> 4957 bytes .../self_outdated_check.cpython-312.pyc | Bin 10538 -> 10497 bytes .../__pycache__/wheel_builder.cpython-312.pyc | Bin 13635 -> 13624 bytes .../site-packages/pip/_internal/build_env.py | 3 + venv/Lib/site-packages/pip/_internal/cache.py | 2 +- .../cli/__pycache__/__init__.cpython-312.pyc | Bin 264 -> 264 bytes .../autocompletion.cpython-312.pyc | Bin 8451 -> 8618 bytes .../__pycache__/base_command.cpython-312.pyc | Bin 10441 -> 10388 bytes .../__pycache__/cmdoptions.cpython-312.pyc | Bin 30360 -> 30363 bytes .../command_context.cpython-312.pyc | Bin 1767 -> 1767 bytes .../cli/__pycache__/main.cpython-312.pyc | Bin 2284 -> 2286 bytes .../__pycache__/main_parser.cpython-312.pyc | Bin 4891 -> 4891 bytes .../cli/__pycache__/parser.cpython-312.pyc | Bin 15008 -> 15052 bytes .../__pycache__/progress_bars.cpython-312.pyc | Bin 2606 -> 3841 bytes .../__pycache__/req_command.cpython-312.pyc | Bin 18838 -> 12261 bytes .../cli/__pycache__/spinners.cpython-312.pyc | Bin 7826 -> 7826 bytes .../__pycache__/status_codes.cpython-312.pyc | Bin 361 -> 361 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-312.pyc | Bin 3988 -> 3988 bytes .../__pycache__/cache.cpython-312.pyc | Bin 9697 -> 9697 bytes .../__pycache__/check.cpython-312.pyc | Bin 2076 -> 1990 bytes .../__pycache__/completion.cpython-312.pyc | Bin 5178 -> 5178 bytes .../__pycache__/configuration.cpython-312.pyc | Bin 13198 -> 13198 bytes .../__pycache__/debug.cpython-312.pyc | Bin 10147 -> 10100 bytes .../__pycache__/download.cpython-312.pyc | Bin 7575 -> 7494 bytes .../__pycache__/freeze.cpython-312.pyc | Bin 4342 -> 4342 bytes .../commands/__pycache__/hash.cpython-312.pyc | Bin 2969 -> 2969 bytes .../commands/__pycache__/help.cpython-312.pyc | Bin 1659 -> 1659 bytes .../__pycache__/index.cpython-312.pyc | Bin 6706 -> 6662 bytes .../__pycache__/inspect.cpython-312.pyc | Bin 3961 -> 3962 bytes .../__pycache__/install.cpython-312.pyc | Bin 28899 -> 28875 bytes .../commands/__pycache__/list.cpython-312.pyc | Bin 15386 -> 15754 bytes .../__pycache__/search.cpython-312.pyc | Bin 7607 -> 7531 bytes .../commands/__pycache__/show.cpython-312.pyc | Bin 9714 -> 10478 bytes .../__pycache__/uninstall.cpython-312.pyc | Bin 4712 -> 4719 bytes .../__pycache__/wheel.cpython-312.pyc | Bin 8942 -> 8861 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-312.pyc | Bin 927 -> 927 bytes .../__pycache__/base.cpython-312.pyc | Bin 2848 -> 2879 bytes .../__pycache__/installed.cpython-312.pyc | Bin 1686 -> 1686 bytes .../__pycache__/sdist.cpython-312.pyc | Bin 8474 -> 8468 bytes .../__pycache__/wheel.cpython-312.pyc | Bin 2234 -> 2267 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-312.pyc | Bin 218 -> 218 bytes .../__pycache__/collector.cpython-312.pyc | Bin 21872 -> 21613 bytes .../package_finder.cpython-312.pyc | Bin 40721 -> 40639 bytes .../index/__pycache__/sources.cpython-312.pyc | Bin 12590 -> 12590 bytes .../pip/_internal/index/collector.py | 47 +- .../pip/_internal/index/package_finder.py | 32 +- .../pip/_internal/locations/__init__.py | 11 - .../__pycache__/__init__.cpython-312.pyc | Bin 16762 -> 16437 bytes .../__pycache__/_distutils.cpython-312.pyc | Bin 6842 -> 6842 bytes .../__pycache__/_sysconfig.cpython-312.pyc | Bin 7997 -> 8019 bytes .../__pycache__/base.cpython-312.pyc | Bin 3767 -> 3767 bytes .../pip/_internal/locations/_sysconfig.py | 5 +- .../__pycache__/__init__.cpython-312.pyc | Bin 5868 -> 5868 bytes .../__pycache__/_json.cpython-312.pyc | Bin 2861 -> 2916 bytes .../metadata/__pycache__/base.cpython-312.pyc | Bin 35698 -> 35210 bytes .../__pycache__/pkg_resources.cpython-312.pyc | Bin 15776 -> 16091 bytes .../pip/_internal/metadata/_json.py | 4 +- .../pip/_internal/metadata/base.py | 56 +- .../__pycache__/__init__.cpython-312.pyc | Bin 344 -> 344 bytes .../__pycache__/_compat.cpython-312.pyc | Bin 3319 -> 3319 bytes .../__pycache__/_dists.cpython-312.pyc | Bin 13411 -> 13065 bytes .../__pycache__/_envs.cpython-312.pyc | Bin 11166 -> 11165 bytes .../_internal/metadata/importlib/_dists.py | 27 +- .../pip/_internal/metadata/importlib/_envs.py | 2 +- .../pip/_internal/metadata/pkg_resources.py | 45 +- .../__pycache__/__init__.cpython-312.pyc | Bin 252 -> 252 bytes .../__pycache__/candidate.cpython-312.pyc | Bin 1891 -> 1590 bytes .../__pycache__/direct_url.cpython-312.pyc | Bin 11185 -> 10825 bytes .../format_control.cpython-312.pyc | Bin 4213 -> 4213 bytes .../models/__pycache__/index.cpython-312.pyc | Bin 1680 -> 1680 bytes .../installation_report.cpython-312.pyc | Bin 2258 -> 2258 bytes .../models/__pycache__/link.cpython-312.pyc | Bin 25988 -> 26590 bytes .../models/__pycache__/scheme.cpython-312.pyc | Bin 1155 -> 1009 bytes .../__pycache__/search_scope.cpython-312.pyc | Bin 5074 -> 4982 bytes .../selection_prefs.cpython-312.pyc | Bin 1837 -> 1837 bytes .../__pycache__/target_python.cpython-312.pyc | Bin 4940 -> 4940 bytes .../models/__pycache__/wheel.cpython-312.pyc | Bin 5766 -> 5766 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-312.pyc | Bin 240 -> 240 bytes .../network/__pycache__/auth.cpython-312.pyc | Bin 21982 -> 21978 bytes .../network/__pycache__/cache.cpython-312.pyc | Bin 6504 -> 6504 bytes .../__pycache__/download.cpython-312.pyc | Bin 8539 -> 8541 bytes .../__pycache__/lazy_wheel.cpython-312.pyc | Bin 11649 -> 11649 bytes .../__pycache__/session.cpython-312.pyc | Bin 18760 -> 18868 bytes .../network/__pycache__/utils.cpython-312.pyc | Bin 2239 -> 2239 bytes .../__pycache__/xmlrpc.cpython-312.pyc | Bin 2935 -> 2935 bytes .../pip/_internal/network/auth.py | 11 +- .../pip/_internal/network/download.py | 1 + .../pip/_internal/network/session.py | 4 +- .../__pycache__/__init__.cpython-312.pyc | Bin 183 -> 183 bytes .../__pycache__/check.cpython-312.pyc | Bin 7565 -> 5902 bytes .../__pycache__/freeze.cpython-312.pyc | Bin 10103 -> 10167 bytes .../__pycache__/prepare.cpython-312.pyc | Bin 25733 -> 25856 bytes .../__pycache__/__init__.cpython-312.pyc | Bin 189 -> 189 bytes .../__pycache__/build_tracker.cpython-312.pyc | Bin 7809 -> 7705 bytes .../__pycache__/metadata.cpython-312.pyc | Bin 1866 -> 1866 bytes .../metadata_editable.cpython-312.pyc | Bin 1900 -> 1900 bytes .../metadata_legacy.cpython-312.pyc | Bin 3051 -> 3013 bytes .../build/__pycache__/wheel.cpython-312.pyc | Bin 1670 -> 1670 bytes .../wheel_editable.cpython-312.pyc | Bin 2011 -> 2011 bytes .../__pycache__/wheel_legacy.cpython-312.pyc | Bin 3915 -> 3843 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-312.pyc | Bin 252 -> 252 bytes .../editable_legacy.cpython-312.pyc | Bin 1803 -> 1805 bytes .../install/__pycache__/wheel.cpython-312.pyc | Bin 33845 -> 33971 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-312.pyc | Bin 3729 -> 3462 bytes .../__pycache__/constructors.cpython-312.pyc | Bin 21568 -> 21225 bytes .../req/__pycache__/req_file.cpython-312.pyc | Bin 21447 -> 21467 bytes .../__pycache__/req_install.cpython-312.pyc | Bin 38400 -> 38034 bytes .../req/__pycache__/req_set.cpython-312.pyc | Bin 7204 -> 5461 bytes .../__pycache__/req_uninstall.cpython-312.pyc | Bin 32963 -> 32236 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-312.pyc | Bin 183 -> 183 bytes .../__pycache__/base.cpython-312.pyc | Bin 1171 -> 1171 bytes .../__pycache__/__init__.cpython-312.pyc | Bin 190 -> 190 bytes .../__pycache__/resolver.cpython-312.pyc | Bin 22425 -> 22603 bytes .../_internal/resolution/legacy/resolver.py | 25 +- .../__pycache__/__init__.cpython-312.pyc | Bin 194 -> 194 bytes .../__pycache__/base.cpython-312.pyc | Bin 8323 -> 8134 bytes .../__pycache__/candidates.cpython-312.pyc | Bin 30384 -> 29179 bytes .../__pycache__/factory.cpython-312.pyc | Bin 32100 -> 32251 bytes .../found_candidates.cpython-312.pyc | Bin 6194 -> 6793 bytes .../__pycache__/provider.cpython-312.pyc | Bin 10364 -> 10509 bytes .../__pycache__/reporter.cpython-312.pyc | Bin 4921 -> 4921 bytes .../__pycache__/requirements.cpython-312.pyc | Bin 11415 -> 15336 bytes .../__pycache__/resolver.cpython-312.pyc | Bin 12337 -> 12337 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-312.pyc | Bin 178 -> 178 bytes .../__pycache__/_jaraco_text.cpython-312.pyc | Bin 4519 -> 4518 bytes .../utils/__pycache__/_log.cpython-312.pyc | Bin 1849 -> 1849 bytes .../utils/__pycache__/appdirs.cpython-312.pyc | Bin 2393 -> 2393 bytes .../utils/__pycache__/compat.cpython-312.pyc | Bin 2196 -> 2890 bytes .../compatibility_tags.cpython-312.pyc | Bin 5544 -> 5544 bytes .../__pycache__/datetime.cpython-312.pyc | Bin 667 -> 667 bytes .../__pycache__/deprecation.cpython-312.pyc | Bin 4169 -> 4173 bytes .../direct_url_helpers.cpython-312.pyc | Bin 3546 -> 3519 bytes .../__pycache__/egg_link.cpython-312.pyc | Bin 3209 -> 3209 bytes .../__pycache__/encoding.cpython-312.pyc | Bin 2141 -> 2141 bytes .../__pycache__/entrypoints.cpython-312.pyc | Bin 3976 -> 3976 bytes .../__pycache__/filesystem.cpython-312.pyc | Bin 7441 -> 7441 bytes .../__pycache__/filetypes.cpython-312.pyc | Bin 1147 -> 1147 bytes .../utils/__pycache__/glibc.cpython-312.pyc | Bin 2325 -> 2325 bytes .../utils/__pycache__/hashes.cpython-312.pyc | Bin 7537 -> 7525 bytes .../utils/__pycache__/logging.cpython-312.pyc | Bin 13540 -> 13540 bytes .../utils/__pycache__/misc.cpython-312.pyc | Bin 34104 -> 33664 bytes .../utils/__pycache__/models.cpython-312.pyc | Bin 2695 -> 0 bytes .../__pycache__/packaging.cpython-312.pyc | Bin 2566 -> 2566 bytes .../setuptools_build.cpython-312.pyc | Bin 4533 -> 4533 bytes .../__pycache__/subprocess.cpython-312.pyc | Bin 8701 -> 8647 bytes .../__pycache__/temp_dir.cpython-312.pyc | Bin 12045 -> 12045 bytes .../__pycache__/unpacking.cpython-312.pyc | Bin 11091 -> 13514 bytes .../utils/__pycache__/urls.cpython-312.pyc | Bin 2388 -> 2060 bytes .../__pycache__/virtualenv.cpython-312.pyc | Bin 4463 -> 4463 bytes .../utils/__pycache__/wheel.cpython-312.pyc | Bin 5909 -> 5882 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-312.pyc | Bin 517 -> 517 bytes .../vcs/__pycache__/bazaar.cpython-312.pyc | Bin 5009 -> 5047 bytes .../vcs/__pycache__/git.cpython-312.pyc | Bin 18978 -> 19013 bytes .../vcs/__pycache__/mercurial.cpython-312.pyc | Bin 7598 -> 7598 bytes .../__pycache__/subversion.cpython-312.pyc | Bin 12470 -> 12511 bytes .../versioncontrol.cpython-312.pyc | Bin 28996 -> 28994 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-312.pyc | Bin 4679 -> 4490 bytes .../_vendor/__pycache__/six.cpython-312.pyc | Bin 41256 -> 0 bytes .../typing_extensions.cpython-312.pyc | Bin 122036 -> 128113 bytes .../pip/_vendor/cachecontrol/__init__.py | 2 +- .../__pycache__/__init__.cpython-312.pyc | Bin 889 -> 889 bytes .../__pycache__/_cmd.cpython-312.pyc | Bin 2633 -> 2633 bytes .../__pycache__/adapter.cpython-312.pyc | Bin 6451 -> 6451 bytes .../__pycache__/cache.cpython-312.pyc | Bin 3796 -> 3796 bytes .../__pycache__/controller.cpython-312.pyc | Bin 16154 -> 16211 bytes .../__pycache__/filewrapper.cpython-312.pyc | Bin 4334 -> 4334 bytes .../__pycache__/heuristics.cpython-312.pyc | Bin 6681 -> 6681 bytes .../__pycache__/serialize.cpython-312.pyc | Bin 6392 -> 5252 bytes .../__pycache__/wrapper.cpython-312.pyc | Bin 1661 -> 1661 bytes .../pip/_vendor/cachecontrol/adapter.py | 10 +- .../__pycache__/__init__.cpython-312.pyc | Bin 422 -> 422 bytes .../__pycache__/file_cache.cpython-312.pyc | Bin 7697 -> 7775 bytes .../__pycache__/redis_cache.cpython-312.pyc | Bin 2725 -> 2725 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-312.pyc | Bin 305 -> 305 bytes .../__pycache__/__main__.cpython-312.pyc | Bin 632 -> 632 bytes .../certifi/__pycache__/core.cpython-312.pyc | Bin 2836 -> 3207 bytes .../pip/_vendor/certifi/cacert.pem | 321 +- .../site-packages/pip/_vendor/certifi/core.py | 6 + .../pip/_vendor/chardet/__init__.py | 115 - .../__pycache__/__init__.cpython-312.pyc | Bin 4555 -> 0 bytes .../__pycache__/big5freq.cpython-312.pyc | Bin 27186 -> 0 bytes .../__pycache__/big5prober.cpython-312.pyc | Bin 1374 -> 0 bytes .../chardistribution.cpython-312.pyc | Bin 9625 -> 0 bytes .../charsetgroupprober.cpython-312.pyc | Bin 4109 -> 0 bytes .../__pycache__/charsetprober.cpython-312.pyc | Bin 5005 -> 0 bytes .../codingstatemachine.cpython-312.pyc | Bin 3865 -> 0 bytes .../codingstatemachinedict.cpython-312.pyc | Bin 776 -> 0 bytes .../__pycache__/cp949prober.cpython-312.pyc | Bin 1383 -> 0 bytes .../chardet/__pycache__/enums.cpython-312.pyc | Bin 2983 -> 0 bytes .../__pycache__/escprober.cpython-312.pyc | Bin 4553 -> 0 bytes .../chardet/__pycache__/escsm.cpython-312.pyc | Bin 15297 -> 0 bytes .../__pycache__/eucjpprober.cpython-312.pyc | Bin 4370 -> 0 bytes .../__pycache__/euckrfreq.cpython-312.pyc | Bin 12069 -> 0 bytes .../__pycache__/euckrprober.cpython-312.pyc | Bin 1377 -> 0 bytes .../__pycache__/euctwfreq.cpython-312.pyc | Bin 27191 -> 0 bytes .../__pycache__/euctwprober.cpython-312.pyc | Bin 1377 -> 0 bytes .../__pycache__/gb2312freq.cpython-312.pyc | Bin 19113 -> 0 bytes .../__pycache__/gb2312prober.cpython-312.pyc | Bin 1390 -> 0 bytes .../__pycache__/hebrewprober.cpython-312.pyc | Bin 5809 -> 0 bytes .../__pycache__/jisfreq.cpython-312.pyc | Bin 22142 -> 0 bytes .../__pycache__/johabfreq.cpython-312.pyc | Bin 82990 -> 0 bytes .../__pycache__/johabprober.cpython-312.pyc | Bin 1381 -> 0 bytes .../__pycache__/jpcntx.cpython-312.pyc | Bin 39536 -> 0 bytes .../langbulgarianmodel.cpython-312.pyc | Bin 83109 -> 0 bytes .../langgreekmodel.cpython-312.pyc | Bin 76975 -> 0 bytes .../langhebrewmodel.cpython-312.pyc | Bin 77486 -> 0 bytes .../langhungarianmodel.cpython-312.pyc | Bin 83063 -> 0 bytes .../langrussianmodel.cpython-312.pyc | Bin 105238 -> 0 bytes .../__pycache__/langthaimodel.cpython-312.pyc | Bin 77664 -> 0 bytes .../langturkishmodel.cpython-312.pyc | Bin 77503 -> 0 bytes .../__pycache__/latin1prober.cpython-312.pyc | Bin 6989 -> 0 bytes .../macromanprober.cpython-312.pyc | Bin 7169 -> 0 bytes .../mbcharsetprober.cpython-312.pyc | Bin 3890 -> 0 bytes .../mbcsgroupprober.cpython-312.pyc | Bin 1575 -> 0 bytes .../__pycache__/mbcssm.cpython-312.pyc | Bin 38632 -> 0 bytes .../__pycache__/resultdict.cpython-312.pyc | Bin 619 -> 0 bytes .../sbcharsetprober.cpython-312.pyc | Bin 6374 -> 0 bytes .../sbcsgroupprober.cpython-312.pyc | Bin 2344 -> 0 bytes .../__pycache__/sjisprober.cpython-312.pyc | Bin 4482 -> 0 bytes .../universaldetector.cpython-312.pyc | Bin 12256 -> 0 bytes .../__pycache__/utf1632prober.cpython-312.pyc | Bin 9966 -> 0 bytes .../__pycache__/utf8prober.cpython-312.pyc | Bin 3162 -> 0 bytes .../__pycache__/version.cpython-312.pyc | Bin 475 -> 0 bytes .../pip/_vendor/chardet/big5freq.py | 386 -- .../pip/_vendor/chardet/big5prober.py | 47 - .../pip/_vendor/chardet/chardistribution.py | 261 - .../pip/_vendor/chardet/charsetgroupprober.py | 106 - .../pip/_vendor/chardet/charsetprober.py | 147 - .../pip/_vendor/chardet/cli/__init__.py | 0 .../cli/__pycache__/__init__.cpython-312.pyc | Bin 182 -> 0 bytes .../__pycache__/chardetect.cpython-312.pyc | Bin 3999 -> 0 bytes .../pip/_vendor/chardet/cli/chardetect.py | 112 - .../pip/_vendor/chardet/codingstatemachine.py | 90 - .../_vendor/chardet/codingstatemachinedict.py | 19 - .../pip/_vendor/chardet/cp949prober.py | 49 - .../pip/_vendor/chardet/enums.py | 85 - .../pip/_vendor/chardet/escprober.py | 102 - .../pip/_vendor/chardet/escsm.py | 261 - .../pip/_vendor/chardet/eucjpprober.py | 102 - .../pip/_vendor/chardet/euckrfreq.py | 196 - .../pip/_vendor/chardet/euckrprober.py | 47 - .../pip/_vendor/chardet/euctwfreq.py | 388 -- .../pip/_vendor/chardet/euctwprober.py | 47 - .../pip/_vendor/chardet/gb2312freq.py | 284 - .../pip/_vendor/chardet/gb2312prober.py | 47 - .../pip/_vendor/chardet/hebrewprober.py | 316 - .../pip/_vendor/chardet/jisfreq.py | 325 - .../pip/_vendor/chardet/johabfreq.py | 2382 ------- .../pip/_vendor/chardet/johabprober.py | 47 - .../pip/_vendor/chardet/jpcntx.py | 238 - .../pip/_vendor/chardet/langbulgarianmodel.py | 4649 ------------- .../pip/_vendor/chardet/langgreekmodel.py | 4397 ------------ .../pip/_vendor/chardet/langhebrewmodel.py | 4380 ------------ .../pip/_vendor/chardet/langhungarianmodel.py | 4649 ------------- .../pip/_vendor/chardet/langrussianmodel.py | 5725 --------------- .../pip/_vendor/chardet/langthaimodel.py | 4380 ------------ .../pip/_vendor/chardet/langturkishmodel.py | 4380 ------------ .../pip/_vendor/chardet/latin1prober.py | 147 - .../pip/_vendor/chardet/macromanprober.py | 162 - .../pip/_vendor/chardet/mbcharsetprober.py | 95 - .../pip/_vendor/chardet/mbcsgroupprober.py | 57 - .../pip/_vendor/chardet/mbcssm.py | 661 -- .../pip/_vendor/chardet/metadata/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 187 -> 0 bytes .../__pycache__/languages.cpython-312.pyc | Bin 9742 -> 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-312.pyc | Bin 479 -> 0 bytes .../colorama/__pycache__/ansi.cpython-312.pyc | Bin 3937 -> 0 bytes .../__pycache__/ansitowin32.cpython-312.pyc | Bin 16408 -> 0 bytes .../__pycache__/initialise.cpython-312.pyc | Bin 3537 -> 0 bytes .../__pycache__/win32.cpython-312.pyc | Bin 8113 -> 0 bytes .../__pycache__/winterm.cpython-312.pyc | Bin 9075 -> 0 bytes .../pip/_vendor/colorama/ansi.py | 102 - .../pip/_vendor/colorama/ansitowin32.py | 277 - .../pip/_vendor/colorama/initialise.py | 121 - .../pip/_vendor/colorama/tests/__init__.py | 1 - .../__pycache__/__init__.cpython-312.pyc | Bin 185 -> 0 bytes .../__pycache__/ansi_test.cpython-312.pyc | Bin 5454 -> 0 bytes .../ansitowin32_test.cpython-312.pyc | Bin 18090 -> 0 bytes .../initialise_test.cpython-312.pyc | Bin 11735 -> 0 bytes .../__pycache__/isatty_test.cpython-312.pyc | Bin 4891 -> 0 bytes .../tests/__pycache__/utils.cpython-312.pyc | Bin 2475 -> 0 bytes .../__pycache__/winterm_test.cpython-312.pyc | Bin 6599 -> 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-312.pyc | Bin 1256 -> 1256 bytes .../__pycache__/compat.cpython-312.pyc | Bin 45592 -> 45592 bytes .../__pycache__/database.cpython-312.pyc | Bin 66014 -> 66014 bytes .../distlib/__pycache__/index.cpython-312.pyc | Bin 24353 -> 24353 bytes .../__pycache__/locators.cpython-312.pyc | Bin 60145 -> 60145 bytes .../__pycache__/manifest.cpython-312.pyc | Bin 15112 -> 15112 bytes .../__pycache__/markers.cpython-312.pyc | Bin 7669 -> 7669 bytes .../__pycache__/metadata.cpython-312.pyc | Bin 41786 -> 41786 bytes .../__pycache__/resources.cpython-312.pyc | Bin 17312 -> 17312 bytes .../__pycache__/scripts.cpython-312.pyc | Bin 19567 -> 19779 bytes .../distlib/__pycache__/util.cpython-312.pyc | Bin 88243 -> 88243 bytes .../__pycache__/version.cpython-312.pyc | Bin 30353 -> 30353 bytes .../distlib/__pycache__/wheel.cpython-312.pyc | Bin 51848 -> 51848 bytes .../pip/_vendor/distlib/scripts.py | 26 +- .../__pycache__/__init__.cpython-312.pyc | Bin 947 -> 947 bytes .../__pycache__/__main__.cpython-312.pyc | Bin 279 -> 279 bytes .../distro/__pycache__/distro.cpython-312.pyc | Bin 53741 -> 53832 bytes .../pip/_vendor/distro/distro.py | 12 +- .../idna/__pycache__/__init__.cpython-312.pyc | Bin 868 -> 868 bytes .../idna/__pycache__/codec.cpython-312.pyc | Bin 4620 -> 4973 bytes .../idna/__pycache__/compat.cpython-312.pyc | Bin 874 -> 874 bytes .../idna/__pycache__/core.cpython-312.pyc | Bin 16269 -> 15835 bytes .../idna/__pycache__/idnadata.cpython-312.pyc | Bin 38369 -> 99463 bytes .../__pycache__/intranges.cpython-312.pyc | Bin 2625 -> 2625 bytes .../__pycache__/package_data.cpython-312.pyc | Bin 203 -> 203 bytes .../__pycache__/uts46data.cpython-312.pyc | Bin 158857 -> 158835 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-312.pyc | Bin 1818 -> 1728 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 2012 -> 2012 bytes .../msgpack/__pycache__/ext.cpython-312.pyc | Bin 8655 -> 8157 bytes .../__pycache__/fallback.cpython-312.pyc | Bin 43563 -> 42061 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-312.pyc | Bin 617 -> 0 bytes .../__pycache__/__init__.cpython-312.pyc | Bin 453 -> 545 bytes .../__pycache__/_manylinux.cpython-312.pyc | Bin 12063 -> 9717 bytes .../__pycache__/_musllinux.cpython-312.pyc | Bin 6897 -> 4556 bytes .../__pycache__/_structures.cpython-312.pyc | Bin 3228 -> 3228 bytes .../__pycache__/markers.cpython-312.pyc | Bin 14045 -> 11000 bytes .../__pycache__/requirements.cpython-312.pyc | Bin 6933 -> 4397 bytes .../__pycache__/specifiers.cpython-312.pyc | Bin 31234 -> 38751 bytes .../__pycache__/tags.cpython-312.pyc | Bin 18943 -> 21440 bytes .../__pycache__/utils.cpython-312.pyc | Bin 5855 -> 7326 bytes .../__pycache__/version.cpython-312.pyc | Bin 19926 -> 19489 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-312.pyc | Bin 146461 -> 146103 bytes .../pip/_vendor/platformdirs/__init__.py | 137 +- .../pip/_vendor/platformdirs/__main__.py | 4 +- .../__pycache__/__init__.cpython-312.pyc | Bin 18016 -> 19816 bytes .../__pycache__/__main__.cpython-312.pyc | Bin 1933 -> 1955 bytes .../__pycache__/android.cpython-312.pyc | Bin 9431 -> 9962 bytes .../__pycache__/api.cpython-312.pyc | Bin 9659 -> 12918 bytes .../__pycache__/macos.cpython-312.pyc | Bin 5624 -> 7994 bytes .../__pycache__/unix.cpython-312.pyc | Bin 12428 -> 15019 bytes .../__pycache__/version.cpython-312.pyc | Bin 298 -> 584 bytes .../__pycache__/windows.cpython-312.pyc | Bin 12986 -> 13660 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-312.pyc | Bin 3476 -> 3476 bytes .../__pycache__/__main__.cpython-312.pyc | Bin 722 -> 722 bytes .../__pycache__/cmdline.cpython-312.pyc | Bin 26593 -> 26558 bytes .../__pycache__/console.cpython-312.pyc | Bin 2614 -> 2614 bytes .../__pycache__/filter.cpython-312.pyc | Bin 3220 -> 3220 bytes .../__pycache__/formatter.cpython-312.pyc | Bin 4557 -> 4557 bytes .../__pycache__/lexer.cpython-312.pyc | Bin 38317 -> 38372 bytes .../__pycache__/modeline.cpython-312.pyc | Bin 1556 -> 1556 bytes .../__pycache__/plugin.cpython-312.pyc | Bin 3384 -> 3384 bytes .../__pycache__/regexopt.cpython-312.pyc | Bin 4069 -> 4069 bytes .../__pycache__/scanner.cpython-312.pyc | Bin 4744 -> 4744 bytes .../__pycache__/sphinxext.cpython-312.pyc | Bin 11034 -> 11956 bytes .../__pycache__/style.cpython-312.pyc | Bin 6662 -> 6705 bytes .../__pycache__/token.cpython-312.pyc | Bin 8130 -> 8182 bytes .../__pycache__/unistring.cpython-312.pyc | Bin 32976 -> 32976 bytes .../pygments/__pycache__/util.cpython-312.pyc | Bin 13969 -> 13969 bytes .../pip/_vendor/pygments/cmdline.py | 4 +- .../__pycache__/__init__.cpython-312.pyc | Bin 37924 -> 37924 bytes .../_vendor/pygments/formatters/__init__.py | 2 +- .../__pycache__/__init__.cpython-312.pyc | Bin 6914 -> 6932 bytes .../__pycache__/_mapping.cpython-312.pyc | Bin 4203 -> 4203 bytes .../__pycache__/bbcode.cpython-312.pyc | Bin 4182 -> 4182 bytes .../__pycache__/groff.cpython-312.pyc | Bin 7252 -> 7252 bytes .../__pycache__/html.cpython-312.pyc | Bin 40560 -> 40659 bytes .../__pycache__/img.cpython-312.pyc | Bin 27031 -> 28467 bytes .../__pycache__/irc.cpython-312.pyc | Bin 6053 -> 6053 bytes .../__pycache__/latex.cpython-312.pyc | Bin 19942 -> 19942 bytes .../__pycache__/other.cpython-312.pyc | Bin 6872 -> 6872 bytes .../__pycache__/pangomarkup.cpython-312.pyc | Bin 2918 -> 2918 bytes .../__pycache__/rtf.cpython-312.pyc | Bin 6114 -> 6114 bytes .../__pycache__/svg.cpython-312.pyc | Bin 9054 -> 9054 bytes .../__pycache__/terminal.cpython-312.pyc | Bin 5817 -> 5817 bytes .../__pycache__/terminal256.cpython-312.pyc | Bin 15145 -> 15145 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-312.pyc | Bin 14640 -> 14668 bytes .../__pycache__/_mapping.cpython-312.pyc | Bin 64392 -> 67020 bytes .../lexers/__pycache__/python.cpython-312.pyc | Bin 42627 -> 42646 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-312.pyc | Bin 4436 -> 2652 bytes .../pip/_vendor/pygments/token.py | 1 + .../pip/_vendor/pyparsing/__init__.py | 322 - .../__pycache__/__init__.cpython-312.pyc | Bin 7899 -> 0 bytes .../__pycache__/actions.cpython-312.pyc | Bin 8383 -> 0 bytes .../__pycache__/common.cpython-312.pyc | Bin 13402 -> 0 bytes .../__pycache__/core.cpython-312.pyc | Bin 267696 -> 0 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 12982 -> 0 bytes .../__pycache__/helpers.cpython-312.pyc | Bin 48489 -> 0 bytes .../__pycache__/results.cpython-312.pyc | Bin 34098 -> 0 bytes .../__pycache__/testing.cpython-312.pyc | Bin 17176 -> 0 bytes .../__pycache__/unicode.cpython-312.pyc | Bin 13172 -> 0 bytes .../__pycache__/util.cpython-312.pyc | Bin 14892 -> 0 bytes .../pip/_vendor/pyparsing/actions.py | 217 - .../pip/_vendor/pyparsing/common.py | 432 -- .../pip/_vendor/pyparsing/core.py | 6115 ----------------- .../pip/_vendor/pyparsing/diagram/__init__.py | 656 -- .../__pycache__/__init__.cpython-312.pyc | Bin 26801 -> 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-312.pyc | Bin 601 -> 601 bytes .../__pycache__/_compat.cpython-312.pyc | Bin 362 -> 362 bytes .../__pycache__/_impl.cpython-312.pyc | Bin 14713 -> 14713 bytes .../__pycache__/__init__.cpython-312.pyc | Bin 1068 -> 1068 bytes .../__pycache__/_in_process.cpython-312.pyc | Bin 14385 -> 14385 bytes .../pip/_vendor/requests/__init__.py | 9 +- .../__pycache__/__init__.cpython-312.pyc | Bin 5441 -> 5241 bytes .../__pycache__/__version__.cpython-312.pyc | Bin 572 -> 572 bytes .../_internal_utils.cpython-312.pyc | Bin 2012 -> 2012 bytes .../__pycache__/adapters.cpython-312.pyc | Bin 21268 -> 28425 bytes .../requests/__pycache__/api.cpython-312.pyc | Bin 7192 -> 7192 bytes .../requests/__pycache__/auth.cpython-312.pyc | Bin 13911 -> 13911 bytes .../__pycache__/certs.cpython-312.pyc | Bin 910 -> 910 bytes .../__pycache__/compat.cpython-312.pyc | Bin 1495 -> 1665 bytes .../__pycache__/cookies.cpython-312.pyc | Bin 25234 -> 25264 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 7035 -> 7586 bytes .../requests/__pycache__/help.cpython-312.pyc | Bin 4300 -> 4216 bytes .../__pycache__/hooks.cpython-312.pyc | Bin 1040 -> 1040 bytes .../__pycache__/models.cpython-312.pyc | Bin 35436 -> 35466 bytes .../__pycache__/packages.cpython-312.pyc | Bin 760 -> 1275 bytes .../__pycache__/sessions.cpython-312.pyc | Bin 27745 -> 27870 bytes .../__pycache__/status_codes.cpython-312.pyc | Bin 5947 -> 6019 bytes .../__pycache__/structures.cpython-312.pyc | Bin 5605 -> 5605 bytes .../__pycache__/utils.cpython-312.pyc | Bin 36257 -> 36430 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-312.pyc | Bin 622 -> 622 bytes .../__pycache__/providers.cpython-312.pyc | Bin 6839 -> 6839 bytes .../__pycache__/reporters.cpython-312.pyc | Bin 2642 -> 2642 bytes .../__pycache__/resolvers.cpython-312.pyc | Bin 25885 -> 25885 bytes .../__pycache__/structs.cpython-312.pyc | Bin 10494 -> 10494 bytes .../__pycache__/__init__.cpython-312.pyc | Bin 188 -> 188 bytes .../collections_abc.cpython-312.pyc | Bin 408 -> 408 bytes .../pip/_vendor/rich/__main__.py | 1 - .../rich/__pycache__/__init__.cpython-312.pyc | Bin 7003 -> 7003 bytes .../rich/__pycache__/__main__.cpython-312.pyc | Bin 10292 -> 10292 bytes .../__pycache__/_cell_widths.cpython-312.pyc | Bin 7809 -> 7860 bytes .../__pycache__/_emoji_codes.cpython-312.pyc | Bin 205964 -> 205964 bytes .../_emoji_replace.cpython-312.pyc | Bin 1717 -> 1717 bytes .../_export_format.cpython-312.pyc | Bin 2309 -> 2337 bytes .../__pycache__/_extension.cpython-312.pyc | Bin 525 -> 525 bytes .../rich/__pycache__/_fileno.cpython-312.pyc | Bin 843 -> 843 bytes .../rich/__pycache__/_inspect.cpython-312.pyc | Bin 12065 -> 12065 bytes .../__pycache__/_log_render.cpython-312.pyc | Bin 4135 -> 4135 bytes .../rich/__pycache__/_loop.cpython-312.pyc | Bin 1873 -> 1873 bytes .../__pycache__/_null_file.cpython-312.pyc | Bin 3608 -> 3608 bytes .../__pycache__/_palettes.cpython-312.pyc | Bin 5148 -> 5148 bytes .../rich/__pycache__/_pick.cpython-312.pyc | Bin 714 -> 714 bytes .../rich/__pycache__/_ratio.cpython-312.pyc | Bin 6567 -> 6565 bytes .../__pycache__/_spinners.cpython-312.pyc | Bin 13167 -> 13167 bytes .../rich/__pycache__/_stack.cpython-312.pyc | Bin 953 -> 953 bytes .../rich/__pycache__/_timer.cpython-312.pyc | Bin 853 -> 853 bytes .../_win32_console.cpython-312.pyc | Bin 28964 -> 28964 bytes .../rich/__pycache__/_windows.cpython-312.pyc | Bin 2478 -> 2478 bytes .../_windows_renderer.cpython-312.pyc | Bin 3561 -> 3561 bytes .../rich/__pycache__/_wrap.cpython-312.pyc | Bin 2348 -> 3324 bytes .../rich/__pycache__/abc.cpython-312.pyc | Bin 1596 -> 1596 bytes .../rich/__pycache__/align.cpython-312.pyc | Bin 12310 -> 12310 bytes .../rich/__pycache__/ansi.cpython-312.pyc | Bin 9094 -> 9094 bytes .../rich/__pycache__/bar.cpython-312.pyc | Bin 4260 -> 4260 bytes .../rich/__pycache__/box.cpython-312.pyc | Bin 11846 -> 11846 bytes .../rich/__pycache__/cells.cpython-312.pyc | Bin 5606 -> 5807 bytes .../rich/__pycache__/color.cpython-312.pyc | Bin 26558 -> 26558 bytes .../__pycache__/color_triplet.cpython-312.pyc | Bin 1689 -> 1689 bytes .../rich/__pycache__/columns.cpython-312.pyc | Bin 8575 -> 8575 bytes .../rich/__pycache__/console.cpython-312.pyc | Bin 113781 -> 113682 bytes .../__pycache__/constrain.cpython-312.pyc | Bin 2246 -> 2246 bytes .../__pycache__/containers.cpython-312.pyc | Bin 9214 -> 9219 bytes .../rich/__pycache__/control.cpython-312.pyc | Bin 10917 -> 10917 bytes .../default_styles.cpython-312.pyc | Bin 10361 -> 10361 bytes .../rich/__pycache__/diagnose.cpython-312.pyc | Bin 1475 -> 1475 bytes .../rich/__pycache__/emoji.cpython-312.pyc | Bin 4197 -> 4197 bytes .../rich/__pycache__/errors.cpython-312.pyc | Bin 1833 -> 1833 bytes .../__pycache__/file_proxy.cpython-312.pyc | Bin 3565 -> 3565 bytes .../rich/__pycache__/filesize.cpython-312.pyc | Bin 3070 -> 3070 bytes .../__pycache__/highlighter.cpython-312.pyc | Bin 9886 -> 9887 bytes .../rich/__pycache__/json.cpython-312.pyc | Bin 6023 -> 6023 bytes .../rich/__pycache__/jupyter.cpython-312.pyc | Bin 5197 -> 5197 bytes .../rich/__pycache__/layout.cpython-312.pyc | Bin 20208 -> 20208 bytes .../rich/__pycache__/live.cpython-312.pyc | Bin 19131 -> 19131 bytes .../__pycache__/live_render.cpython-312.pyc | Bin 4882 -> 4882 bytes .../rich/__pycache__/logging.cpython-312.pyc | Bin 13542 -> 13542 bytes .../rich/__pycache__/markup.cpython-312.pyc | Bin 9286 -> 9578 bytes .../rich/__pycache__/measure.cpython-312.pyc | Bin 6364 -> 6364 bytes .../rich/__pycache__/padding.cpython-312.pyc | Bin 7122 -> 7122 bytes .../rich/__pycache__/pager.cpython-312.pyc | Bin 1808 -> 1808 bytes .../rich/__pycache__/palette.cpython-312.pyc | Bin 5302 -> 5302 bytes .../rich/__pycache__/panel.cpython-312.pyc | Bin 12085 -> 12176 bytes .../rich/__pycache__/pretty.cpython-312.pyc | Bin 40044 -> 40153 bytes .../rich/__pycache__/progress.cpython-312.pyc | Bin 75066 -> 75107 bytes .../__pycache__/progress_bar.cpython-312.pyc | Bin 10377 -> 10377 bytes .../rich/__pycache__/prompt.cpython-312.pyc | Bin 14769 -> 14775 bytes .../rich/__pycache__/protocol.cpython-312.pyc | Bin 1780 -> 1780 bytes .../rich/__pycache__/region.cpython-312.pyc | Bin 555 -> 555 bytes .../rich/__pycache__/repr.cpython-312.pyc | Bin 6614 -> 6612 bytes .../rich/__pycache__/rule.cpython-312.pyc | Bin 6556 -> 6556 bytes .../rich/__pycache__/scope.cpython-312.pyc | Bin 3818 -> 3818 bytes .../rich/__pycache__/screen.cpython-312.pyc | Bin 2472 -> 2472 bytes .../rich/__pycache__/segment.cpython-312.pyc | Bin 28149 -> 28149 bytes .../rich/__pycache__/spinner.cpython-312.pyc | Bin 6052 -> 6052 bytes .../rich/__pycache__/status.cpython-312.pyc | Bin 6056 -> 6056 bytes .../rich/__pycache__/style.cpython-312.pyc | Bin 33502 -> 33502 bytes .../rich/__pycache__/styled.cpython-312.pyc | Bin 2127 -> 2127 bytes .../rich/__pycache__/syntax.cpython-312.pyc | Bin 39600 -> 39963 bytes .../rich/__pycache__/table.cpython-312.pyc | Bin 43572 -> 43572 bytes .../terminal_theme.cpython-312.pyc | Bin 3336 -> 3336 bytes .../rich/__pycache__/text.cpython-312.pyc | Bin 58951 -> 60881 bytes .../rich/__pycache__/theme.cpython-312.pyc | Bin 6328 -> 6328 bytes .../rich/__pycache__/themes.cpython-312.pyc | Bin 302 -> 302 bytes .../__pycache__/traceback.cpython-312.pyc | Bin 31536 -> 31536 bytes .../rich/__pycache__/tree.cpython-312.pyc | Bin 11427 -> 11427 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 - venv/Lib/site-packages/pip/_vendor/six.py | 998 --- .../pip/_vendor/tenacity/__init__.py | 2 +- .../__pycache__/__init__.cpython-312.pyc | Bin 27074 -> 27155 bytes .../__pycache__/_asyncio.cpython-312.pyc | Bin 4794 -> 4794 bytes .../__pycache__/_utils.cpython-312.pyc | Bin 2303 -> 2303 bytes .../__pycache__/after.cpython-312.pyc | Bin 1612 -> 1612 bytes .../__pycache__/before.cpython-312.pyc | Bin 1452 -> 1452 bytes .../__pycache__/before_sleep.cpython-312.pyc | Bin 2290 -> 2290 bytes .../tenacity/__pycache__/nap.cpython-312.pyc | Bin 1400 -> 1400 bytes .../__pycache__/retry.cpython-312.pyc | Bin 14269 -> 14269 bytes .../tenacity/__pycache__/stop.cpython-312.pyc | Bin 5556 -> 5556 bytes .../__pycache__/tornadoweb.cpython-312.pyc | Bin 2574 -> 2574 bytes .../tenacity/__pycache__/wait.cpython-312.pyc | Bin 12401 -> 12401 bytes .../__pycache__/__init__.cpython-312.pyc | Bin 372 -> 372 bytes .../tomli/__pycache__/_parser.cpython-312.pyc | Bin 26915 -> 26915 bytes .../tomli/__pycache__/_re.cpython-312.pyc | Bin 3896 -> 3896 bytes .../tomli/__pycache__/_types.cpython-312.pyc | Bin 354 -> 354 bytes .../pip/_vendor/truststore/__init__.py | 2 +- .../__pycache__/__init__.cpython-312.pyc | Bin 606 -> 606 bytes .../__pycache__/_api.cpython-312.pyc | Bin 15785 -> 16529 bytes .../__pycache__/_macos.cpython-312.pyc | Bin 16650 -> 16565 bytes .../__pycache__/_openssl.cpython-312.pyc | Bin 2203 -> 2203 bytes .../_ssl_constants.cpython-312.pyc | Bin 1087 -> 1087 bytes .../__pycache__/_windows.cpython-312.pyc | Bin 15494 -> 15738 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-312.pyc | Bin 3393 -> 3393 bytes .../__pycache__/_collections.cpython-312.pyc | Bin 15919 -> 16476 bytes .../__pycache__/_version.cpython-312.pyc | Bin 206 -> 206 bytes .../__pycache__/connection.cpython-312.pyc | Bin 20395 -> 20395 bytes .../connectionpool.cpython-312.pyc | Bin 36267 -> 36430 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 13481 -> 13481 bytes .../__pycache__/fields.cpython-312.pyc | Bin 10397 -> 10397 bytes .../__pycache__/filepost.cpython-312.pyc | Bin 4006 -> 4006 bytes .../__pycache__/poolmanager.cpython-312.pyc | Bin 20290 -> 20460 bytes .../__pycache__/request.cpython-312.pyc | Bin 7282 -> 7282 bytes .../__pycache__/response.cpython-312.pyc | Bin 33956 -> 33956 bytes .../pip/_vendor/urllib3/_collections.py | 18 + .../pip/_vendor/urllib3/_version.py | 2 +- .../pip/_vendor/urllib3/connectionpool.py | 5 + .../__pycache__/__init__.cpython-312.pyc | Bin 186 -> 186 bytes .../_appengine_environ.cpython-312.pyc | Bin 1836 -> 1836 bytes .../__pycache__/appengine.cpython-312.pyc | Bin 11552 -> 11552 bytes .../__pycache__/ntlmpool.cpython-312.pyc | Bin 5707 -> 5707 bytes .../__pycache__/pyopenssl.cpython-312.pyc | Bin 24438 -> 24438 bytes .../securetransport.cpython-312.pyc | Bin 35544 -> 35541 bytes .../contrib/__pycache__/socks.cpython-312.pyc | Bin 7499 -> 7499 bytes .../__pycache__/__init__.cpython-312.pyc | Bin 203 -> 203 bytes .../__pycache__/bindings.cpython-312.pyc | Bin 17415 -> 17415 bytes .../__pycache__/low_level.cpython-312.pyc | Bin 14789 -> 14789 bytes .../urllib3/contrib/securetransport.py | 3 +- .../__pycache__/__init__.cpython-312.pyc | Bin 187 -> 187 bytes .../packages/__pycache__/six.cpython-312.pyc | Bin 41307 -> 41307 bytes .../__pycache__/__init__.cpython-312.pyc | Bin 197 -> 197 bytes .../__pycache__/makefile.cpython-312.pyc | Bin 1813 -> 1813 bytes .../weakref_finalize.cpython-312.pyc | Bin 7319 -> 7319 bytes .../pip/_vendor/urllib3/poolmanager.py | 7 +- .../util/__pycache__/__init__.cpython-312.pyc | Bin 1134 -> 1134 bytes .../__pycache__/connection.cpython-312.pyc | Bin 4744 -> 4744 bytes .../util/__pycache__/proxy.cpython-312.pyc | Bin 1540 -> 1540 bytes .../util/__pycache__/queue.cpython-312.pyc | Bin 1340 -> 1340 bytes .../util/__pycache__/request.cpython-312.pyc | Bin 4171 -> 4171 bytes .../util/__pycache__/response.cpython-312.pyc | Bin 2977 -> 2977 bytes .../util/__pycache__/retry.cpython-312.pyc | Bin 21685 -> 21685 bytes .../util/__pycache__/ssl_.cpython-312.pyc | Bin 15091 -> 15091 bytes .../ssl_match_hostname.cpython-312.pyc | Bin 5059 -> 5059 bytes .../__pycache__/ssltransport.cpython-312.pyc | Bin 10760 -> 10760 bytes .../util/__pycache__/timeout.cpython-312.pyc | Bin 11127 -> 11127 bytes .../util/__pycache__/url.cpython-312.pyc | Bin 15783 -> 15783 bytes .../util/__pycache__/wait.cpython-312.pyc | Bin 4391 -> 4391 bytes venv/Lib/site-packages/pip/_vendor/vendor.txt | 35 +- .../pip/_vendor/webencodings/__init__.py | 342 - .../__pycache__/__init__.cpython-312.pyc | Bin 11989 -> 0 bytes .../__pycache__/labels.cpython-312.pyc | Bin 7120 -> 0 bytes .../__pycache__/mklabels.cpython-312.pyc | Bin 2687 -> 0 bytes .../__pycache__/tests.cpython-312.pyc | Bin 9239 -> 0 bytes .../x_user_defined.cpython-312.pyc | Bin 3283 -> 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 - venv/Scripts/pip.exe | Bin 108411 -> 108411 bytes venv/Scripts/pip3.12.exe | Bin 108411 -> 108411 bytes venv/Scripts/pip3.exe | Bin 108411 -> 108411 bytes 788 files changed, 7335 insertions(+), 62071 deletions(-) delete mode 100644 docs/assets/images/Display-Library-Sound.png rename docs/assets/images/{drawio files/Nordeste Sampler (Documentation).drawio => nordest-sampler-presentation.drawio} (99%) delete mode 100644 docs/assets/images/nordest-sampler-presentation.html delete mode 100644 venv/Lib/site-packages/pip-24.0.dist-info/AUTHORS.txt delete mode 100644 venv/Lib/site-packages/pip-24.0.dist-info/INSTALLER delete mode 100644 venv/Lib/site-packages/pip-24.0.dist-info/LICENSE.txt delete mode 100644 venv/Lib/site-packages/pip-24.0.dist-info/METADATA delete mode 100644 venv/Lib/site-packages/pip-24.0.dist-info/RECORD delete mode 100644 venv/Lib/site-packages/pip-24.0.dist-info/REQUESTED delete mode 100644 venv/Lib/site-packages/pip-24.0.dist-info/WHEEL delete mode 100644 venv/Lib/site-packages/pip-24.0.dist-info/entry_points.txt delete mode 100644 venv/Lib/site-packages/pip-24.0.dist-info/top_level.txt delete mode 100644 venv/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_internal/utils/models.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__init__.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachinedict.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/johabfreq.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/johabprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/macromanprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/resultdict.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf1632prober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/big5freq.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/big5prober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/chardistribution.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/charsetprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/codingstatemachinedict.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/cp949prober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/enums.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/escprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/escsm.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/euckrprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/euctwprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/jisfreq.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/johabfreq.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/johabprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/jpcntx.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/latin1prober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/macromanprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/mbcssm.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/metadata/__init__.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/languages.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/py.typed delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/resultdict.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/sjisprober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/universaldetector.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/utf1632prober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/utf8prober.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/chardet/version.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/__init__.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/ansi.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/initialise.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/__init__.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/ansi_test.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/ansitowin32_test.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/initialise_test.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/isatty_test.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/utils.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/winterm_test.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/ansi_test.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/ansitowin32_test.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/initialise_test.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/isatty_test.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/utils.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/tests/winterm_test.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/win32.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/colorama/winterm.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/packaging/__about__.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__init__.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/actions.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/common.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/core.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/exceptions.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/helpers.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/results.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/testing.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/unicode.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/util.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/actions.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/common.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/core.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__init__.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/exceptions.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/helpers.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/py.typed delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/results.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/testing.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/unicode.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/pyparsing/util.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/six.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/webencodings/__init__.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-312.pyc delete mode 100644 venv/Lib/site-packages/pip/_vendor/webencodings/labels.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/webencodings/mklabels.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/webencodings/tests.py delete mode 100644 venv/Lib/site-packages/pip/_vendor/webencodings/x_user_defined.py diff --git a/docs/Nordest-Sampler/Como-usar/01-conhecendo-a-interface.md b/docs/Nordest-Sampler/Como-usar/01-conhecendo-a-interface.md index 1d6817c..e59da4d 100644 --- a/docs/Nordest-Sampler/Como-usar/01-conhecendo-a-interface.md +++ b/docs/Nordest-Sampler/Como-usar/01-conhecendo-a-interface.md @@ -10,19 +10,20 @@ Nesta imagem, listado em seções numéricas, temos todas as funcionalidades dis ![Nordest Sampler - Presentation](../../assets/images/nordest-sampler-presentation.svg) +![Page-1](../../assets/images/nordest-sampler-presentation.drawio) + !!! info "Parâmetros de controle do plugin" - | Seção | Descrição | - | :---------------------- | :--------------------------------------------------------------------------- | - | 01. Sound List | Exibição de timbres e módulos sonoros, com controles de NEXT/PREV para ambos | - | 02. Master Volume | Controla o volume geral de saída do plugin | - | 03. Sound Modify | Controles básicos attack, decay, sustain e release das amostras de áudio | - | 04. FX Mixer | Controles de mix dos efeitos: Drive, Delay, Chorus e Reverb | - | 05. Instrument Settings | Trás ajustes de controle de LFO avançados, veloticy e outros | - | 06. Delay Section | Mostra os parâmetros de ajustes e controles do Delay | - | 07. Chorus/Distortion | Mostra os parâmetros de ajustes e controles do Chorus e Distortion | - | 08. Reverb | Mostra os parâmetros de ajustes e controles do Reverb | - | 09. Velocity Amp | Trás ajustes mais precisos de controle do Velocity | - | 10. Group List/Mode | Seletor de grupos manual com ajustes de seleção de grupos de forma personalizada | + + [01. Sound List](#01-sound-list) + [02. Master Volume](#02-master-volume) | Controla o volume geral de saída do plugin + [03. Sound Modify](#03-sound-modify) | Controles básicos attack, decay, sustain e release das amostras de áudio + [04. FX Mixer](#04-fx-mixer) | Controles de mix dos efeitos: Drive, Delay, Chorus e Reverb + [05. Instrument Settings](#05-instrument-settings) | Trás ajustes de controle de LFO avançados, veloticy e outros + [06. Delay](#06-delay) | Mostra os parâmetros de ajustes e controles do Delay + [07. Chorus/Distortion](#07-chorus---distortioncab) | Mostra os parâmetros de ajustes e controles do Chorus e Distortion + [08. Reverb](#08-reverb) | Mostra os parâmetros de ajustes e controles do Reverb + 09. Velocity Amp | Trás ajustes mais precisos de controle do Velocity + 10. Group List/Mode | Seletor de grupos manual com ajustes de seleção de grupos de forma personalizada Nos próximos tópicos, traremos diversas informações completas sobre cada uma dessas Seções e como os seus ajustes podem afetar diretamente o som do seu instrumento virtual durante sua performance ou produção musical. @@ -30,7 +31,8 @@ Nos próximos tópicos, traremos diversas informações completas sobre cada uma ![Nordest Sampler - Sound List](../../assets/images/nordest-sampler-sound-list.svg) -Aqui nós temos quatro seções, onde cada uma delas representa exatamente: +Nesta seção nós temos a exibição de timbres e módulos sonoros, com controles de NEXT/PREV para ambos. +Aqui nós temos alguns controles básicos, onde cada um deles representa exatamente: - [x] **Module View:** uma tela que mostra o nome do módulo de sons que está selecionado; - [x] **Group View (Instrument View):** uma tela que mostra o som do módulo selecionado que está ativo; @@ -104,4 +106,32 @@ Abaixo estão listados todos os parâmetros: Nesta seção você tem acesso aos controles destinados aos efeitos de chorus, distorção e cabinet simulator. Abaixo estão listados todos os parâmetros: -- [x] **Toggle ON/OFF:** Estes 3 botões ligam e desligam os efeitos desta seção; \ No newline at end of file +- [x] **Toggle ON/OFF:** Estes 3 botões ligam e desligam os efeitos desta seção; + +!!! info "Informação importante" + + Um dos controles **Toggle ON/OFF** liga ou desliga o efeito de Cab Simulator ou Cabinet. Este controle simula um som gerado por um amplificador de guitarra, e funciona em formato de áudio **MONO**, ao habilitar este efeito certifique-se de que o seu som estará sendo mudado para **MONO** e você irá notar que haverá uma diferença notória. + +- [x] **Frequency:** Este controle ajusta a velocidade que o chorus irá operar; +- [x] **Mod Depth:** Este controle ajusta a quantidade de modulação de pitch que o chorus vai gerar no som; +- [x] **Drive:** Este controle vai determinar a quantidade de distorção harmônica sobre o som dos instrumentos; +- [x] **Gain:** Este controel regula a quantidade de ganho de sinal gerado pelo Drive Distortion/Cabinet. + +## 08. Reverb + +Nesta seção você tem acesso aos controles destinados ao efeito de Reverb do Nordest Sampler. +Abaixo estão listados todos os parâmetros: + +- [x] **Toggle ON/OFF:** Este botão liga e desliga o efeito de Reverb; +- [x] **Size:** Este botão regula a duração do efeito de reverb, popularmente conhecido como tamanho ou size; +- [x] **Damping:** Este botão vai determinar a dispersação de frequências altas; + +!!! example "Exemplo de uso do Damping" + + Para entender melhor este controle, basta fazer uso dele em suas extremindades, ele completamente para a esquerda, serão audíveis todas as frequências agudas, ele completamente para a direita, serão dispersas com mais rapidez as frequências agudas, trazendo assim a característica de um Reverb mais Dark no seu som. + +- [x] **Width:** Este controle regula a abertura stereo do efeito de Reverb no som; +- [x] **LFO Rate:** Este controle não está relacionado ao reverb, mas sim aos controles avançados da aba [Instrument Settings](#05-instrument-settings), e tem o propósito de regular a velocidade do LFO que gera sinais como trêmolo, auto pan e outros; +- [x] **LFO Depth:** Este controle também está relacionado aos parâmetros de LFO da aba [Instrument Settings](#05-instrument-settings), o qual regula exatamente a intensidade do efeito gerado pelo LFO. + +## \ No newline at end of file diff --git a/docs/assets/images/Display-Library-Sound.png b/docs/assets/images/Display-Library-Sound.png deleted file mode 100644 index 62faafb08e8fb40a14b135382a5c772391033778..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 61442 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 diff --git a/docs/assets/images/drawio files/Nordeste Sampler (Documentation).drawio b/docs/assets/images/nordest-sampler-presentation.drawio similarity index 99% rename from docs/assets/images/drawio files/Nordeste Sampler (Documentation).drawio rename to docs/assets/images/nordest-sampler-presentation.drawio index a407b0e..b5d13cc 100644 --- a/docs/assets/images/drawio files/Nordeste Sampler (Documentation).drawio +++ b/docs/assets/images/nordest-sampler-presentation.drawio @@ -1,110 +1,110 @@ - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + diff --git a/docs/assets/images/nordest-sampler-presentation.html b/docs/assets/images/nordest-sampler-presentation.html deleted file mode 100644 index fd201b0..0000000 --- a/docs/assets/images/nordest-sampler-presentation.html +++ /dev/null @@ -1,11 +0,0 @@ - - - - -Nordeste Sampler (Documentation)-Página-1 - - -
- - - \ No newline at end of file diff --git a/mkdocs.yml b/mkdocs.yml index fe57002..faa3912 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -33,19 +33,16 @@ theme: accent: indigo plugins: - - git-revision-date-localized: - enable_creation_date: true - - offline - - info: - enabled: true - enabled_on_serve: true + - search - social: cards: true enabled: !ENV [CI, false] + - tags + - offline - search: lang: pt + - drawio_file - print-site - - tags extra: social: diff --git a/venv/Lib/site-packages/pip-24.0.dist-info/AUTHORS.txt b/venv/Lib/site-packages/pip-24.0.dist-info/AUTHORS.txt deleted file mode 100644 index 0e63548..0000000 --- a/venv/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/venv/Lib/site-packages/pip-24.0.dist-info/INSTALLER b/venv/Lib/site-packages/pip-24.0.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/venv/Lib/site-packages/pip-24.0.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/Lib/site-packages/pip-24.0.dist-info/LICENSE.txt b/venv/Lib/site-packages/pip-24.0.dist-info/LICENSE.txt deleted file mode 100644 index 8e7b65e..0000000 --- a/venv/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/venv/Lib/site-packages/pip-24.0.dist-info/METADATA b/venv/Lib/site-packages/pip-24.0.dist-info/METADATA deleted file mode 100644 index e5b45bd..0000000 --- a/venv/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/venv/Lib/site-packages/pip-24.0.dist-info/RECORD b/venv/Lib/site-packages/pip-24.0.dist-info/RECORD deleted file mode 100644 index 4dcde68..0000000 --- a/venv/Lib/site-packages/pip-24.0.dist-info/RECORD +++ /dev/null @@ -1,1024 +0,0 @@ -../../Scripts/pip.exe,sha256=Uq_3n7vOY8q5vSuH2CQCQXU2qNmR9ZStcQzoSPWr43Q,108411 -../../Scripts/pip3.12.exe,sha256=Uq_3n7vOY8q5vSuH2CQCQXU2qNmR9ZStcQzoSPWr43Q,108411 -../../Scripts/pip3.exe,sha256=Uq_3n7vOY8q5vSuH2CQCQXU2qNmR9ZStcQzoSPWr43Q,108411 -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-312.pyc,, -pip/__pycache__/__main__.cpython-312.pyc,, -pip/__pycache__/__pip-runner__.cpython-312.pyc,, -pip/_internal/__init__.py,sha256=iqZ5-YQsQV08tkUc7L806Reop6tguLFWf70ySF6be0Y,515 -pip/_internal/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/__pycache__/build_env.cpython-312.pyc,, -pip/_internal/__pycache__/cache.cpython-312.pyc,, -pip/_internal/__pycache__/configuration.cpython-312.pyc,, -pip/_internal/__pycache__/exceptions.cpython-312.pyc,, -pip/_internal/__pycache__/main.cpython-312.pyc,, -pip/_internal/__pycache__/pyproject.cpython-312.pyc,, -pip/_internal/__pycache__/self_outdated_check.cpython-312.pyc,, -pip/_internal/__pycache__/wheel_builder.cpython-312.pyc,, -pip/_internal/build_env.py,sha256=1ESpqw0iupS_K7phZK5zshVE5Czy9BtGLFU4W6Enva8,10243 -pip/_internal/cache.py,sha256=uiYD-9F0Bv1C8ZyWE85lpzDmQf7hcUkgL99GmI8I41Q,10370 -pip/_internal/cli/__init__.py,sha256=FkHBgpxxb-_gd6r1FjnNhfMOzAUYyXoXKJ6abijfcFU,132 -pip/_internal/cli/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/cli/__pycache__/autocompletion.cpython-312.pyc,, -pip/_internal/cli/__pycache__/base_command.cpython-312.pyc,, -pip/_internal/cli/__pycache__/cmdoptions.cpython-312.pyc,, -pip/_internal/cli/__pycache__/command_context.cpython-312.pyc,, -pip/_internal/cli/__pycache__/main.cpython-312.pyc,, -pip/_internal/cli/__pycache__/main_parser.cpython-312.pyc,, -pip/_internal/cli/__pycache__/parser.cpython-312.pyc,, -pip/_internal/cli/__pycache__/progress_bars.cpython-312.pyc,, -pip/_internal/cli/__pycache__/req_command.cpython-312.pyc,, -pip/_internal/cli/__pycache__/spinners.cpython-312.pyc,, -pip/_internal/cli/__pycache__/status_codes.cpython-312.pyc,, -pip/_internal/cli/autocompletion.py,sha256=_br_5NgSxSuvPjMF0MLHzS5s6BpSkQAQHKrLK89VauM,6690 -pip/_internal/cli/base_command.py,sha256=iuVWGa2oTq7gBReo0er3Z0tXJ2oqBIC6QjDHcnDhKXY,8733 -pip/_internal/cli/cmdoptions.py,sha256=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-312.pyc,, -pip/_internal/commands/__pycache__/cache.cpython-312.pyc,, -pip/_internal/commands/__pycache__/check.cpython-312.pyc,, -pip/_internal/commands/__pycache__/completion.cpython-312.pyc,, -pip/_internal/commands/__pycache__/configuration.cpython-312.pyc,, -pip/_internal/commands/__pycache__/debug.cpython-312.pyc,, -pip/_internal/commands/__pycache__/download.cpython-312.pyc,, -pip/_internal/commands/__pycache__/freeze.cpython-312.pyc,, -pip/_internal/commands/__pycache__/hash.cpython-312.pyc,, -pip/_internal/commands/__pycache__/help.cpython-312.pyc,, -pip/_internal/commands/__pycache__/index.cpython-312.pyc,, -pip/_internal/commands/__pycache__/inspect.cpython-312.pyc,, -pip/_internal/commands/__pycache__/install.cpython-312.pyc,, -pip/_internal/commands/__pycache__/list.cpython-312.pyc,, -pip/_internal/commands/__pycache__/search.cpython-312.pyc,, -pip/_internal/commands/__pycache__/show.cpython-312.pyc,, -pip/_internal/commands/__pycache__/uninstall.cpython-312.pyc,, -pip/_internal/commands/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/commands/cache.py,sha256=xg76_ZFEBC6zoQ3gXLRfMZJft4z2a0RwH4GEFZC6nnU,7944 -pip/_internal/commands/check.py,sha256=Rb13Q28yoLh0j1gpx5SU0jlResNct21eQCRsnaO9xKA,1782 -pip/_internal/commands/completion.py,sha256=HT4lD0bgsflHq2IDgYfiEdp7IGGtE7s6MgI3xn0VQEw,4287 -pip/_internal/commands/configuration.py,sha256=n98enwp6y0b5G6fiRQjaZo43FlJKYve_daMhN-4BRNc,9766 -pip/_internal/commands/debug.py,sha256=63972uUCeMIGOdMMVeIUGrOjTOqTVWplFC82a-hcKyA,6777 -pip/_internal/commands/download.py,sha256=e4hw088zGo26WmJaMIRvCniLlLmoOjqolGyfHjsCkCQ,5335 -pip/_internal/commands/freeze.py,sha256=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-312.pyc,, -pip/_internal/distributions/__pycache__/base.cpython-312.pyc,, -pip/_internal/distributions/__pycache__/installed.cpython-312.pyc,, -pip/_internal/distributions/__pycache__/sdist.cpython-312.pyc,, -pip/_internal/distributions/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/distributions/base.py,sha256=oRSEvnv2ZjBnargamnv2fcJa1n6gUDKaW0g6CWSEpWs,1743 -pip/_internal/distributions/installed.py,sha256=QinHFbWAQ8oE0pbD8MFZWkwlnfU1QYTccA1vnhrlYOU,842 -pip/_internal/distributions/sdist.py,sha256=4K3V0VNMllHbBzCJibjwd_tylUKpmIdu2AQyhplvCQo,6709 -pip/_internal/distributions/wheel.py,sha256=-ma3sOtUQj0AxXCEb6_Fhmjl3nh4k3A0HC2taAb2N-4,1277 -pip/_internal/exceptions.py,sha256=TmF1iNFEneSWaemwlg6a5bpPuq2cMHK7d1-SvjsQHb0,23634 -pip/_internal/index/__init__.py,sha256=vpt-JeTZefh8a-FC22ZeBSXFVbuBcXSGiILhQZJaNpQ,30 -pip/_internal/index/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/index/__pycache__/collector.cpython-312.pyc,, -pip/_internal/index/__pycache__/package_finder.cpython-312.pyc,, -pip/_internal/index/__pycache__/sources.cpython-312.pyc,, -pip/_internal/index/collector.py,sha256=sH0tL_cOoCk6pLLfCSGVjFM4rPEJtllF-VobvAvLSH4,16590 -pip/_internal/index/package_finder.py,sha256=S_nC8gzVIMY6ikWfKoSOzRtoesUqnfNhAPl_BwSOusA,37843 -pip/_internal/index/sources.py,sha256=dJegiR9f86kslaAHcv9-R5L_XBf5Rzm_FkyPteDuPxI,8688 -pip/_internal/locations/__init__.py,sha256=Dh8LJWG8LRlDK4JIj9sfRF96TREzE--N_AIlx7Tqoe4,15365 -pip/_internal/locations/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/locations/__pycache__/_distutils.cpython-312.pyc,, -pip/_internal/locations/__pycache__/_sysconfig.cpython-312.pyc,, -pip/_internal/locations/__pycache__/base.cpython-312.pyc,, -pip/_internal/locations/_distutils.py,sha256=H9ZHK_35rdDV1Qsmi4QeaBULjFT4Mbu6QuoVGkJ6QHI,6009 -pip/_internal/locations/_sysconfig.py,sha256=jyNVtUfMIf0mtyY-Xp1m9yQ8iwECozSVVFmjkN9a2yw,7680 -pip/_internal/locations/base.py,sha256=RQiPi1d4FVM2Bxk04dQhXZ2PqkeljEL2fZZ9SYqIQ78,2556 -pip/_internal/main.py,sha256=r-UnUe8HLo5XFJz8inTcOOTiu_sxNhgHb6VwlGUllOI,340 -pip/_internal/metadata/__init__.py,sha256=9pU3W3s-6HtjFuYhWcLTYVmSaziklPv7k2x8p7X1GmA,4339 -pip/_internal/metadata/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/metadata/__pycache__/_json.cpython-312.pyc,, -pip/_internal/metadata/__pycache__/base.cpython-312.pyc,, -pip/_internal/metadata/__pycache__/pkg_resources.cpython-312.pyc,, -pip/_internal/metadata/_json.py,sha256=Rz5M5ciSNvITwaTQR6NfN8TgKgM5WfTws4D6CFknovE,2627 -pip/_internal/metadata/base.py,sha256=l3Wgku4xlgr8s4p6fS-3qQ4QKOpPbWLRwi5d9omEFG4,25907 -pip/_internal/metadata/importlib/__init__.py,sha256=jUUidoxnHcfITHHaAWG1G2i5fdBYklv_uJcjo2x7VYE,135 -pip/_internal/metadata/importlib/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/metadata/importlib/__pycache__/_compat.cpython-312.pyc,, -pip/_internal/metadata/importlib/__pycache__/_dists.cpython-312.pyc,, -pip/_internal/metadata/importlib/__pycache__/_envs.cpython-312.pyc,, -pip/_internal/metadata/importlib/_compat.py,sha256=GAe_prIfCE4iUylrnr_2dJRlkkBVRUbOidEoID7LPoE,1882 -pip/_internal/metadata/importlib/_dists.py,sha256=UPl1wUujFqiwiltRJ1tMF42WRINO1sSpNNlYQ2mX0mk,8297 -pip/_internal/metadata/importlib/_envs.py,sha256=XTaFIYERP2JF0QUZuPx2ETiugXbPEcZ8q8ZKeht6Lpc,7456 -pip/_internal/metadata/pkg_resources.py,sha256=opjw4IBSqHvie6sXJ_cbT42meygoPEUfNURJuWZY7sk,10035 -pip/_internal/models/__init__.py,sha256=3DHUd_qxpPozfzouoqa9g9ts1Czr5qaHfFxbnxriepM,63 -pip/_internal/models/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/models/__pycache__/candidate.cpython-312.pyc,, -pip/_internal/models/__pycache__/direct_url.cpython-312.pyc,, -pip/_internal/models/__pycache__/format_control.cpython-312.pyc,, -pip/_internal/models/__pycache__/index.cpython-312.pyc,, -pip/_internal/models/__pycache__/installation_report.cpython-312.pyc,, -pip/_internal/models/__pycache__/link.cpython-312.pyc,, -pip/_internal/models/__pycache__/scheme.cpython-312.pyc,, -pip/_internal/models/__pycache__/search_scope.cpython-312.pyc,, -pip/_internal/models/__pycache__/selection_prefs.cpython-312.pyc,, -pip/_internal/models/__pycache__/target_python.cpython-312.pyc,, -pip/_internal/models/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/models/candidate.py,sha256=hEPu8VdGE5qVASv6vLz-R-Rgh5-7LMbai1jgthMCd8M,931 -pip/_internal/models/direct_url.py,sha256=FwouYBKcqckh7B-k2H3HVgRhhFTukFwqiS3kfvtFLSk,6889 -pip/_internal/models/format_control.py,sha256=wtsQqSK9HaUiNxQEuB-C62eVimw6G4_VQFxV9-_KDBE,2486 -pip/_internal/models/index.py,sha256=tYnL8oxGi4aSNWur0mG8DAP7rC6yuha_MwJO8xw0crI,1030 -pip/_internal/models/installation_report.py,sha256=zRVZoaz-2vsrezj_H3hLOhMZCK9c7TbzWgC-jOalD00,2818 -pip/_internal/models/link.py,sha256=XirOAGv1jgMu7vu87kuPbohGj7VHpwVrd2q3KUgVQNg,20777 -pip/_internal/models/scheme.py,sha256=3EFQp_ICu_shH1-TBqhl0QAusKCPDFOlgHFeN4XowWs,738 -pip/_internal/models/search_scope.py,sha256=ASVyyZxiJILw7bTIVVpJx8J293M3Hk5F33ilGn0e80c,4643 -pip/_internal/models/selection_prefs.py,sha256=KZdi66gsR-_RUXUr9uejssk3rmTHrQVJWeNA2sV-VSY,1907 -pip/_internal/models/target_python.py,sha256=34EkorrMuRvRp-bjqHKJ-bOO71m9xdjN2b8WWFEC2HU,4272 -pip/_internal/models/wheel.py,sha256=YqazoIZyma_Q1ejFa1C7NHKQRRWlvWkdK96VRKmDBeI,3600 -pip/_internal/network/__init__.py,sha256=jf6Tt5nV_7zkARBrKojIXItgejvoegVJVKUbhAa5Ioc,50 -pip/_internal/network/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/network/__pycache__/auth.cpython-312.pyc,, -pip/_internal/network/__pycache__/cache.cpython-312.pyc,, -pip/_internal/network/__pycache__/download.cpython-312.pyc,, -pip/_internal/network/__pycache__/lazy_wheel.cpython-312.pyc,, -pip/_internal/network/__pycache__/session.cpython-312.pyc,, -pip/_internal/network/__pycache__/utils.cpython-312.pyc,, -pip/_internal/network/__pycache__/xmlrpc.cpython-312.pyc,, -pip/_internal/network/auth.py,sha256=TC-OcW2KU4W6R1hU4qPgQXvVH54adACpZz6sWq-R9NA,20541 -pip/_internal/network/cache.py,sha256=48A971qCzKNFvkb57uGEk7-0xaqPS0HWj2711QNTxkU,3935 -pip/_internal/network/download.py,sha256=i0Tn55CD5D7XYEFY3TxiYaCf0OaaTQ6SScNgCsSeV14,6086 -pip/_internal/network/lazy_wheel.py,sha256=2PXVduYZPCPZkkQFe1J1GbfHJWeCU--FXonGyIfw9eU,7638 -pip/_internal/network/session.py,sha256=9tqEDD8JiVaFdplOEXJxNo9cjRfBZ6RIa0yQQ_qBNiM,18698 -pip/_internal/network/utils.py,sha256=6A5SrUJEEUHxbGtbscwU2NpCyz-3ztiDlGWHpRRhsJ8,4073 -pip/_internal/network/xmlrpc.py,sha256=sAxzOacJ-N1NXGPvap9jC3zuYWSnnv3GXtgR2-E2APA,1838 -pip/_internal/operations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/operations/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/operations/__pycache__/check.cpython-312.pyc,, -pip/_internal/operations/__pycache__/freeze.cpython-312.pyc,, -pip/_internal/operations/__pycache__/prepare.cpython-312.pyc,, -pip/_internal/operations/build/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/operations/build/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/build_tracker.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/metadata.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/metadata_editable.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/wheel_editable.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-312.pyc,, -pip/_internal/operations/build/build_tracker.py,sha256=z-H5DOknZdBa3dh2Vq6VBMY5qLYIKmlj2p6CGZK5Lc8,4832 -pip/_internal/operations/build/metadata.py,sha256=9S0CUD8U3QqZeXp-Zyt8HxwU90lE4QrnYDgrqZDzBnc,1422 -pip/_internal/operations/build/metadata_editable.py,sha256=VLL7LvntKE8qxdhUdEJhcotFzUsOSI8NNS043xULKew,1474 -pip/_internal/operations/build/metadata_legacy.py,sha256=o-eU21As175hDC7dluM1fJJ_FqokTIShyWpjKaIpHZw,2198 -pip/_internal/operations/build/wheel.py,sha256=sT12FBLAxDC6wyrDorh8kvcZ1jG5qInCRWzzP-UkJiQ,1075 -pip/_internal/operations/build/wheel_editable.py,sha256=yOtoH6zpAkoKYEUtr8FhzrYnkNHQaQBjWQ2HYae1MQg,1417 -pip/_internal/operations/build/wheel_legacy.py,sha256=C9j6rukgQI1n_JeQLoZGuDdfUwzCXShyIdPTp6edbMQ,3064 -pip/_internal/operations/check.py,sha256=fsqA88iGaqftCr2tlP3sSU202CSkoODRtW0O-JU9M4Y,6806 -pip/_internal/operations/freeze.py,sha256=uqoeTAf6HOYVMR2UgAT8N85UZoGEVEoQdan_Ao6SOfk,9816 -pip/_internal/operations/install/__init__.py,sha256=mX7hyD2GNBO2mFGokDQ30r_GXv7Y_PLdtxcUv144e-s,51 -pip/_internal/operations/install/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/operations/install/__pycache__/editable_legacy.cpython-312.pyc,, -pip/_internal/operations/install/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/operations/install/editable_legacy.py,sha256=YeR0KadWXw_ZheC1NtAG1qVIEkOgRGHc23x-YtGW7NU,1282 -pip/_internal/operations/install/wheel.py,sha256=9hGb1c4bRnPIb2FG7CtUSPfPxqprmHQBtwIAlWPNTtE,27311 -pip/_internal/operations/prepare.py,sha256=57Oq87HfunX3Rbqp47FdaJr9cHbAKUm_3gv7WhBAqbE,28128 -pip/_internal/pyproject.py,sha256=4Xszp11xgr126yzG6BbJA0oaQ9WXuhb0jyUb-y_6lPQ,7152 -pip/_internal/req/__init__.py,sha256=TELFgZOof3lhMmaICVWL9U7PlhXo9OufokbMAJ6J2GI,2738 -pip/_internal/req/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/req/__pycache__/constructors.cpython-312.pyc,, -pip/_internal/req/__pycache__/req_file.cpython-312.pyc,, -pip/_internal/req/__pycache__/req_install.cpython-312.pyc,, -pip/_internal/req/__pycache__/req_set.cpython-312.pyc,, -pip/_internal/req/__pycache__/req_uninstall.cpython-312.pyc,, -pip/_internal/req/constructors.py,sha256=8hlY56imEthLORRwmloyKz3YOyXymIaKsNB6P9ewvNI,19018 -pip/_internal/req/req_file.py,sha256=M8ttOZL-PwAj7scPElhW3ZD2hiD9mm_6FJAGIbwAzEI,17790 -pip/_internal/req/req_install.py,sha256=wtOPxkyRSM8comTks8oL1Gp2oyGqbH7JwIDRci2QiPk,35460 -pip/_internal/req/req_set.py,sha256=iMYDUToSgkxFyrP_OrTtPSgw4dwjRyGRDpGooTqeA4Y,4704 -pip/_internal/req/req_uninstall.py,sha256=nmvTQaRCC0iu-5Tw0djlXJhSj6WmqHRvT3qkkEdC35E,24551 -pip/_internal/resolution/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/resolution/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/resolution/__pycache__/base.cpython-312.pyc,, -pip/_internal/resolution/base.py,sha256=qlmh325SBVfvG6Me9gc5Nsh5sdwHBwzHBq6aEXtKsLA,583 -pip/_internal/resolution/legacy/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/resolution/legacy/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/resolution/legacy/__pycache__/resolver.cpython-312.pyc,, -pip/_internal/resolution/legacy/resolver.py,sha256=Xk24jQ62GvLr4Mc7IjN_qiO88qp0BImzVmPIFz9QLOE,24025 -pip/_internal/resolution/resolvelib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/base.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/base.py,sha256=jg5COmHLhmBIKOR-4spdJD3jyULYa1BdsqiBu2YJnJ4,5173 -pip/_internal/resolution/resolvelib/candidates.py,sha256=19Ki91Po-MSxBknGIfOGkaWkFdOznN0W_nKv7jL28L0,21052 -pip/_internal/resolution/resolvelib/factory.py,sha256=vqqk-hjchdhShwWVdeW2_A-5ZblLhE_nC_v3Mhz4Svc,32292 -pip/_internal/resolution/resolvelib/found_candidates.py,sha256=hvL3Hoa9VaYo-qEOZkBi2Iqw251UDxPz-uMHVaWmLpE,5705 -pip/_internal/resolution/resolvelib/provider.py,sha256=4t23ivjruqM6hKBX1KpGiTt-M4HGhRcZnGLV0c01K7U,9824 -pip/_internal/resolution/resolvelib/reporter.py,sha256=YFm9hQvz4DFCbjZeFTQ56hTz3Ac-mDBnHkeNRVvMHLY,3100 -pip/_internal/resolution/resolvelib/requirements.py,sha256=-kJONP0WjDfdTvBAs2vUXPgAnOyNIBEAXY4b72ogtPE,5696 -pip/_internal/resolution/resolvelib/resolver.py,sha256=nLJOsVMEVi2gQUVJoUFKMZAeu2f7GRMjGMvNSWyz0Bc,12592 -pip/_internal/self_outdated_check.py,sha256=saxQLB8UzIFtMScquytG10TOTsYVFJQ_mkW1NY-46wE,8378 -pip/_internal/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/utils/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/utils/__pycache__/_jaraco_text.cpython-312.pyc,, -pip/_internal/utils/__pycache__/_log.cpython-312.pyc,, -pip/_internal/utils/__pycache__/appdirs.cpython-312.pyc,, -pip/_internal/utils/__pycache__/compat.cpython-312.pyc,, -pip/_internal/utils/__pycache__/compatibility_tags.cpython-312.pyc,, -pip/_internal/utils/__pycache__/datetime.cpython-312.pyc,, -pip/_internal/utils/__pycache__/deprecation.cpython-312.pyc,, -pip/_internal/utils/__pycache__/direct_url_helpers.cpython-312.pyc,, -pip/_internal/utils/__pycache__/egg_link.cpython-312.pyc,, -pip/_internal/utils/__pycache__/encoding.cpython-312.pyc,, -pip/_internal/utils/__pycache__/entrypoints.cpython-312.pyc,, -pip/_internal/utils/__pycache__/filesystem.cpython-312.pyc,, -pip/_internal/utils/__pycache__/filetypes.cpython-312.pyc,, -pip/_internal/utils/__pycache__/glibc.cpython-312.pyc,, -pip/_internal/utils/__pycache__/hashes.cpython-312.pyc,, -pip/_internal/utils/__pycache__/logging.cpython-312.pyc,, -pip/_internal/utils/__pycache__/misc.cpython-312.pyc,, -pip/_internal/utils/__pycache__/models.cpython-312.pyc,, -pip/_internal/utils/__pycache__/packaging.cpython-312.pyc,, -pip/_internal/utils/__pycache__/setuptools_build.cpython-312.pyc,, -pip/_internal/utils/__pycache__/subprocess.cpython-312.pyc,, -pip/_internal/utils/__pycache__/temp_dir.cpython-312.pyc,, -pip/_internal/utils/__pycache__/unpacking.cpython-312.pyc,, -pip/_internal/utils/__pycache__/urls.cpython-312.pyc,, -pip/_internal/utils/__pycache__/virtualenv.cpython-312.pyc,, -pip/_internal/utils/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/utils/_jaraco_text.py,sha256=yvDGelTVugRayPaOF2k4ab0Ky4d3uOkAfuOQjASjImY,3351 -pip/_internal/utils/_log.py,sha256=-jHLOE_THaZz5BFcCnoSL9EYAtJ0nXem49s9of4jvKw,1015 -pip/_internal/utils/appdirs.py,sha256=swgcTKOm3daLeXTW6v5BUS2Ti2RvEnGRQYH_yDXklAo,1665 -pip/_internal/utils/compat.py,sha256=ACyBfLgj3_XG-iA5omEDrXqDM0cQKzi8h8HRBInzG6Q,1884 -pip/_internal/utils/compatibility_tags.py,sha256=ydin8QG8BHqYRsPY4OL6cmb44CbqXl1T0xxS97VhHkk,5377 -pip/_internal/utils/datetime.py,sha256=m21Y3wAtQc-ji6Veb6k_M5g6A0ZyFI4egchTdnwh-pQ,242 -pip/_internal/utils/deprecation.py,sha256=NKo8VqLioJ4nnXXGmW4KdasxF90EFHkZaHeX1fT08C8,3627 -pip/_internal/utils/direct_url_helpers.py,sha256=6F1tc2rcKaCZmgfVwsE6ObIe_Pux23mUVYA-2D9wCFc,3206 -pip/_internal/utils/egg_link.py,sha256=0FePZoUYKv4RGQ2t6x7w5Z427wbA_Uo3WZnAkrgsuqo,2463 -pip/_internal/utils/encoding.py,sha256=qqsXDtiwMIjXMEiIVSaOjwH5YmirCaK-dIzb6-XJsL0,1169 -pip/_internal/utils/entrypoints.py,sha256=YlhLTRl2oHBAuqhc-zmL7USS67TPWVHImjeAQHreZTQ,3064 -pip/_internal/utils/filesystem.py,sha256=RhMIXUaNVMGjc3rhsDahWQ4MavvEQDdqXqgq-F6fpw8,5122 -pip/_internal/utils/filetypes.py,sha256=i8XAQ0eFCog26Fw9yV0Yb1ygAqKYB1w9Cz9n0fj8gZU,716 -pip/_internal/utils/glibc.py,sha256=Mesxxgg3BLxheLZx-dSf30b6gKpOgdVXw6W--uHSszQ,3113 -pip/_internal/utils/hashes.py,sha256=MjOigC75z6qoRMkgHiHqot7eqxfwDZSrEflJMPm-bHE,5118 -pip/_internal/utils/logging.py,sha256=fdtuZJ-AKkqwDTANDvGcBEpssL8el7T1jnwk1CnZl3Y,11603 -pip/_internal/utils/misc.py,sha256=fNXwaeeikvnUt4CPMFIL4-IQbZDxxjj4jDpzCi4ZsOw,23623 -pip/_internal/utils/models.py,sha256=5GoYU586SrxURMvDn_jBMJInitviJg4O5-iOU-6I0WY,1193 -pip/_internal/utils/packaging.py,sha256=5Wm6_x7lKrlqVjPI5MBN_RurcRHwVYoQ7Ksrs84de7s,2108 -pip/_internal/utils/setuptools_build.py,sha256=ouXpud-jeS8xPyTPsXJ-m34NPvK5os45otAzdSV_IJE,4435 -pip/_internal/utils/subprocess.py,sha256=zzdimb75jVLE1GU4WlTZ055gczhD7n1y1xTcNc7vNZQ,9207 -pip/_internal/utils/temp_dir.py,sha256=DUAw22uFruQdK43i2L2K53C-CDjRCPeAsBKJpu-rHQ4,9312 -pip/_internal/utils/unpacking.py,sha256=SBb2iV1crb89MDRTEKY86R4A_UOWApTQn9VQVcMDOlE,8821 -pip/_internal/utils/urls.py,sha256=AhaesUGl-9it6uvG6fsFPOr9ynFpGaTMk4t5XTX7Z_Q,1759 -pip/_internal/utils/virtualenv.py,sha256=S6f7csYorRpiD6cvn3jISZYc3I8PJC43H5iMFpRAEDU,3456 -pip/_internal/utils/wheel.py,sha256=i4BwUNHattzN0ixy3HBAF04tZPRh2CcxaT6t86viwkE,4499 -pip/_internal/vcs/__init__.py,sha256=UAqvzpbi0VbZo3Ub6skEeZAw-ooIZR-zX_WpCbxyCoU,596 -pip/_internal/vcs/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/vcs/__pycache__/bazaar.cpython-312.pyc,, -pip/_internal/vcs/__pycache__/git.cpython-312.pyc,, -pip/_internal/vcs/__pycache__/mercurial.cpython-312.pyc,, -pip/_internal/vcs/__pycache__/subversion.cpython-312.pyc,, -pip/_internal/vcs/__pycache__/versioncontrol.cpython-312.pyc,, -pip/_internal/vcs/bazaar.py,sha256=j0oin0fpGRHcCFCxEcpPCQoFEvA-DMLULKdGP8Nv76o,3519 -pip/_internal/vcs/git.py,sha256=CeKBGJnl6uskvvjkAUXrJVxbHJrpS_B_pyfFdjL3CRc,18121 -pip/_internal/vcs/mercurial.py,sha256=oULOhzJ2Uie-06d1omkL-_Gc6meGaUkyogvqG9ZCyPs,5249 -pip/_internal/vcs/subversion.py,sha256=vhZs8L-TNggXqM1bbhl-FpbxE3TrIB6Tgnx8fh3S2HE,11729 -pip/_internal/vcs/versioncontrol.py,sha256=3eIjtOMYvOY5qP6BMYIYDZ375CSuec6kSEB0bOo1cSs,22787 -pip/_internal/wheel_builder.py,sha256=qTTzQV8F6b1jNsFCda1TRQC8J7gK-m7iuRNgKo7Dj68,11801 -pip/_vendor/__init__.py,sha256=U51NPwXdA-wXOiANIQncYjcMp6txgeOL5nHxksJeyas,4993 -pip/_vendor/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/__pycache__/six.cpython-312.pyc,, -pip/_vendor/__pycache__/typing_extensions.cpython-312.pyc,, -pip/_vendor/cachecontrol/__init__.py,sha256=ctHagMhQXuvQDdm4TirZrwDOT5H8oBNAJqzdKI6sovk,676 -pip/_vendor/cachecontrol/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/adapter.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/cache.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/controller.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/serialize.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-312.pyc,, -pip/_vendor/cachecontrol/_cmd.py,sha256=iist2EpzJvDVIhMAxXq8iFnTBsiZAd6iplxfmNboNyk,1737 -pip/_vendor/cachecontrol/adapter.py,sha256=_CcWvUP9048qAZjsNqViaHbdcLs9mmFNixVfpO7oebE,6392 -pip/_vendor/cachecontrol/cache.py,sha256=OTQj72tUf8C1uEgczdl3Gc8vkldSzsTITKtDGKMx4z8,1952 -pip/_vendor/cachecontrol/caches/__init__.py,sha256=dtrrroK5BnADR1GWjCZ19aZ0tFsMfvFBtLQQU1sp_ag,303 -pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-312.pyc,, -pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-312.pyc,, -pip/_vendor/cachecontrol/caches/file_cache.py,sha256=3z8AWKD-vfKeiJqIzLmJyIYtR2yd6Tsh3u1TyLRQoIQ,5352 -pip/_vendor/cachecontrol/caches/redis_cache.py,sha256=9rmqwtYu_ljVkW6_oLqbC7EaX_a8YT_yLuna-eS0dgo,1386 -pip/_vendor/cachecontrol/controller.py,sha256=keCFA3ZaNVaWTwHd6F1zqWhb4vyvNx_UvZuo5iIYMfo,18384 -pip/_vendor/cachecontrol/filewrapper.py,sha256=STttGmIPBvZzt2b51dUOwoWX5crcMCpKZOisM3f5BNc,4292 -pip/_vendor/cachecontrol/heuristics.py,sha256=fdFbk9W8IeLrjteIz_fK4mj2HD_Y7COXF2Uc8TgjT1c,4828 -pip/_vendor/cachecontrol/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-312.pyc,, -pip/_vendor/certifi/__pycache__/__main__.cpython-312.pyc,, -pip/_vendor/certifi/__pycache__/core.cpython-312.pyc,, -pip/_vendor/certifi/cacert.pem,sha256=eU0Dn_3yd8BH4m8sfVj4Glhl2KDrcCSg-sEWT-pNJ88,281617 -pip/_vendor/certifi/core.py,sha256=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-312.pyc,, -pip/_vendor/chardet/__pycache__/big5freq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/big5prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/chardistribution.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/charsetprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/codingstatemachinedict.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/cp949prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/enums.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/escprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/escsm.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/eucjpprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/euckrfreq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/euckrprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/euctwfreq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/euctwprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/gb2312freq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/gb2312prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/hebrewprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/jisfreq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/johabfreq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/johabprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/jpcntx.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langthaimodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/latin1prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/macromanprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/mbcssm.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/resultdict.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/sjisprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/universaldetector.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/utf1632prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/utf8prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/version.cpython-312.pyc,, -pip/_vendor/chardet/big5freq.py,sha256=ltcfP-3PjlNHCoo5e4a7C4z-2DhBTXRfY6jbMbB7P30,31274 -pip/_vendor/chardet/big5prober.py,sha256=lPMfwCX6v2AaPgvFh_cSWZcgLDbWiFCHLZ_p9RQ9uxE,1763 -pip/_vendor/chardet/chardistribution.py,sha256=13B8XUG4oXDuLdXvfbIWwLFeR-ZU21AqTS1zcdON8bU,10032 -pip/_vendor/chardet/charsetgroupprober.py,sha256=UKK3SaIZB2PCdKSIS0gnvMtLR9JJX62M-fZJu3OlWyg,3915 -pip/_vendor/chardet/charsetprober.py,sha256=L3t8_wIOov8em-vZWOcbkdsrwe43N6_gqNh5pH7WPd4,5420 -pip/_vendor/chardet/cli/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/chardet/cli/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-312.pyc,, -pip/_vendor/chardet/cli/chardetect.py,sha256=zibMVg5RpKb-ME9_7EYG4ZM2Sf07NHcQzZ12U-rYJho,3242 -pip/_vendor/chardet/codingstatemachine.py,sha256=K7k69sw3jY5DmTXoSJQVsUtFIQKYPQVOSJJhBuGv_yE,3732 -pip/_vendor/chardet/codingstatemachinedict.py,sha256=0GY3Hi2qIZvDrOOJ3AtqppM1RsYxr_66ER4EHjuMiMc,542 -pip/_vendor/chardet/cp949prober.py,sha256=0jKRV7fECuWI16rNnks0ZECKA1iZYCIEaP8A1ZvjUSI,1860 -pip/_vendor/chardet/enums.py,sha256=TzECiZoCKNMqgwU76cPCeKWFBqaWvAdLMev5_bCkhY8,1683 -pip/_vendor/chardet/escprober.py,sha256=Kho48X65xE0scFylIdeJjM2bcbvRvv0h0WUbMWrJD3A,4006 -pip/_vendor/chardet/escsm.py,sha256=AqyXpA2FQFD7k-buBty_7itGEYkhmVa8X09NLRul3QM,12176 -pip/_vendor/chardet/eucjpprober.py,sha256=5KYaM9fsxkRYzw1b5k0fL-j_-ezIw-ij9r97a9MHxLY,3934 -pip/_vendor/chardet/euckrfreq.py,sha256=3mHuRvXfsq_QcQysDQFb8qSudvTiol71C6Ic2w57tKM,13566 -pip/_vendor/chardet/euckrprober.py,sha256=hiFT6wM174GIwRvqDsIcuOc-dDsq2uPKMKbyV8-1Xnc,1753 -pip/_vendor/chardet/euctwfreq.py,sha256=2alILE1Lh5eqiFJZjzRkMQXolNJRHY5oBQd-vmZYFFM,36913 -pip/_vendor/chardet/euctwprober.py,sha256=NxbpNdBtU0VFI0bKfGfDkpP7S2_8_6FlO87dVH0ogws,1753 -pip/_vendor/chardet/gb2312freq.py,sha256=49OrdXzD-HXqwavkqjo8Z7gvs58hONNzDhAyMENNkvY,20735 -pip/_vendor/chardet/gb2312prober.py,sha256=KPEBueaSLSvBpFeINMu0D6TgHcR90e5PaQawifzF4o0,1759 -pip/_vendor/chardet/hebrewprober.py,sha256=96T_Lj_OmW-fK7JrSHojYjyG3fsGgbzkoTNleZ3kfYE,14537 -pip/_vendor/chardet/jisfreq.py,sha256=mm8tfrwqhpOd3wzZKS4NJqkYBQVcDfTM2JiQ5aW932E,25796 -pip/_vendor/chardet/johabfreq.py,sha256=dBpOYG34GRX6SL8k_LbS9rxZPMjLjoMlgZ03Pz5Hmqc,42498 -pip/_vendor/chardet/johabprober.py,sha256=O1Qw9nVzRnun7vZp4UZM7wvJSv9W941mEU9uDMnY3DU,1752 -pip/_vendor/chardet/jpcntx.py,sha256=uhHrYWkLxE_rF5OkHKInm0HUsrjgKHHVQvtt3UcvotA,27055 -pip/_vendor/chardet/langbulgarianmodel.py,sha256=vmbvYFP8SZkSxoBvLkFqKiH1sjma5ihk3PTpdy71Rr4,104562 -pip/_vendor/chardet/langgreekmodel.py,sha256=JfB7bupjjJH2w3X_mYnQr9cJA_7EuITC2cRW13fUjeI,98484 -pip/_vendor/chardet/langhebrewmodel.py,sha256=3HXHaLQPNAGcXnJjkIJfozNZLTvTJmf4W5Awi6zRRKc,98196 -pip/_vendor/chardet/langhungarianmodel.py,sha256=WxbeQIxkv8YtApiNqxQcvj-tMycsoI4Xy-fwkDHpP_Y,101363 -pip/_vendor/chardet/langrussianmodel.py,sha256=s395bTZ87ESTrZCOdgXbEjZ9P1iGPwCl_8xSsac_DLY,128035 -pip/_vendor/chardet/langthaimodel.py,sha256=7bJlQitRpTnVGABmbSznHnJwOHDy3InkTvtFUx13WQI,102774 -pip/_vendor/chardet/langturkishmodel.py,sha256=XY0eGdTIy4eQ9Xg1LVPZacb-UBhHBR-cq0IpPVHowKc,95372 -pip/_vendor/chardet/latin1prober.py,sha256=p15EEmFbmQUwbKLC7lOJVGHEZwcG45ubEZYTGu01J5g,5380 -pip/_vendor/chardet/macromanprober.py,sha256=9anfzmY6TBfUPDyBDOdY07kqmTHpZ1tK0jL-p1JWcOY,6077 -pip/_vendor/chardet/mbcharsetprober.py,sha256=Wr04WNI4F3X_VxEverNG-H25g7u-MDDKlNt-JGj-_uU,3715 -pip/_vendor/chardet/mbcsgroupprober.py,sha256=iRpaNBjV0DNwYPu_z6TiHgRpwYahiM7ztI_4kZ4Uz9A,2131 -pip/_vendor/chardet/mbcssm.py,sha256=hUtPvDYgWDaA2dWdgLsshbwRfm3Q5YRlRogdmeRUNQw,30391 -pip/_vendor/chardet/metadata/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/chardet/metadata/__pycache__/languages.cpython-312.pyc,, -pip/_vendor/chardet/metadata/languages.py,sha256=FhvBIdZFxRQ-dTwkb_0madRKgVBCaUMQz9I5xqjE5iQ,13560 -pip/_vendor/chardet/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-312.pyc,, -pip/_vendor/colorama/__pycache__/ansi.cpython-312.pyc,, -pip/_vendor/colorama/__pycache__/ansitowin32.cpython-312.pyc,, -pip/_vendor/colorama/__pycache__/initialise.cpython-312.pyc,, -pip/_vendor/colorama/__pycache__/win32.cpython-312.pyc,, -pip/_vendor/colorama/__pycache__/winterm.cpython-312.pyc,, -pip/_vendor/colorama/ansi.py,sha256=Top4EeEuaQdBWdteKMEcGOTeKeF19Q-Wo_6_Cj5kOzQ,2522 -pip/_vendor/colorama/ansitowin32.py,sha256=vPNYa3OZbxjbuFyaVo0Tmhmy1FZ1lKMWCnT7odXpItk,11128 -pip/_vendor/colorama/initialise.py,sha256=-hIny86ClXo39ixh5iSCfUIa2f_h_bgKRDW7gqs-KLU,3325 -pip/_vendor/colorama/tests/__init__.py,sha256=MkgPAEzGQd-Rq0w0PZXSX2LadRWhUECcisJY8lSrm4Q,75 -pip/_vendor/colorama/tests/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/ansi_test.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/ansitowin32_test.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/initialise_test.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/isatty_test.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/utils.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/winterm_test.cpython-312.pyc,, -pip/_vendor/colorama/tests/ansi_test.py,sha256=FeViDrUINIZcr505PAxvU4AjXz1asEiALs9GXMhwRaE,2839 -pip/_vendor/colorama/tests/ansitowin32_test.py,sha256=RN7AIhMJ5EqDsYaCjVo-o4u8JzDD4ukJbmevWKS70rY,10678 -pip/_vendor/colorama/tests/initialise_test.py,sha256=BbPy-XfyHwJ6zKozuQOvNvQZzsx9vdb_0bYXn7hsBTc,6741 -pip/_vendor/colorama/tests/isatty_test.py,sha256=Pg26LRpv0yQDB5Ac-sxgVXG7hsA1NYvapFgApZfYzZg,1866 -pip/_vendor/colorama/tests/utils.py,sha256=1IIRylG39z5-dzq09R_ngufxyPZxgldNbrxKxUGwGKE,1079 -pip/_vendor/colorama/tests/winterm_test.py,sha256=qoWFPEjym5gm2RuMwpf3pOis3a5r_PJZFCzK254JL8A,3709 -pip/_vendor/colorama/win32.py,sha256=YQOKwMTwtGBbsY4dL5HYTvwTeP9wIQra5MvPNddpxZs,6181 -pip/_vendor/colorama/winterm.py,sha256=XCQFDHjPi6AHYNdZwy0tA02H-Jh48Jp-HvCjeLeLp3U,7134 -pip/_vendor/distlib/__init__.py,sha256=hJKF7FHoqbmGckncDuEINWo_OYkDNiHODtYXSMcvjcc,625 -pip/_vendor/distlib/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/compat.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/database.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/index.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/locators.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/manifest.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/markers.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/metadata.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/resources.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/scripts.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/util.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/version.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/wheel.cpython-312.pyc,, -pip/_vendor/distlib/compat.py,sha256=Un-uIBvy02w-D267OG4VEhuddqWgKj9nNkxVltAb75w,41487 -pip/_vendor/distlib/database.py,sha256=0V9Qvs0Vrxa2F_-hLWitIyVyRifJ0pCxyOI-kEOBwsA,51965 -pip/_vendor/distlib/index.py,sha256=lTbw268rRhj8dw1sib3VZ_0EhSGgoJO3FKJzSFMOaeA,20797 -pip/_vendor/distlib/locators.py,sha256=o1r_M86_bRLafSpetmyfX8KRtFu-_Q58abvQrnOSnbA,51767 -pip/_vendor/distlib/manifest.py,sha256=3qfmAmVwxRqU1o23AlfXrQGZzh6g_GGzTAP_Hb9C5zQ,14168 -pip/_vendor/distlib/markers.py,sha256=n3DfOh1yvZ_8EW7atMyoYeZFXjYla0Nz0itQlojCd0A,5268 -pip/_vendor/distlib/metadata.py,sha256=pB9WZ9mBfmQxc9OVIldLS5CjOoQRvKAvUwwQyKwKQtQ,39693 -pip/_vendor/distlib/resources.py,sha256=LwbPksc0A1JMbi6XnuPdMBUn83X7BPuFNWqPGEKI698,10820 -pip/_vendor/distlib/scripts.py,sha256=nQFXN6G7nOWNDUyxirUep-3WOlJhB7McvCs9zOnkGTI,18315 -pip/_vendor/distlib/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-312.pyc,, -pip/_vendor/distro/__pycache__/__main__.cpython-312.pyc,, -pip/_vendor/distro/__pycache__/distro.cpython-312.pyc,, -pip/_vendor/distro/distro.py,sha256=UZO1LjIhtFCMdlbiz39gj3raV-Amf3SBwzGzfApiMHw,49330 -pip/_vendor/distro/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/idna/__init__.py,sha256=KJQN1eQBr8iIK5SKrJ47lXvxG0BJ7Lm38W4zT0v_8lk,849 -pip/_vendor/idna/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/codec.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/compat.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/core.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/idnadata.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/intranges.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/package_data.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/uts46data.cpython-312.pyc,, -pip/_vendor/idna/codec.py,sha256=6ly5odKfqrytKT9_7UrlGklHnf1DSK2r9C6cSM4sa28,3374 -pip/_vendor/idna/compat.py,sha256=0_sOEUMT4CVw9doD3vyRhX80X19PwqFoUBs7gWsFME4,321 -pip/_vendor/idna/core.py,sha256=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-312.pyc,, -pip/_vendor/msgpack/__pycache__/exceptions.cpython-312.pyc,, -pip/_vendor/msgpack/__pycache__/ext.cpython-312.pyc,, -pip/_vendor/msgpack/__pycache__/fallback.cpython-312.pyc,, -pip/_vendor/msgpack/exceptions.py,sha256=dCTWei8dpkrMsQDcjQk74ATl9HsIBH0ybt8zOPNqMYc,1081 -pip/_vendor/msgpack/ext.py,sha256=C5MK8JhVYGYFWPvxsORsqZAnvOXefYQ57m1Ym0luW5M,6079 -pip/_vendor/msgpack/fallback.py,sha256=tvNBHyxxFbuVlC8GZShETClJxjLiDMOja4XwwyvNm2g,34544 -pip/_vendor/packaging/__about__.py,sha256=ugASIO2w1oUyH8_COqQ2X_s0rDhjbhQC3yJocD03h2c,661 -pip/_vendor/packaging/__init__.py,sha256=b9Kk5MF7KxhhLgcDmiUWukN-LatWFxPdNug0joPhHSk,497 -pip/_vendor/packaging/__pycache__/__about__.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/_manylinux.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/_musllinux.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/_structures.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/markers.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/requirements.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/specifiers.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/tags.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/utils.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/version.cpython-312.pyc,, -pip/_vendor/packaging/_manylinux.py,sha256=XcbiXB-qcjv3bcohp6N98TMpOP4_j3m-iOA8ptK2GWY,11488 -pip/_vendor/packaging/_musllinux.py,sha256=_KGgY_qc7vhMGpoqss25n2hiLCNKRtvz9mCrS7gkqyc,4378 -pip/_vendor/packaging/_structures.py,sha256=q3eVNmbWJGG_S0Dit_S3Ao8qQqz_5PYTXFAKBZe5yr4,1431 -pip/_vendor/packaging/markers.py,sha256=AJBOcY8Oq0kYc570KuuPTkvuqjAlhufaE2c9sCUbm64,8487 -pip/_vendor/packaging/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-312.pyc,, -pip/_vendor/platformdirs/__init__.py,sha256=SkhEYVyC_HUHC6KX7n4M_6coyRMtEB38QMyOYIAX6Yk,20155 -pip/_vendor/platformdirs/__main__.py,sha256=fVvSiTzr2-RM6IsjWjj4fkaOtDOgDhUWv6sA99do4CQ,1476 -pip/_vendor/platformdirs/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/__main__.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/android.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/api.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/macos.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/unix.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/version.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/windows.cpython-312.pyc,, -pip/_vendor/platformdirs/android.py,sha256=y_EEMKwYl2-bzYBDovksSn8m76on0Lda8eyJksVQE9U,7211 -pip/_vendor/platformdirs/api.py,sha256=jWtX06jAJytYrkJDOqEls97mCkyHRSZkoqUlbMK5Qew,7132 -pip/_vendor/platformdirs/macos.py,sha256=LueVOoVgGWDBwQb8OFwXkVKfVn33CM1Lkwf1-A86tRQ,3678 -pip/_vendor/platformdirs/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-312.pyc,, -pip/_vendor/pygments/__pycache__/__main__.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/cmdline.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/console.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/filter.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/formatter.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/lexer.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/modeline.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/plugin.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/regexopt.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/scanner.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/sphinxext.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/style.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/token.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/unistring.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/util.cpython-312.pyc,, -pip/_vendor/pygments/cmdline.py,sha256=byxYJp9gnjVeyhRlZ3UTMgo_LhkXh1afvN8wJBtAcc8,23685 -pip/_vendor/pygments/console.py,sha256=2wZ5W-U6TudJD1_NLUwjclMpbomFM91lNv11_60sfGY,1697 -pip/_vendor/pygments/filter.py,sha256=j5aLM9a9wSx6eH1oy473oSkJ02hGWNptBlVo4s1g_30,1938 -pip/_vendor/pygments/filters/__init__.py,sha256=h_koYkUFo-FFUxjs564JHUAz7O3yJpVwI6fKN3MYzG0,40386 -pip/_vendor/pygments/filters/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pygments/formatter.py,sha256=J9OL9hXLJKZk7moUgKwpjW9HNf4WlJFg_o_-Z_S_tTY,4178 -pip/_vendor/pygments/formatters/__init__.py,sha256=_xgAcdFKr0QNYwh_i98AU9hvfP3X2wAkhElFcRRF3Uo,5424 -pip/_vendor/pygments/formatters/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/_mapping.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/bbcode.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/groff.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/html.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/img.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/irc.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/latex.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/other.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/pangomarkup.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/rtf.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/svg.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/terminal.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/terminal256.cpython-312.pyc,, -pip/_vendor/pygments/formatters/_mapping.py,sha256=1Cw37FuQlNacnxRKmtlPX4nyLoX9_ttko5ZwscNUZZ4,4176 -pip/_vendor/pygments/formatters/bbcode.py,sha256=r1b7wzWTJouADDLh-Z11iRi4iQxD0JKJ1qHl6mOYxsA,3314 -pip/_vendor/pygments/formatters/groff.py,sha256=xy8Zf3tXOo6MWrXh7yPGWx3lVEkg_DhY4CxmsDb0IVo,5094 -pip/_vendor/pygments/formatters/html.py,sha256=PIzAyilNqaTzSSP2slDG2VDLE3qNioWy2rgtSSoviuI,35610 -pip/_vendor/pygments/formatters/img.py,sha256=XKXmg2_XONrR4mtq2jfEU8XCsoln3VSGTw-UYiEokys,21938 -pip/_vendor/pygments/formatters/irc.py,sha256=Ep-m8jd3voFO6Fv57cUGFmz6JVA67IEgyiBOwv0N4a0,4981 -pip/_vendor/pygments/formatters/latex.py,sha256=FGzJ-YqSTE8z_voWPdzvLY5Tq8jE_ygjGjM6dXZJ8-k,19351 -pip/_vendor/pygments/formatters/other.py,sha256=gPxkk5BdAzWTCgbEHg1lpLi-1F6ZPh5A_aotgLXHnzg,5073 -pip/_vendor/pygments/formatters/pangomarkup.py,sha256=6LKnQc8yh49f802bF0sPvbzck4QivMYqqoXAPaYP8uU,2212 -pip/_vendor/pygments/formatters/rtf.py,sha256=aA0v_psW6KZI3N18TKDifxeL6mcF8EDXcPXDWI4vhVQ,5014 -pip/_vendor/pygments/formatters/svg.py,sha256=dQONWypbzfvzGCDtdp3M_NJawScJvM2DiHbx1k-ww7g,7335 -pip/_vendor/pygments/formatters/terminal.py,sha256=FG-rpjRpFmNpiGB4NzIucvxq6sQIXB3HOTo2meTKtrU,4674 -pip/_vendor/pygments/formatters/terminal256.py,sha256=13SJ3D5pFdqZ9zROE6HbWnBDwHvOGE8GlsmqGhprRp4,11753 -pip/_vendor/pygments/lexer.py,sha256=2BpqLlT2ExvOOi7vnjK5nB4Fp-m52ldiPaXMox5uwug,34618 -pip/_vendor/pygments/lexers/__init__.py,sha256=j5KEi5O_VQ5GS59H49l-10gzUOkWKxlwGeVMlGO2MMk,12130 -pip/_vendor/pygments/lexers/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pygments/lexers/__pycache__/_mapping.cpython-312.pyc,, -pip/_vendor/pygments/lexers/__pycache__/python.cpython-312.pyc,, -pip/_vendor/pygments/lexers/_mapping.py,sha256=Hts4r_ZQ8icftGM7gkBPeED5lyVSv4affFgXYE6Ap04,72281 -pip/_vendor/pygments/lexers/python.py,sha256=c7jnmKFU9DLxTJW0UbwXt6Z9FJqbBlVsWA1Qr9xSA_w,53424 -pip/_vendor/pygments/modeline.py,sha256=eF2vO4LpOGoPvIKKkbPfnyut8hT4UiebZPpb-BYGQdI,986 -pip/_vendor/pygments/plugin.py,sha256=j1Fh310RbV2DQ9nvkmkqvlj38gdyuYKllLnGxbc8sJM,2591 -pip/_vendor/pygments/regexopt.py,sha256=jg1ALogcYGU96TQS9isBl6dCrvw5y5--BP_K-uFk_8s,3072 -pip/_vendor/pygments/scanner.py,sha256=b_nu5_f3HCgSdp5S_aNRBQ1MSCm4ZjDwec2OmTRickw,3092 -pip/_vendor/pygments/sphinxext.py,sha256=wBFYm180qea9JKt__UzhRlNRNhczPDFDaqGD21sbuso,6882 -pip/_vendor/pygments/style.py,sha256=C4qyoJrUTkq-OV3iO-8Vz3UtWYpJwSTdh5_vlGCGdNQ,6257 -pip/_vendor/pygments/styles/__init__.py,sha256=he7HjQx7sC0d2kfTVLjUs0J15mtToJM6M1brwIm9--Q,3700 -pip/_vendor/pygments/styles/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pygments/token.py,sha256=seNsmcch9OEHXYirh8Ool7w8xDhfNTbLj5rHAC-gc_o,6184 -pip/_vendor/pygments/unistring.py,sha256=FaUfG14NBJEKLQoY9qj6JYeXrpYcLmKulghdxOGFaOc,63223 -pip/_vendor/pygments/util.py,sha256=AEVY0qonyyEMgv4Do2dINrrqUAwUk2XYSqHM650uzek,10230 -pip/_vendor/pyparsing/__init__.py,sha256=9m1JbE2JTLdBG0Mb6B0lEaZj181Wx5cuPXZpsbHEYgE,9116 -pip/_vendor/pyparsing/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/actions.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/common.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/core.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/exceptions.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/helpers.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/results.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/testing.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/unicode.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/util.cpython-312.pyc,, -pip/_vendor/pyparsing/actions.py,sha256=05uaIPOznJPQ7VgRdmGCmG4sDnUPtwgv5qOYIqbL2UY,6567 -pip/_vendor/pyparsing/common.py,sha256=p-3c83E5-DjlkF35G0O9-kjQRpoejP-2_z0hxZ-eol4,13387 -pip/_vendor/pyparsing/core.py,sha256=yvuRlLpXSF8mgk-QhiW3OVLqD9T0rsj9tbibhRH4Yaw,224445 -pip/_vendor/pyparsing/diagram/__init__.py,sha256=nxmDOoYF9NXuLaGYy01tKFjkNReWJlrGFuJNWEiTo84,24215 -pip/_vendor/pyparsing/diagram/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pyparsing/exceptions.py,sha256=6Jc6W1eDZBzyFu1J0YrcdNFVBC-RINujZmveSnB8Rxw,9523 -pip/_vendor/pyparsing/helpers.py,sha256=BZJHCA8SS0pYio30KGQTc9w2qMOaK4YpZ7hcvHbnTgk,38646 -pip/_vendor/pyparsing/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-312.pyc,, -pip/_vendor/pyproject_hooks/__pycache__/_compat.cpython-312.pyc,, -pip/_vendor/pyproject_hooks/__pycache__/_impl.cpython-312.pyc,, -pip/_vendor/pyproject_hooks/_compat.py,sha256=by6evrYnqkisiM-MQcvOKs5bgDMzlOSgZqRHNqf04zE,138 -pip/_vendor/pyproject_hooks/_impl.py,sha256=61GJxzQip0IInhuO69ZI5GbNQ82XEDUB_1Gg5_KtUoc,11920 -pip/_vendor/pyproject_hooks/_in_process/__init__.py,sha256=9gQATptbFkelkIy0OfWFEACzqxXJMQDWCH9rBOAZVwQ,546 -pip/_vendor/pyproject_hooks/_in_process/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pyproject_hooks/_in_process/__pycache__/_in_process.cpython-312.pyc,, -pip/_vendor/pyproject_hooks/_in_process/_in_process.py,sha256=m2b34c917IW5o-Q_6TYIHlsK9lSUlNiyrITTUH_zwew,10927 -pip/_vendor/requests/__init__.py,sha256=owujob4dk45Siy4EYtbCKR6wcFph7E04a_v_OuAacBA,5169 -pip/_vendor/requests/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/__version__.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/_internal_utils.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/adapters.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/api.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/auth.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/certs.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/compat.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/cookies.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/exceptions.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/help.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/hooks.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/models.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/packages.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/sessions.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/status_codes.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/structures.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/utils.cpython-312.pyc,, -pip/_vendor/requests/__version__.py,sha256=ssI3Ezt7PaxgkOW45GhtwPUclo_SO_ygtIm4A74IOfw,435 -pip/_vendor/requests/_internal_utils.py,sha256=nMQymr4hs32TqVo5AbCrmcJEhvPUh7xXlluyqwslLiQ,1495 -pip/_vendor/requests/adapters.py,sha256=idj6cZcId3L5xNNeJ7ieOLtw3awJk5A64xUfetHwq3M,19697 -pip/_vendor/requests/api.py,sha256=q61xcXq4tmiImrvcSVLTbFyCiD2F-L_-hWKGbz4y8vg,6449 -pip/_vendor/requests/auth.py,sha256=h-HLlVx9j8rKV5hfSAycP2ApOSglTz77R0tz7qCbbEE,10187 -pip/_vendor/requests/certs.py,sha256=PVPooB0jP5hkZEULSCwC074532UFbR2Ptgu0I5zwmCs,575 -pip/_vendor/requests/compat.py,sha256=IhK9quyX0RRuWTNcg6d2JGSAOUbM6mym2p_2XjLTwf4,1286 -pip/_vendor/requests/cookies.py,sha256=kD3kNEcCj-mxbtf5fJsSaT86eGoEYpD3X0CSgpzl7BM,18560 -pip/_vendor/requests/exceptions.py,sha256=FA-_kVwBZ2jhXauRctN_ewHVK25b-fj0Azyz1THQ0Kk,3823 -pip/_vendor/requests/help.py,sha256=FnAAklv8MGm_qb2UilDQgS6l0cUttiCFKUjx0zn2XNA,3879 -pip/_vendor/requests/hooks.py,sha256=CiuysiHA39V5UfcCBXFIx83IrDpuwfN9RcTUgv28ftQ,733 -pip/_vendor/requests/models.py,sha256=dDZ-iThotky-Noq9yy97cUEJhr3wnY6mv-xR_ePg_lk,35288 -pip/_vendor/requests/packages.py,sha256=njJmVifY4aSctuW3PP5EFRCxjEwMRDO6J_feG2dKWsI,695 -pip/_vendor/requests/sessions.py,sha256=-LvTzrPtetSTrR3buxu4XhdgMrJFLB1q5D7P--L2Xhw,30373 -pip/_vendor/requests/status_codes.py,sha256=FvHmT5uH-_uimtRz5hH9VCbt7VV-Nei2J9upbej6j8g,4235 -pip/_vendor/requests/structures.py,sha256=-IbmhVz06S-5aPSZuUthZ6-6D9XOjRuTXHOabY041XM,2912 -pip/_vendor/requests/utils.py,sha256=kOPn0qYD6xRTzaxbqTdYiSInBZHl6379AJsyIgzYGLY,33460 -pip/_vendor/resolvelib/__init__.py,sha256=h509TdEcpb5-44JonaU3ex2TM15GVBLjM9CNCPwnTTs,537 -pip/_vendor/resolvelib/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/resolvelib/__pycache__/providers.cpython-312.pyc,, -pip/_vendor/resolvelib/__pycache__/reporters.cpython-312.pyc,, -pip/_vendor/resolvelib/__pycache__/resolvers.cpython-312.pyc,, -pip/_vendor/resolvelib/__pycache__/structs.cpython-312.pyc,, -pip/_vendor/resolvelib/compat/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-312.pyc,, -pip/_vendor/resolvelib/compat/collections_abc.py,sha256=uy8xUZ-NDEw916tugUXm8HgwCGiMO0f-RcdnpkfXfOs,156 -pip/_vendor/resolvelib/providers.py,sha256=fuuvVrCetu5gsxPB43ERyjfO8aReS3rFQHpDgiItbs4,5871 -pip/_vendor/resolvelib/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-312.pyc,, -pip/_vendor/rich/__pycache__/__main__.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_cell_widths.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_emoji_codes.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_emoji_replace.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_export_format.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_extension.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_fileno.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_inspect.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_log_render.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_loop.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_null_file.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_palettes.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_pick.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_ratio.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_spinners.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_stack.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_timer.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_win32_console.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_windows.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_windows_renderer.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_wrap.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/abc.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/align.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/ansi.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/bar.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/box.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/cells.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/color.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/color_triplet.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/columns.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/console.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/constrain.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/containers.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/control.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/default_styles.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/diagnose.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/emoji.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/errors.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/file_proxy.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/filesize.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/highlighter.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/json.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/jupyter.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/layout.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/live.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/live_render.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/logging.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/markup.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/measure.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/padding.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/pager.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/palette.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/panel.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/pretty.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/progress.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/progress_bar.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/prompt.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/protocol.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/region.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/repr.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/rule.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/scope.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/screen.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/segment.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/spinner.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/status.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/style.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/styled.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/syntax.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/table.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/terminal_theme.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/text.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/theme.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/themes.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/traceback.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/tree.cpython-312.pyc,, -pip/_vendor/rich/_cell_widths.py,sha256=2n4EiJi3X9sqIq0O16kUZ_zy6UYMd3xFfChlKfnW1Hc,10096 -pip/_vendor/rich/_emoji_codes.py,sha256=hu1VL9nbVdppJrVoijVshRlcRRe_v3dju3Mmd2sKZdY,140235 -pip/_vendor/rich/_emoji_replace.py,sha256=n-kcetsEUx2ZUmhQrfeMNc-teeGhpuSQ5F8VPBsyvDo,1064 -pip/_vendor/rich/_export_format.py,sha256=qxgV3nKnXQu1hfbnRVswPYy-AwIg1X0LSC47cK5s8jk,2100 -pip/_vendor/rich/_extension.py,sha256=Xt47QacCKwYruzjDi-gOBq724JReDj9Cm9xUi5fr-34,265 -pip/_vendor/rich/_fileno.py,sha256=HWZxP5C2ajMbHryvAQZseflVfQoGzsKOHzKGsLD8ynQ,799 -pip/_vendor/rich/_inspect.py,sha256=oZJGw31e64dwXSCmrDnvZbwVb1ZKhWfU8wI3VWohjJk,9695 -pip/_vendor/rich/_log_render.py,sha256=1ByI0PA1ZpxZY3CGJOK54hjlq4X-Bz_boIjIqCd8Kns,3225 -pip/_vendor/rich/_loop.py,sha256=hV_6CLdoPm0va22Wpw4zKqM0RYsz3TZxXj0PoS-9eDQ,1236 -pip/_vendor/rich/_null_file.py,sha256=tGSXk_v-IZmbj1GAzHit8A3kYIQMiCpVsCFfsC-_KJ4,1387 -pip/_vendor/rich/_palettes.py,sha256=cdev1JQKZ0JvlguV9ipHgznTdnvlIzUFDBb0It2PzjI,7063 -pip/_vendor/rich/_pick.py,sha256=evDt8QN4lF5CiwrUIXlOJCntitBCOsI3ZLPEIAVRLJU,423 -pip/_vendor/rich/_ratio.py,sha256=2lLSliL025Y-YMfdfGbutkQDevhcyDqc-DtUYW9mU70,5472 -pip/_vendor/rich/_spinners.py,sha256=U2r1_g_1zSjsjiUdAESc2iAMc3i4ri_S8PYP6kQ5z1I,19919 -pip/_vendor/rich/_stack.py,sha256=-C8OK7rxn3sIUdVwxZBBpeHhIzX0eI-VM3MemYfaXm0,351 -pip/_vendor/rich/_timer.py,sha256=zelxbT6oPFZnNrwWPpc1ktUeAT-Vc4fuFcRZLQGLtMI,417 -pip/_vendor/rich/_win32_console.py,sha256=P0vxI2fcndym1UU1S37XAzQzQnkyY7YqAKmxm24_gug,22820 -pip/_vendor/rich/_windows.py,sha256=dvNl9TmfPzNVxiKk5WDFihErZ5796g2UC9-KGGyfXmk,1926 -pip/_vendor/rich/_windows_renderer.py,sha256=t74ZL3xuDCP3nmTp9pH1L5LiI2cakJuQRQleHCJerlk,2783 -pip/_vendor/rich/_wrap.py,sha256=xfV_9t0Sg6rzimmrDru8fCVmUlalYAcHLDfrJZnbbwQ,1840 -pip/_vendor/rich/abc.py,sha256=ON-E-ZqSSheZ88VrKX2M3PXpFbGEUUZPMa_Af0l-4f0,890 -pip/_vendor/rich/align.py,sha256=Ji-Yokfkhnfe_xMmr4ISjZB07TJXggBCOYoYa-HDAr8,10368 -pip/_vendor/rich/ansi.py,sha256=iD6532QYqnBm6hADulKjrV8l8kFJ-9fEVooHJHH3hMg,6906 -pip/_vendor/rich/bar.py,sha256=a7UD303BccRCrEhGjfMElpv5RFYIinaAhAuqYqhUvmw,3264 -pip/_vendor/rich/box.py,sha256=FJ6nI3jD7h2XNFU138bJUt2HYmWOlRbltoCEuIAZhew,9842 -pip/_vendor/rich/cells.py,sha256=627ztJs9zOL-38HJ7kXBerR-gT8KBfYC8UzEwMJDYYo,4509 -pip/_vendor/rich/color.py,sha256=9Gh958U3f75WVdLTeC0U9nkGTn2n0wnojKpJ6jQEkIE,18224 -pip/_vendor/rich/color_triplet.py,sha256=3lhQkdJbvWPoLDO-AnYImAWmJvV5dlgYNCVZ97ORaN4,1054 -pip/_vendor/rich/columns.py,sha256=HUX0KcMm9dsKNi11fTbiM_h2iDtl8ySCaVcxlalEzq8,7131 -pip/_vendor/rich/console.py,sha256=pDvkbLkvtZIMIwQx_jkZ-seyNl4zGBLviXoWXte9fwg,99218 -pip/_vendor/rich/constrain.py,sha256=1VIPuC8AgtKWrcncQrjBdYqA3JVWysu6jZo1rrh7c7Q,1288 -pip/_vendor/rich/containers.py,sha256=aKgm5UDHn5Nmui6IJaKdsZhbHClh_X7D-_Wg8Ehrr7s,5497 -pip/_vendor/rich/control.py,sha256=DSkHTUQLorfSERAKE_oTAEUFefZnZp4bQb4q8rHbKws,6630 -pip/_vendor/rich/default_styles.py,sha256=-Fe318kMVI_IwciK5POpThcO0-9DYJ67TZAN6DlmlmM,8082 -pip/_vendor/rich/diagnose.py,sha256=an6uouwhKPAlvQhYpNNpGq9EJysfMIOvvCbO3oSoR24,972 -pip/_vendor/rich/emoji.py,sha256=omTF9asaAnsM4yLY94eR_9dgRRSm1lHUszX20D1yYCQ,2501 -pip/_vendor/rich/errors.py,sha256=5pP3Kc5d4QJ_c0KFsxrfyhjiPVe7J1zOqSFbFAzcV-Y,642 -pip/_vendor/rich/file_proxy.py,sha256=Tl9THMDZ-Pk5Wm8sI1gGg_U5DhusmxD-FZ0fUbcU0W0,1683 -pip/_vendor/rich/filesize.py,sha256=9fTLAPCAwHmBXdRv7KZU194jSgNrRb6Wx7RIoBgqeKY,2508 -pip/_vendor/rich/highlighter.py,sha256=p3C1g4QYzezFKdR7NF9EhPbzQDvdPUhGRgSyGGEmPko,9584 -pip/_vendor/rich/json.py,sha256=EYp9ucj-nDjYDkHCV6Mk1ve8nUOpuFLaW76X50Mis2M,5032 -pip/_vendor/rich/jupyter.py,sha256=QyoKoE_8IdCbrtiSHp9TsTSNyTHY0FO5whE7jOTd9UE,3252 -pip/_vendor/rich/layout.py,sha256=RFYL6HdCFsHf9WRpcvi3w-fpj-8O5dMZ8W96VdKNdbI,14007 -pip/_vendor/rich/live.py,sha256=vZzYvu7fqwlv3Gthl2xiw1Dc_O80VlGcCV0DOHwCyDM,14273 -pip/_vendor/rich/live_render.py,sha256=zElm3PrfSIvjOce28zETHMIUf9pFYSUA5o0AflgUP64,3667 -pip/_vendor/rich/logging.py,sha256=uB-cB-3Q4bmXDLLpbOWkmFviw-Fde39zyMV6tKJ2WHQ,11903 -pip/_vendor/rich/markup.py,sha256=xzF4uAafiEeEYDJYt_vUnJOGoTU8RrH-PH7WcWYXjCg,8198 -pip/_vendor/rich/measure.py,sha256=HmrIJX8sWRTHbgh8MxEay_83VkqNW_70s8aKP5ZcYI8,5305 -pip/_vendor/rich/padding.py,sha256=kTFGsdGe0os7tXLnHKpwTI90CXEvrceeZGCshmJy5zw,4970 -pip/_vendor/rich/pager.py,sha256=SO_ETBFKbg3n_AgOzXm41Sv36YxXAyI3_R-KOY2_uSc,828 -pip/_vendor/rich/palette.py,sha256=lInvR1ODDT2f3UZMfL1grq7dY_pDdKHw4bdUgOGaM4Y,3396 -pip/_vendor/rich/panel.py,sha256=wGMe40J8KCGgQoM0LyjRErmGIkv2bsYA71RCXThD0xE,10574 -pip/_vendor/rich/pretty.py,sha256=eLEYN9xVaMNuA6EJVYm4li7HdOHxCqmVKvnOqJpyFt0,35852 -pip/_vendor/rich/progress.py,sha256=n4KF9vky8_5iYeXcyZPEvzyLplWlDvFLkM5JI0Bs08A,59706 -pip/_vendor/rich/progress_bar.py,sha256=cEoBfkc3lLwqba4XKsUpy4vSQKDh2QQ5J2J94-ACFoo,8165 -pip/_vendor/rich/prompt.py,sha256=x0mW-pIPodJM4ry6grgmmLrl8VZp99kqcmdnBe70YYA,11303 -pip/_vendor/rich/protocol.py,sha256=5hHHDDNHckdk8iWH5zEbi-zuIVSF5hbU2jIo47R7lTE,1391 -pip/_vendor/rich/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-312.pyc,, -pip/_vendor/tenacity/__pycache__/_asyncio.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/_utils.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/after.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/before.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/before_sleep.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/nap.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/retry.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/stop.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/wait.cpython-312.pyc,, -pip/_vendor/tenacity/_asyncio.py,sha256=Qi6wgQsGa9MQibYRy3OXqcDQswIZZ00dLOoSUGN-6o8,3551 -pip/_vendor/tenacity/_utils.py,sha256=ubs6a7sxj3JDNRKWCyCU2j5r1CB7rgyONgZzYZq6D_4,2179 -pip/_vendor/tenacity/after.py,sha256=S5NCISScPeIrKwIeXRwdJl3kV9Q4nqZfnNPDx6Hf__g,1682 -pip/_vendor/tenacity/before.py,sha256=dIZE9gmBTffisfwNkK0F1xFwGPV41u5GK70UY4Pi5Kc,1562 -pip/_vendor/tenacity/before_sleep.py,sha256=YmpgN9Y7HGlH97U24vvq_YWb5deaK4_DbiD8ZuFmy-E,2372 -pip/_vendor/tenacity/nap.py,sha256=fRWvnz1aIzbIq9Ap3gAkAZgDH6oo5zxMrU6ZOVByq0I,1383 -pip/_vendor/tenacity/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-312.pyc,, -pip/_vendor/tomli/__pycache__/_parser.cpython-312.pyc,, -pip/_vendor/tomli/__pycache__/_re.cpython-312.pyc,, -pip/_vendor/tomli/__pycache__/_types.cpython-312.pyc,, -pip/_vendor/tomli/_parser.py,sha256=g9-ENaALS-B8dokYpCuzUFalWlog7T-SIYMjLZSWrtM,22633 -pip/_vendor/tomli/_re.py,sha256=dbjg5ChZT23Ka9z9DHOXfdtSpPwUfdgMXnj8NOoly-w,2943 -pip/_vendor/tomli/_types.py,sha256=-GTG2VUqkpxwMqzmVO4F7ybKddIbAnuAHXfmWQcTi3Q,254 -pip/_vendor/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-312.pyc,, -pip/_vendor/truststore/__pycache__/_api.cpython-312.pyc,, -pip/_vendor/truststore/__pycache__/_macos.cpython-312.pyc,, -pip/_vendor/truststore/__pycache__/_openssl.cpython-312.pyc,, -pip/_vendor/truststore/__pycache__/_ssl_constants.cpython-312.pyc,, -pip/_vendor/truststore/__pycache__/_windows.cpython-312.pyc,, -pip/_vendor/truststore/_api.py,sha256=xjuEu_rlH4hcdJTROImEyOEqdw-F8t5vO2H2BToY0Ro,9893 -pip/_vendor/truststore/_macos.py,sha256=BjvAKoAjXhdIPuxpY124HJIFswDb0pq8DjynzJOVwqc,17694 -pip/_vendor/truststore/_openssl.py,sha256=LLUZ7ZGaio-i5dpKKjKCSeSufmn6T8pi9lDcFnvSyq0,2324 -pip/_vendor/truststore/_ssl_constants.py,sha256=NUD4fVKdSD02ri7-db0tnO0VqLP9aHuzmStcW7tAl08,1130 -pip/_vendor/truststore/_windows.py,sha256=1x_EhROeJ9QK1sMAjfnZC7awYI8UnBJYL-TjACUYI4A,17468 -pip/_vendor/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-312.pyc,, -pip/_vendor/urllib3/__pycache__/_collections.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/_version.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/connection.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/connectionpool.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/exceptions.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/fields.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/filepost.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/poolmanager.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/request.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/response.cpython-312.pyc,, -pip/_vendor/urllib3/_collections.py,sha256=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-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/_appengine_environ.py,sha256=bDbyOEhW2CKLJcQqAKAyrEHN-aklsyHFKq6vF8ZFsmk,957 -pip/_vendor/urllib3/contrib/_securetransport/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/bindings.py,sha256=4Xk64qIkPBt09A5q-RIFUuDhNc9mXilVapm7WnYnzRw,17632 -pip/_vendor/urllib3/contrib/_securetransport/low_level.py,sha256=B2JBB2_NRP02xK6DCa1Pa9IuxrPwxzDzZbixQkb7U9M,13922 -pip/_vendor/urllib3/contrib/appengine.py,sha256=VR68eAVE137lxTgjBDwCna5UiBZTOKa01Aj_-5BaCz4,11036 -pip/_vendor/urllib3/contrib/ntlmpool.py,sha256=NlfkW7WMdW8ziqudopjHoW299og1BTWi0IeIibquFwk,4528 -pip/_vendor/urllib3/contrib/pyopenssl.py,sha256=hDJh4MhyY_p-oKlFcYcQaVQRDv6GMmBGuW9yjxyeejM,17081 -pip/_vendor/urllib3/contrib/securetransport.py,sha256=yhZdmVjY6PI6EeFbp7qYOp6-vp1Rkv2NMuOGaEj7pmc,34448 -pip/_vendor/urllib3/contrib/socks.py,sha256=aRi9eWXo9ZEb95XUxef4Z21CFlnnjbEiAo9HOseoMt4,7097 -pip/_vendor/urllib3/exceptions.py,sha256=0Mnno3KHTNfXRfY7638NufOPkUb6mXOm-Lqj-4x2w8A,8217 -pip/_vendor/urllib3/fields.py,sha256=kvLDCg_JmH1lLjUUEY_FLS8UhY7hBvDPuVETbY8mdrM,8579 -pip/_vendor/urllib3/filepost.py,sha256=5b_qqgRHVlL7uLtdAYBzBh-GHmU5AfJVt_2N0XS3PeY,2440 -pip/_vendor/urllib3/packages/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/urllib3/packages/__pycache__/six.cpython-312.pyc,, -pip/_vendor/urllib3/packages/backports/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-312.pyc,, -pip/_vendor/urllib3/packages/backports/__pycache__/weakref_finalize.cpython-312.pyc,, -pip/_vendor/urllib3/packages/backports/makefile.py,sha256=nbzt3i0agPVP07jqqgjhaYjMmuAi_W5E0EywZivVO8E,1417 -pip/_vendor/urllib3/packages/backports/weakref_finalize.py,sha256=tRCal5OAhNSRyb0DhHp-38AtIlCsRP8BxF3NX-6rqIA,5343 -pip/_vendor/urllib3/packages/six.py,sha256=b9LM0wBXv7E7SrbCjAm4wwN-hrH-iNxv18LgWNMMKPo,34665 -pip/_vendor/urllib3/poolmanager.py,sha256=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-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/connection.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/proxy.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/queue.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/request.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/response.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/retry.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssl_match_hostname.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/timeout.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/url.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/wait.cpython-312.pyc,, -pip/_vendor/urllib3/util/connection.py,sha256=5Lx2B1PW29KxBn2T0xkN1CBgRBa3gGVJBKoQoRogEVk,4901 -pip/_vendor/urllib3/util/proxy.py,sha256=zUvPPCJrp6dOF0N4GAVbOcl6o-4uXKSrGiTkkr5vUS4,1605 -pip/_vendor/urllib3/util/queue.py,sha256=nRgX8_eX-_VkvxoX096QWoz8Ps0QHUAExILCY_7PncM,498 -pip/_vendor/urllib3/util/request.py,sha256=C0OUt2tcU6LRiQJ7YYNP9GvPrSvl7ziIBekQ-5nlBZk,3997 -pip/_vendor/urllib3/util/response.py,sha256=GJpg3Egi9qaJXRwBh5wv-MNuRWan5BIu40oReoxWP28,3510 -pip/_vendor/urllib3/util/retry.py,sha256=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-312.pyc,, -pip/_vendor/webencodings/__pycache__/labels.cpython-312.pyc,, -pip/_vendor/webencodings/__pycache__/mklabels.cpython-312.pyc,, -pip/_vendor/webencodings/__pycache__/tests.cpython-312.pyc,, -pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-312.pyc,, -pip/_vendor/webencodings/labels.py,sha256=4AO_KxTddqGtrL9ns7kAPjb0CcN6xsCIxbK37HY9r3E,8979 -pip/_vendor/webencodings/mklabels.py,sha256=GYIeywnpaLnP0GSic8LFWgd0UVvO_l1Nc6YoF-87R_4,1305 -pip/_vendor/webencodings/tests.py,sha256=OtGLyjhNY1fvkW1GvLJ_FV9ZoqC9Anyjr7q3kxTbzNs,6563 -pip/_vendor/webencodings/x_user_defined.py,sha256=yOqWSdmpytGfUgh_Z6JYgDNhoc-BAHyyeeT15Fr42tM,4307 -pip/py.typed,sha256=EBVvvPRTn_eIpz5e5QztSCdrMX7Qwd7VP93RSoIlZ2I,286 diff --git a/venv/Lib/site-packages/pip-24.0.dist-info/REQUESTED b/venv/Lib/site-packages/pip-24.0.dist-info/REQUESTED deleted file mode 100644 index e69de29..0000000 diff --git a/venv/Lib/site-packages/pip-24.0.dist-info/WHEEL b/venv/Lib/site-packages/pip-24.0.dist-info/WHEEL deleted file mode 100644 index 98c0d20..0000000 --- a/venv/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/venv/Lib/site-packages/pip-24.0.dist-info/entry_points.txt b/venv/Lib/site-packages/pip-24.0.dist-info/entry_points.txt deleted file mode 100644 index 5367846..0000000 --- a/venv/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/venv/Lib/site-packages/pip-24.0.dist-info/top_level.txt b/venv/Lib/site-packages/pip-24.0.dist-info/top_level.txt deleted file mode 100644 index a1b589e..0000000 --- a/venv/Lib/site-packages/pip-24.0.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/Lib/site-packages/pip/__init__.py b/venv/Lib/site-packages/pip/__init__.py index be0e3ed..60c2d0e 100644 --- a/venv/Lib/site-packages/pip/__init__.py +++ b/venv/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/venv/Lib/site-packages/pip/__pip-runner__.py b/venv/Lib/site-packages/pip/__pip-runner__.py index 49a148a..c633787 100644 --- a/venv/Lib/site-packages/pip/__pip-runner__.py +++ b/venv/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/venv/Lib/site-packages/pip/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/__pycache__/__init__.cpython-312.pyc index 83f736b189341ac67e4cd376fe0034dc3c0d4900..efe89c80ef8f7400f2fcb3435ab88d9e396b0b5d 100644 GIT binary patch delta 39 tcmbQwx{#IkG%qg~0}wp!otKt6kvEr}&B#R0P|s*%{U1g~vB@<|$^g{V3e^Ar delta 37 rcmZ3;I-iyIG%qg~0}!0pJu5AFB5y7$i;;<*!N$fvjEo|a>zI@Q!*2?I diff --git a/venv/Lib/site-packages/pip/__pycache__/__main__.cpython-312.pyc b/venv/Lib/site-packages/pip/__pycache__/__main__.cpython-312.pyc index 1a5cad60d7f92f3a0d435e9a41b9038eeeeb0c42..ed3eacfb869ca03ae390c53afb72aaa618cdb1c9 100644 GIT binary patch delta 20 acmdnZwwsOnG%qg~0}wp!owt$OfEfTf`vrOc delta 20 acmdnZwwsOnG%qg~0}!0pJ!>Pk0W$zQJ_U&Y diff --git a/venv/Lib/site-packages/pip/__pycache__/__pip-runner__.cpython-312.pyc b/venv/Lib/site-packages/pip/__pycache__/__pip-runner__.cpython-312.pyc index 9494be4f25ad259b3575a87ca0782efdc55992fa..61248e3172dbbbf8fb2641e61ae043049951187d 100644 GIT binary patch delta 29 jcmeAZ>=WcY&CAQh00fVF=cTRM$m_|($gw$`$(#)UcCrVw delta 29 jcmeAZ>=WcY&CAQh00bv?&q`aek=K)nk$rPGlQ|mzcP 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/venv/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-312.pyc index 719f0a4e602062868f699b5c8a763831340a4739..9ff72093f6a9f0fb40f696c650da8696e05f978e 100644 GIT binary patch delta 51 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 We^Vmdc~m*T($}NI|B!GLDf}Pdt2(Oy diff --git a/venv/Lib/site-packages/pip/_internal/__pycache__/cache.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/__pycache__/cache.cpython-312.pyc index ca021243dad3262ab2e71694a1396db571d704d6..e1ebc1dc8d61895172c7e4f9c2739f7ed54c03f3 100644 GIT binary patch delta 22 ccmaEz^g4<6G%qg~0}wp!otM_QkvGl|0AKD0*#H0l delta 22 ccmaEz^g4<6G%qg~0}!0pJu9tgBX67`0AN%H=>Px# diff --git a/venv/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-312.pyc index 6690961f85178ec6e34b99f5559c36c7569d1df8..2617f2417c25354f349a57362f1b8893ae5066d8 100644 GIT binary patch delta 22 ccmey;$@ry{k^3|+FBbz4Jno&hk^7|!09-By?f?J) delta 22 ccmey;$@ry{k^3|+FBbz4oY*~UBlk-e09{d(Ca?-SMQbAl-XqHu5Rc&jn*a^1f#&+Vi=iC|4 zI89ir{m$Fx+;h*p_ndq0oB#eZ)%)jEiLWLkm<0U0bM_lUIfIWSX0rW{tqKfy(;R6` zkeH=?S5 z(>Z9IE8A9F)NnQr+58xG4QC6G6=OWC<*XIiLb-ay!#d7BfNW6=yB^soK`KVNB!;f# z#;cGmjbZCJTZU|TOm`bNyBgVw7_%kkW7w^nZ9sMtXQv`-*Tm^Yq&LepRA@LYIGQ=X z1^KOVa}3|Y`6lFvUCsbIXIqf9$FQxOZAG?CZe6i$?F0z~i3CZZ zM>9uNaCMI{G@CP~N=+t`tjp9&8_5TtD!*BG6~#akc&$b7Wd0%3e$o*91856s*nW8L zKo;~AyuuEES)9=wM9p|7KS3=WkKL|ctfD*^%DD$i$QaKu;*RjWtyPmzK^$8ZL4>^W5zH z)yLrJ)#--r2>A#ne^BuVZgJR_Ad%YYdD{Pyw=2`2zp@63 zZTsOyWjbquUsu+_b(;$wwxz?4Dn0uu?5q){xH2!k4! z-)jz4RX4KKzsC16o$@H@NLJ3m$(roAvm{1HxI2;uS8GI82)ApVOL&MHsFePQ?R<+F zC-{479$&$Ev!Jdjal=k*^~tnwQ&X^H63T6ht5$ztOw-oA zm6pDw#pjYvNXxlUzmQt8q^DPdkeYp=Y$2rxrq^0wS5*omt+v9AwJrHT-4is#u9`Kn zK)@HswXOlO*QK*us9Bdm^#kE`-^q`Le}URRfv}vV5d!{peFbZS>+AncM@r=aLMd5hc?!-J#c>G9QzD<>YLfOqJ7WSTiKW4XZ4-YzGui2K{u>z=w>s#v}+3M)+Fta zgHFjAbhi7BIz4V_+`LSP?ttiykhVxn>EvVs95~eM5)>Y+Dx%mxAx3u=9wHF|Is`;f zRC1{qt?78?vhQeTwu1-VK6mioK^H9uZBnO%MRVq9&0iT8E!n3vXHAgYn**DRn?&Uq za*!dqoGVd@-e~CcqH>YO-Rb8x|G$$!P&s(eLw!(zVjn3v7wk{BKhb`nVZNksPP%gV zrNeXk=aV|-4IPne;48N6S+rINWNK?efzmL4Nu$!{%;(iC3HY3QfIqGleME0d2Bz&~ z7t-zt^o;m=HuOkCwVI_sXmhcZ@5J9Fzu!Z^B5EUfg;1V{PdE3mu~65RGNy~r(Ix%b z)>3v3UfSB1%!|ZG?e15K=@PvYjKb!oFSAQ=x2=d>gQm80_Jh!aZBq=b7Pob=7om82Kd&fd5Bd8ELI9^%h$hNU zQH1~5R)X#?Z}*jOcPy+K@Jq+h?Qv@IPt-(3O`>g1KyQ0Fdl@F$*QH!RKCB7&m7t;_ z<7;rOeOngKjMVMUfU8we{7L{bk0-^Cz}oS%#7NB4iQj{ff7-EzU4e>Dhvgc1;2RS; zP+lYWH(tz_NhG)gbDitiW%zaH1baO+()C@HZh~|_4(0EBnOR;%c|38YV;hZQ5#H}P ztNR66y-JIl$)iiTZxjvgze1OKyO{0<8TON5VVJz-#2C^x?N(&3>uW{aIJqIdmVSfEV#12Ahdgzh3Ry zRF13aO*s58cm_%`d5}BDXY7u}y1Jz4R|xxe91u*&cFG<{4W!6ry`A7LN!L-dF4lcF9=S|K=!g&K3qNr|L^ z9{LWygCp8FGFi#1PaD~q_zDb@QxiGZfYS2W7h&Pf$PRWgRO7L*xD^w;Yxa7Jap1?i zHg*QS?LE)pV6!hjx^EfD6~PHOqWy zeo+fybwD0fPD0MnhuI6EnWJUu>?ES&Tl~Hu_i&F>3CK!VqsUH4vBF!&-K+#U#*0hl zDR%sv7Q(vGh>boV57I4P`DapHMOjZQF1?FvPe%Dh?$2&Cq zey7FzohF=)-xt0>(CP6+i=a;)^efVM=GZb{>GM}AoU9yjdt_*8PB$fE7w6b{VS+(Q ztvPj4HK9_p6Do;~lwtsNNPj;yL#@K+*OD!IVMaZv4(g%Hk?WGwl4e5vq%fnBv_q=r zXtTz@NsTWlNEyZdB;ADSNkP)jsGq}r=xd{1L~5<9Ma*4y#AqqvNW^#_@{1{xQ+(9(D!A0adAnS)IO-f6 zaSqGkF@8betz}6ZI4+K_wTTo!z~vwFNaCPN9vl(fL!vt<4my3}$^u{vD_(4$rL;JG zK7TMqJ>C@4&8mPn==TM2+Yg9SPDMt$5ug8K+*5iQbHzgw;4lVU5e}1Jjn=se(VAe=8Tjw`rGn5xe<>Zh+zqbNPa~{Iv0A zQs#yBS<5eTZHpG`4NLigrF`DJdUnmM=Z39$!PY!q*)pGMKi%?1TE_Xt#~K%tH!r3& z%(cv|pHFGJS~s8E`H@y_PCR3ux@Qv1nTx4ae{Y;Uu_UktJ3~ydvyarMKW#^~G4YIk z!I1feIdeXzVs`&*_k32vYvxT$8kSPMSiR{+b?ZWP>wHz)Rp%1k<=Pp3c4Xu%B?!i> zj|IKa#J4rPytm=l6${O5CPMc`ol=cYD6%KR?fmSDO{6CHPa1G44R~5uOfEmw{#%Vj zYx+Pyi0qJ?Vv2g#pD5}sdDuC4+>UdP6YmMMN0N5DcqOMQXX}XoIIDqlT+k^Cp;1pN-Sgsn(`%%Sz7`HvqiHR3< zjRnMGGG#kuv~zH9OmPNf&v8+b@pllf+wH?Vb-4#!JY@q|q#nO-m}(SjB%(ORYsZ7T zEzy1-Hg;mkDM7c>bH7GxN)twgr)~=lCUQBB{n4Y1L3Mt%T=2)IZ6y~4H7-pRdca(K z!;tVN(n6Jzho7350!cgt4AB%&+G&M57+9Oqc6O0W@c9>3yN*`dNUMzyS#2^Z>r>WJ z+;q+;CWh1Pg+@Vt9;oFn>aS3FZ$j#yUWFDSe?@#6=@j}(pg$d6L zB^9P7t&o0lUtA4&n z2t5lz&$~j$g3xhGD8D6?+*T*w(&W9XX@uveo`Nr(T1+yqPBx#u>YhNty>zI0_#aE| f32lsJ-Ro0jGShrs)ja{9_iE$$%f|vf`3(ObmU%u& delta 4163 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 diff --git a/venv/Lib/site-packages/pip/_internal/__pycache__/main.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/__pycache__/main.cpython-312.pyc index b920f34cdd9e0fb2a5bc0aae88c0c82cea0f0e1a..4d92d369c4e9d97e8afa2993f6d5bccc87d6fd06 100644 GIT binary patch delta 20 acmbQhI)Rn@G%qg~0}wp!owt#@l?ebf9tCy) delta 20 acmbQhI)Rn@G%qg~0}!0pJ!>O(D-!@UVFiT% diff --git a/venv/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-312.pyc index 7d25852b7382302885aa4ee291fb09e12f348af7..39c2bf83626ee951e631f6d90223e74ec24de306 100644 GIT binary patch delta 20 acmcbsc2|x2G%qg~0}wp!owt!YNEiS_+XgTI delta 20 acmcbsc2|x2G%qg~0}!0pJ!>O(kT3v69tJ-E diff --git a/venv/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-312.pyc index bfd762c54e5f2c0c0851c64bef1d56f3e9a1e27b..9780a82a53c67ceb2cf79fa540a0bc5f35baea87 100644 GIT binary patch delta 700 zcmZXR&2JJx7{+H-N-3}`lrG-ng-1%s`#^6cr~abM@;A{%4)M?vTC5~*X8)Vm%WJMy6OIIhlO+c0lPEg`iF z8n^~<@(AG6Sex}Vh+nB`sb>DF-aSq_Bf`UOS;*N*ee_8`W4(j$iuhDKh6|!?TTOSuBtGm7YrBW!01tSL_xA4A zW`hE*YyRhs$iop2iVwC0b@9cnz>xT5XPjnfAHw(IRk>8k);pk~X<({wGaxxsE}1y zPp^!Z&t`#w6+A_gECo}N!_;IJv?O1ob1V(hlBa2gWnorwgyvWt<|S*iz>2UaIZ8{c z49k*rI?pPwBH5r-R)aOkF>13qtV@nxp$==n23vp&Qb^ECY!NQ9CAh?v;j+|bXp^nL z6`-gJQTq2e$|U(cpx?MG_Mtuwo^yVX)d~2cz%`sAEo_ojH-xRD5WI@#!NA%d}!3fK*Tx1xy9eA zZT?e5spM8~?76+pf!7-j?hKcZcC$o3g>A0Lcd6v&-m(){P9 z1wh1qZM^^>=G*DGn$&}a@B^11kGP4T%<#9fr_;huR6hW4n}4Yt^E-A4MEKAy0F58p zIS}RV>?+Xtce}A^1PRutH)`(p1|npD#P1OgVdNn<7MQvJo6Qay6Mv@u2!N0Lsk6pU Q922zpSLYXS_(@~uH#Y{U3jhEB diff --git a/venv/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-312.pyc index 711ac1c1971fb1959bf45b2d951b38d528059b3c..b26ba849259d474e0c9d39245bbc6110a93aaf97 100644 GIT binary patch delta 74 zcmX?{wIhr7G%qg~0}wp!otGxQk@o}}+ZiBlI>Y1#T;h{IvCR 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/venv/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-312.pyc index 04e8b81b587597380c19d838d772510080652b82..5d1a921b9e5f174563a009079280f61bd28cd417 100644 GIT binary patch delta 19 ZcmeBR>R{qN&CAQh00fVF=S}4P3ji)U1-1YH delta 19 ZcmeBR>R{qN&CAQh00bv?&zi{n7XU791;qdW diff --git a/venv/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-312.pyc index 3f47315fd212c84beb8b1855c51d652491917c36..2724e725af8e6a94bce8cfe308f990945a733db3 100644 GIT binary patch delta 1471 zcmah|O>7%Q6rS1t^*?oDC;oSx){PyKk^n7f>!i3+8wmh>l;b-<;X{-2D~i0xC4{DM$zP z2e1qwF06_bE`%&(sF35*$Aw$ne3( z+=SC_@3k)2@JA$!Oil~JnvjHJyf4TywZ?7=mHNX}PDrvGrm98Z9sU`r_fd}@2cf|y zQ!zWFGn=T=(!PX=%XDfn@Cey`N!xEa?J6+3<`t0fubM{ksofy1;$G+4yA$XfE!FZE zos^#cP8q_;*teTXvdNa$^uoBN>W4Bi(uZ=>F5_OK*7Hu5H zl_Zt9CPZLW@y7qZ?l2bMju>cH{ zn)>@oRWMrSQpj+?w)*{3O-H_P=H;pUYlYH@-`G!r9~?#h-X>Smn{stwX_nL$n*7D8 zQ6F|zFdnGC?^?mfU!g?yA@qv^LThMSLQ447-cK?gWwzvj9~I9Z5^{NNj9wkRk-M7v zVBn!M{TbOw})d!kgc8DMc^(_UW-=Qn-h^i~E&(>2NVCG*nmd zpwtLR4EuVE&r6M*MDhNpvv^eaj`x?au;~w!B-ds}pt$9A7GwNY6jLNGP+f$zk(BCp z_ZYl;f(d0WK9L}2;bhkiigzCa)WWB-l!xuNvj0GHLSVh2?(n z@wAM6l5ucN7wMc}gPdjN5gSbK1s_O9*!E2Q*Wj4wX2M1)QUI>=!jtfIv^$%ijHX<^pf8q-ka|lFY z+2NKdb-FgcI5jgnS0yu)uB#MU5-E(gWoD^~FnF)N9Lr*7>jI+8*asVN7-9V-=NYhv q)vl@)^E%sJV8F!xsT`fJRW8j{bL28yN<1fN82h#-;ZC9;Fw$SO$Qv5~ delta 1404 zcma)5Pi)&%829sk$94KAandwtovbTanlZMavO(F(=roE1)Y;IcZHzU-sT8Y8re{;w z%R&knq+La4Ja6=q;UxL%E(h#5I-~0Z(@9*=C z`S)Kmel(02$7plov*kTs8ykfGRE4`_0j~23B>2S0I$9YyqQj4IZO&KVJHB{A$}rtJ z>6*AU(YSyMh$CKO!O+s?eZ6O6UjH&}!8anEABVld%ldF6yCZNrnUe_@@U96D)Es;( zm^10f+z+8KJI3EdeS0j>;DL~Yq-c>GjAn~)QH(Qgdo&sEb+Ah4K%l!hSW->+QcO)* zQLI3Z`XSs$gCghuM|ERT+A8!f@{Y02_oS2DCDvp+?pt6>ncWQ@B%D9lza~fd+JnKM zyEoGBobD5FTN=0a?Pwy-pN=?pKm09O=>w6xa|T21L0HmKuppaoNKU{NIU|X4v6i5NSQWl8_e<(#_!I)~1XIP<0cugH9N7-O4 zG7D>}Svnd;+&QC`*&vQZTK717uNDaIz5G9#&1OZ`+T$CZEIryuZe8eQYNvt}H6MC} z1-PkMM*jggBkl>fuN845bGuik67DKL$@wZYW4{dliZ4Hm%`d)cU!Fg=c={w%^h&%C z@+~h^YR%O;Z8baJ=nf&}&X{qH#9n9qgY5I>;q!Q^b3Z;KF8yGt_7HdHz?{8D+~iHW zsBZ4d+WW<=*noXV-b%}eQyKe+yfr5?ygRGg$Hbq+M1>dcB~uk;;9gl|xILuXmasiR z7*d=$eHNk8X(W8XSir3KI`esY27XJ;k`G`y{nVRN=#xNr5&`EK3Z73X&LdPBHNU!A zrJ+!5UM)!vhehvG=tEkb#LhetJ%j4Q5xfhx(m%`3q4-MY!_hgZgy~8Gy@)C-DO8v1 zE45~|QS)#;`TSZh#2fJEc$s_w*2F^kJUWjsDCu+@dHnUM1@BE{rya(I%1YhyojRpQ zP?GB&#tfyp$8;r)_VUA>iSprY!P;A`#+A$HLu>4Ur!m0dkzVMf$N!2VT<_$qGSR!U z>E@n7fK6yDi&Y{!2%&X1kMj=j|O+W9e#U7!s##7Ph|DnC&vqDJl3*pB1ipD^nL z$f3BUD$ok?GgL~Ys=XAI3MwI)s#1I6w?(~#azR@TmFSHFZc7C1sqbwFP<0O9y!qaH zGjI02d3$sG%((4mtJTE8xOe>XiC@K2HW!&ZCEY$mxD3gd3;tpt8PH@)Ay|}>QZbYa zX=`gCTmz!V`LJ?F?xnM9y{b2UEo_f$R zbi?oCLqAqGw>Bq{G6Gb&yEbvbD8ex=%g+80pu#+j!=#$DyUHn=Q@-Y@ww<=qa{aB+PEK zy{E?$Xqatrwv+B!&Uu*d69OA_?PCwxyNH{8*nULn0uyccIl7y06>)i;F;rGA%Ts8=}eF2|pou}OSrV)3r~yB)&WH3?C;+(|Y&gv+7@v2S3w zPq-o>bEVG-cvUwrsuQjbB6CfLHrMR2jYi=*kIZ#r!VlAp$N=Dv-2uR#nn1x0dOQ6& z2qY{}43h3gn8nDjY~JxfurNcpjeA^d!P`Il4eHhc{9WZ9>N%V9gnUe%-*wv>tn+== z@P&AtgXvOy5vRWd&L(Mm{cXavNDG!Al-r0e(CvjCDCU!H15gdKS-PjJWYva!Gx=|6un!9U4S&xe ztLv@8Lr%I)AC53HCk!6avQ+0dFs@JN+%RExMWj0SMGpRzhG)sM~F1cc-@g)39 zXg8pvC}E&lmi{rWhfL2DvV-&-aPY!7<$X2~N|+3Uf5ZVS+Sx~;KF7N}i7(j1MGghc F|6jF|qdout delta 1861 zcmY*ZU2GIp6rQ`&?oaop?e=H4-EKQuwmaRHmbTjzL5gi@Q6N-mtUpU+*zQi3ZDw}L zoo#_i(h^9N_+at!P>nG@h)O_>SsqMGM6d|NXh0HU#`@-yPm9oiKB(tRSsHFK-#z!7 z@1A?^oO93Fv72L_AKdOT4#thI-h0!4|pt0>4I#Kb2o3wS?H%Czk07qiQ^x$?Ca;q9k$| zEt~i9mkDXk|6DRNTnpr zJX?PriKPGw+^=>Q9b&Pvn_k>accR4tAb=0%aXv#{V53ff3^C2wb6^+@QDRh$YPntN zv?8l=HYcY>DAj0`r;i=bJ?I60m4I$wHh4OdopTmLfyI8L*Z~%}6;J4vJp@tw=X`0G zd4z@b;-<3c1l46JLDTwq%bI)Bb1^>P(0u@N-lF664F}i>yC>;kpqnVgv)Ixu2Z&LxF}CWSY>_4i8Wx3sW#SMU&q=j z8=X&bYS`KOdeX(ds6Rq_m>B3My-W_ABLU`Y*w^WY&D4ufi%^A74`7r|(@ZvJ@cJ>` zu#sp24z%vyk4Ei6FNA2v*ue~HSIP)ZLMxI#$>Q-g2SiYwKP zE7ffUN2%ZY7w4!9-FI;{0rpc+V3&hd*4=n@zmGrHHyGlt1jutf{z}M&*s*n}gTE@G z=4wX+;CGI#!w!C#N6oSWIm%?gJGDyk8K6KzNrQ9MlBfFXj3432*QFw z!;tAwgd+fEp&b+;bXXXE_Dz$YoonhI`W$VW0sda#?pryJ?``R{wDigyccftHbVo17 z3LH$AVyiga<2jFL>I(-6S1sOhMW7)4LQ9(f9%vH+mYQLkmFa}0%SP$pnT(vHuc8GT z1&y<`u$^Ss$3mA?L50RvgubUED25O!0Srenkvt?zsSKq-RMsKjQ>1t~qbwy)%%mk% zgFKD0y`i9YH>jhw_3EcP+3`@Y_jTMdieUZ&tWQWFjDfYc{~{>n+{JexsR`&5`5!~e zMC^5lE47VF`bRsKj^3_qE%2cD!(FqOd_T5$=(f9QwGts@@SRt(Xuaz&;eKs~+t% z-;tSPs4mbu)eN+8YydRKUK5*1BU=z_tY(b}Yi_Kr*$mCiBosM2OGE5i(ci<6pFzN@ z&=CZT*i6?y_HB^z8AaYs&w~yg9;d&-%324@?Zonc1GtN@>Sg1t9o~5hiQV#qRyh<* GC;tO&vAQw< diff --git a/venv/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-312.pyc index d6afbb38123fb1b98baf4db6e6e96813c8441b80..df6c1fe1360ade706aadf1a9a14e7d8a8e1eb4ec 100644 GIT binary patch delta 1689 zcmZ{ke^69a6vsKcxFEQN!w>}_3#`B*XzYR!O0gvVYRUK^pa`_U!fv}h@Vx~EB;gMr zGt==nNt%TbOhl%59m+q_%F)Rorm=~UdCf3ZOf?OzP5;q2P50bIaZGo1K6~zY=YG$5 z_nf%sTys766 z-z__NaGMQ(Gh{7FHE;(mi+c;)I1;xXc421xXW+q^c!hh)6MUf(505=2Z1w}wGpM2=!Y5@9)^QviFH`*dQvgzbs%h6+=NNEn;+FGyTJ3bT^8>kd$S z5B4RuMF?q;L_|^&xfhd6MmU5v({1QsYg6LDc&`Gvmm(g>e}sHTuxmvh^k7tKYnTYX zUvMBb4*Kv)>MNxq1<4oFnx*jr5V9(03M~9!Jn3H&CReuXjmIJPGxIZ%0H<(sx(SAuH$4%I{$nGtg;O7+5NiuJqcSp?w>VU%!|a1O6zCc_x|GN*MSLks(1 z^#RBe_Cm`juPM;4u$uOXzMtn7pMhujj{+P9fB%K>S^OaD=3U9|=Sm>`3m)-*jWO<( zFFc?i>Knz7HMRU4r8Sq~ZDwA(R|Bo=%=1A2*VyMTjKGR(v^9}1NHBAlg5+qjPZ4qn zQG{>tpfv|3*tm5L{L>(2%>R4B7x!NRS-YUz3WXn`6+sOl_2VBAxjiDg)=X$gP+i38-QUpVLKKG1c>YkZv9ti@*q5b45GH!Na0(JC<*)HKnlA4LiS64q0FZ|X z6$xpEirscuN;S9|q(<3MX-KYf)Z3dq-fRQ;O}wEZy_i!E>!`@l=q^!Zf8$q`ZQ=Cp zs?KRwoDM}!Apcb?s7lg{vUGRL>Z;0xQ2eIq576OAb(eo?+|2xHE`XaU_N4&f*j=*) z{=~_eT%EYiZWdi@xxbn76;#zF0{qUp9hU%FFu$Q`-%d)~NN6H76ZR1H5;_TQ5cYGZ zA&P5flgClrEPLcP$$N-!m>~XE`p6Rh3gWK!({hOL2|?U7x)t&mL0p6^G0YZPw-UtE zPLM?dD`yfi2-gXd1TkY%xXT%CoTl~9gkK0g!Ytu7VUF+*e(a1X1bzYKP=cQD7~ye3 zI3a@Y1cw@FwUt@76<6oKY|XRfud804Z!OtclwT}IQOMJT7{W4K>WT@;;3oeDC?zb* c<0QJDYCIA2c delta 1622 zcmZXUe@xVM7{__;;0qmIA;wCOac~G6AP5J9T8Yx65TbyPB(dY};O@9P*!O#gphavQ zVi94_CSWXCV3X+-{lu!(%+(xZ%>2V4yU5Yc9l>`}`oN1RsV!kbXQjl4sj<+DQ>nc?z`emH zpU8q;#4B zhH+3*pE4H!ggUV7lF<- z1o{>7leykhXH`^u zrCYqYFEGFK6JFH&r7yue?k?+rIh-qN=i6Q7vtT^+ueO-9A=1&<6}wyUnA~QoFVJaM zJTkSWA!P9$@U@C!xXZ3od;nphoXaon!q+Pue6Vg+4uXsIyf_3vq^T_-E}&bRZ)1xI=iA%Yz@usG+s@SNENmh>e>5MF)HZ-rFa|1_q48| zOYliHlVYY3G&0PqXzvVIQGghh3YZB9DYO=uu^2+f281o7!PL{=w< zPovmfjZW*{CfO+;CT}<4ZG!l0^pYjM0b;gt2Pl{{uB(maGe~QP9X0?&9R{8N diff --git a/venv/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-312.pyc index 5fa98028f1e628f9c50f28186a24c2510604b4a9..fadff35e464e384555b0d7d3891911303f027055 100644 GIT binary patch delta 53 zcmaDO_)d`bG%qg~0}wp!otMVAk(Zy1QGc^6TP~AuG*IvZGb1D8McW=2NFk4%h=ERPv@C(q>w F1OQz@43z)? diff --git a/venv/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-312.pyc index 21ba253fb70134a34c1fa06417f2385cb5cea2cd..1107c0aaa5d038df5ad527df688bad56ec71af5b 100644 GIT binary patch delta 20 acmbQOHd~GRG%qg~0}wp!owt!&Ko|fziv?-` delta 20 acmbQOHd~GRG%qg~0}!0pJ!>PkfG_|$&INe@ diff --git a/venv/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-312.pyc index bad619e4bd83b1ae452ce7e34555cc270c591332..dd4953e63f3a39efd90ef27d121bf9823009d6f0 100644 GIT binary patch delta 2389 zcmZuyX>40X5Ps|9*^Xn!N8%)PlQ@Z!)M-;%nzkejQSXDc(9(m}9L}@fi*fRNXrCRD zsHmr)Dr%uwgj6B*;I0Z%C36VG4-i7C00{{MMce+PzW|{i)E~6`U}j&Oq!pI(dHl`n z96Pg2>Mo^L&#DhWQno<2Xk=B%fYEIHftgqrony+l%pYS(MBzPL}wvhL3Y;(=^1 z9u&VFdTq8YUY8BULqxJj8W~xNp6>l<4OfWC#2YQr7D;uUkW`mu8R=zzIf6ab8C_WD zszB$~!dEKnLcvx8>wy#fc%r4EYZf{$=xVg)*%K{n7g^pVbL+a?1h;L>q>9|NMayYa zDds7+?Z_BK?tH9J%;a;5&d!rDa*Nej-q_&LoQ;r*YSWyis0 zIn_G&LrYl=0p~j@jgz>){HH}HvLC$A02{KUNi(}T@4}SX1sOAuHJ@)twE(W)N(+HEW~|yiVbm-LBTbGU-`D+-rfPYY-N* zbKb7S>rh;eumK=uH3Mx1ncHQhTRnWizHm2k^j5W{-nBm)SoxJHT+W z??Pm|u;F&2pl6D775=iDA@+ex_cOb{MHZE>W8MBkB*5PFuYl{l;SV3^LW@p>hY>a* zI1zRu>_x!rxhIiG>55^bG+j?5E)yC7)*t|D%}e!xND%_4_=#-`yw?8gRpWAYTJqUL zUs(Ufuj#1W9=f>oy*-z9PD>zOO|d(Hh}0HkgpyYqFDN-Rp=!fQNiT{P(}mkD-JE zNYSf#cO{e%PQahBTL{w@m%Z+nU})OvVlOvsGH;;tCT}8SgxzR;MsN!;JG;;`NpZ83A@z7+LeHje0 zLS(B?@k9^OPBC%Zn;+9C&8S);PgRgkvg^@EtMKVCv=r`4ieU_VU!upN&E zMCaG?Vf4qHDMiN@IVr<^Dv5dF|uNY z^a`ywyoplS;&#X_PpK7ndK@8xAj*+nMe!~6RnMNi;%-DRm#!4Gga#o+{^FX%O6FvY zJ0NDlDAKu6Ht-)}rM}9}9R+T(9h*{qe(5dy149_-Z3GNKPXTb7o>x>_jlZW5(2x1> zM%gR93%6leG>afI{s5&j05cQ9tx%ZhPPE%m*$^Ls&D;`*(AM(p-UJ~V*}hd%+YX=u zJ9if-Jds4nP|_Mb3mlh?B6e{umC734i0&)^mD;X=JlP-yZo}%;;t9rT?|XsfJ`pc4 ziQa9=d|nsxExKzyIC1+p&eVl~eWkb%DBhlVTc4wZ0snswjYyJJq9g3z)i=Av-~%DW zA|g6>==pRylS`Ws!{`JnrR$lcZ>5F0SZ`mHRI!77t+E^WYIdZrIqX4E43P^)YzMf2 zTM^6h9Q(8{JRlZ7?mu2_Zk1gMHNZq{3JibW3c2GP$mZ3Ot_{*}n6H14ZScA@$Oig{ HY?$zWvyKz# delta 2368 zcmZuyU2GIp6rQ^~Gu`cWyMO(IcDq|Fg>5MES4%5m5fCelV5mZhu$}JQF5Axjq?a`D5r1yOk_=me(rW>P zS}Zv>+k_8w`7jATmIRWm=D+&ykPiM!?cPK;Fm8JWYOg9O50iTOfU|7tK;RJAnh$gm zvW0(J*VQ6r9swEQ&D&WUlP4APP|yO&6Tx*P@F+0Z075sf)URnCL~;khV*n|yYiKwB zy*@^gTnl{+&U_N;ZAWL=!zi-o%hNzF`w|NegWy>B?c|eEMrd})$~mkTPnxTA1ZegQ zPec;_B$9&wJQ-}_MpU z5#B6ySQ}FHbf#n!%(O`-jI!m(qB8?;R14Zu)G%7Ij0|OUz)R_FqE_)k&7G~%_oe=L z!3`h}V#n9;6hi)ZjZH|hpNBVdMi8wT%pq$hZan1B7Ui@ z0s7~9+sO&^@u^gubdo)XI**{RH&<|&ipMk_18%AJpbhpsa(pFLEK%mnvKo{cLwFGZ zyO5z)Hzf{I4u30t)Q!x!Oxg*_aZloO6M8Syf{~}}G>SzKqWogw>_{h&5a}7@;6fC7 zrdXKBWo6wMHe$6LQbayqN`~85_ZKJ5=aOS#=@~YL@J`WL#wx!hgM_5{KONnj%iG{p zw9BLvoypvt)ym#glb)d_bfCs{?-dl&at_VgLbr<9EM-D7>3BKI4xt*{#3`Tb9Z_GL zri|rGnl3UEs5AWE&SZx)RAbW&juS)MwhutoQI@ju=;|>-rYe`ZKGR1~pYUZ2%NjQ_ zQ|{EaxMk9xHLNnV*%XTC)A9i03GIFnIknLEX&7I$A}2vNT$4fmQBParNswX35TxH6 zsmuIU&w+h1F;c1DG8~$wpj!GVb0n9nAk(4-bf<9{ELFnB+EwGIZqdog>+Ap4=CHBY zy9lV6$uz1~(J)y6&*u>Q2nNC=fKW5V(yR!lF%F1-F&0|}!z>h&?$0B27GSYQgcnln zT9K8n!Fg}QfvK7946mL9No`MV2=l2XZD? zJZ?Kt=dP6f_^*U9xhBw~`}W6e-?n_wEL(It`vPtW{MmB=3w&sxRo(KvvV|WT7*jEz F{{SPw99jSX diff --git a/venv/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-312.pyc index 4dcc632a57865673e8b0e285b0b3371f6331602c..118c54492fa09841815da12734e52a42df70d4c6 100644 GIT binary patch delta 1774 zcmahJO>Y}TbY^#Fcl{B&shz}jn#5@n6(j1BMkS>UsnRAYC~bvWA<#-yYP{>>u#ThI zwL+qe9I6}=K2%pmG_6pT0|%lORH>K#2QEo5irJ(BL=PNI0~C7V&H5ujAQ)-h_j~i^ z&3p4z@cmBT*G)}s1nZ}dZ>Mg#ulqtLd>Ek{NJT2vky6E2!N7Amm*EvYBPc?KC?q2) zVn$M=jI79*+41`IOTGC_KnXakpa(N8N{d4iy*1OOv|*(28qq>wIPePA#445I7_Wp? zv941kEuzX=yXw*eEu>-H*^paQA+OYaw@x z!zod1S`d}a865LnfA-kxxsWimv*}FQ)ad<9e1h)@LReeOO{t);d0m@~$+QJzw3UH2 z1`ZUDliMT?Wa$1QauDZ}P(5ccEW$njd;50)V+galViV}vr&+8fg#~^xfy+a^ZhDf=sw}eCkx)7o)r-eu{5kj6NC>&6>&+dJlX0K4qFrvL`G@AnGjtMqz%ow(4m})j>+GLtS%h)8P=ZtsqF^;|n2{{)v zSoYBlakvCu<9KUz)!O^w8;q~xvNj}At`G)peIkF8th_WQEFbbiylQClRX?O=#Z3=IUY(lk! zI>V5mnK7x_;7)J9#B3UuvAq<=U|g>b2z>#R1}k8+x~i9K&i~_9bP$Z#Hm(8q8T~Pj zDsGOnf6iABpu49XbZ=yvaTOW)_spLud-r_sT48v8bSu!gY+5Fx=uQkMOn^cQl)JzY%6y@$)L=E55fU6Cz+Xu}^} z_eV?JM;-)A{-HH_=&?Vr=%E8(9P6U2o9L0^O?kQ_GL@c+k3&0XbTXmGlX^OCOr<9$ zHEPg6(d+8Q!D8GMyG)NUpGHcQ9leU2fX=f&lLs?dHK%Js^c<+z4`tW@Dm=z`6YbeV z?(fmq1{!-Rcrf=A)xmEOg!><%f#O})o0nh30URv*S_`?QY=sB9A|g+q(7$x3A~8-z wqJJ@0P?ty6;C`fg+r^}Dbg1tM?*-51V8y}vdR8vpJm=6qkd9vo=$uUd0wOPcoB#j- delta 533 zcmYLDO-LI-6rQ)UyV+#3tCCGj+A1OuSxl%>4^n@Mr-IN@@KD%WaAqa2No2A?Je3v? zdJJ=rir7L=UPSO9;>lY<@LaYOdg!G$sXg`7H>;%&-uK@3eeb=Qx1-0Nd*wJeg7Nuc zKRn6w-SY4?vOU5GgNOvGY7w-wpub$SK~Wl6t!&V5OuR{{9u-<%-~r(p*Lksm+v~uM zyDroe4@%7V=P{EHvkWgYi&I`?z#yb*CbU>~TMsIz)uf?5C)J-xQ4G}jRkx=g> zdNbxiJjS-Gj*pFrn%vD-b5D>wRqCWX%TKsJ1`0d&Epp;N6w}gnHsvR01Pb!f@#hoT zY{%(2q1KLwn8hM$2!E`FR)_T>z9bfr0%rFE!VLw0uVhfx-3rXf75DYj3XuBDFPa1I Z%aC`I)<@NktM6Z={dZ&Jw}D=I`Y(ZCa5n$| diff --git a/venv/Lib/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-312.pyc index 3350bd556aa4bdd534179ed9e224ab58ee2a9d86..12c8cedfd529251d9646e5ac548310c38c38f911 100644 GIT binary patch delta 2925 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 Xn%0)^wY+iM#5rcF*S=2>VY~Z((cm@{ diff --git a/venv/Lib/site-packages/pip/_internal/cli/__pycache__/spinners.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/cli/__pycache__/spinners.cpython-312.pyc index 216a56ceba3aa559b0c12f121cb180e453b82529..0fdb6e30b301bda31f6a61f34bb899397e420fee 100644 GIT binary patch delta 20 acmbPaJIR*&G%qg~0}wp!owt#@T@C;}Y6b`Z delta 20 acmbPaJIR*&G%qg~0}!0pJ!>O(yBq*Ltp*nW diff --git a/venv/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-312.pyc index 0bdb1ef02f849268896d28b5d7f7cf464d1986d1..cec6e8ec83cd30463396d7ae69d53334f7f89a75 100644 GIT binary patch delta 20 acmaFK^pc7DG%qg~0}wp!owt!Yju8MsnFaa) delta 20 acmaFK^pc7DG%qg~0}!0pJ!>O(93uch+y)5% diff --git a/venv/Lib/site-packages/pip/_internal/cli/autocompletion.py b/venv/Lib/site-packages/pip/_internal/cli/autocompletion.py index e5950b9..f3f70ac 100644 --- a/venv/Lib/site-packages/pip/_internal/cli/autocompletion.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/cli/base_command.py b/venv/Lib/site-packages/pip/_internal/cli/base_command.py index db9d5cc..09f8c75 100644 --- a/venv/Lib/site-packages/pip/_internal/cli/base_command.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/cli/cmdoptions.py b/venv/Lib/site-packages/pip/_internal/cli/cmdoptions.py index d05e502..a47f8a3 100644 --- a/venv/Lib/site-packages/pip/_internal/cli/cmdoptions.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/cli/main.py b/venv/Lib/site-packages/pip/_internal/cli/main.py index 7e061f5..563ac79 100644 --- a/venv/Lib/site-packages/pip/_internal/cli/main.py +++ b/venv/Lib/site-packages/pip/_internal/cli/main.py @@ -1,5 +1,6 @@ """Primary application entrypoint. """ + import locale import logging import os diff --git a/venv/Lib/site-packages/pip/_internal/cli/parser.py b/venv/Lib/site-packages/pip/_internal/cli/parser.py index ae554b2..b7d7c1f 100644 --- a/venv/Lib/site-packages/pip/_internal/cli/parser.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/cli/progress_bars.py b/venv/Lib/site-packages/pip/_internal/cli/progress_bars.py index 0ad1403..b842b1b 100644 --- a/venv/Lib/site-packages/pip/_internal/cli/progress_bars.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/cli/req_command.py b/venv/Lib/site-packages/pip/_internal/cli/req_command.py index 6f2f79c..92900f9 100644 --- a/venv/Lib/site-packages/pip/_internal/cli/req_command.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-312.pyc index 6e32b234f5590f8e2d6a848b08433a2d6afea991..af13480f710d80b399e9aeff4ae0450a2c5d2255 100644 GIT binary patch delta 20 acmbOtKSiGVG%qg~0}wp!owt#@lOF&%a|Ocy delta 20 acmbOtKSiGVG%qg~0}!0pJ!>O(CqDo=wgu7v diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-312.pyc index 47ab792c49a23478afb653824e11938ee086c99f..d813e36b528db2564f9bdc6fadeb46a79536f08b 100644 GIT binary patch delta 20 acmaFp{m`5HG%qg~0}wp!owt$unkoQG!3P)s delta 20 acmaFp{m`5HG%qg~0}!0pJ!>QPHB|si1P3Po diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-312.pyc index dbe0f45740e32229ac7af49fb89f2164919f7e9e..5efb8cb80e7263599eaf0a0434c353d1706cb1d1 100644 GIT binary patch delta 513 zcmbOuaEzb#G%qg~0}wp!otHLcBCjOlw2A8e9*hhr3@Pk6yt#Z)e2ffC45q1Ig~oMC&X@!VwGi#lm$wxWGDjpwnzp<@W2QGAfs3dNVG8AWO4k!!pJMx;QE10 zj#YYw*#`z7wL)Y?@=8fCb3^eLkO;&WkO`W?lP|E%n_SE;T@P~SEzb1R5}*9^^wgpv zc@Up12f_i{rUn#2xZoFuO>TZlX-=wLkpWNw6yn7;K;i>4BO~K&2EMxt(svoepE4NT yXR!Rv#LUR_m4kuN=mDoxhxm0)sf(OaGb}E1sx+{DVN+q0o?y=Pl>tbDjRyc>4Q-+T delta 545 zcmX@cKSzM~G%qg~0}!0pJuB_oL|#e8SrgU$eR6rDco`W|7*g1C_;UH9_!$|P7*ZLs z6hJCbL8{6U+vHRxRYuOq z-AvX%_Hm#H=j5+U#>!xagRBW=DB*-y$H0)n0&@^hKhI=u=3Z&`B9LqmNO=(lkhsMT zwY-RX@;hcRHa?I9|70!}7e=AU{w&KC#DN0EkAXx3!yQ$(%c>q1Ig~oMC&b?2&|cwv zg~MVqAFC{5q#RJeN`@kNkZxHJ!3!etbB4FmvhUwYL5 diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-312.pyc index 347fa6faa949b1ca630f7de3270d282cf5c51355..2c550837789b21ff832d8f50dc6c2aa0b6ad3c8d 100644 GIT binary patch delta 20 acmdm`u}g#dG%qg~0}wp!owt!&UjzU@tOd*f delta 20 acmdm`u}g#dG%qg~0}!0pJ!>Pkz6bz6?*-cc diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-312.pyc index 3bfcd5614ce745ef42dbf441325cac63f61330e0..98b242ffbfa7b6da357e6d5535bfcb7bf499fa91 100644 GIT binary patch delta 20 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 diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/hash.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/hash.cpython-312.pyc index 770169597aec38900e9516820d9250733ea6cd8a..6292d7caff31895b49fea931090a6826220cb3b1 100644 GIT binary patch delta 20 acmbO!K2x0gG%qg~0}wp!owt#@j~f6v7X`im delta 20 acmbO!K2x0gG%qg~0}!0pJ!>O(A2$FwS_RDj diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/help.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/help.cpython-312.pyc index 61424167313bd7090cc31ee6de0f3409e818809d..eab8c48e5db656c07b98ed8e7595ece8da7c72e3 100644 GIT binary patch delta 20 acmey(^P7kJG%qg~0}wp!owt#@fDHge)&@xc delta 20 acmey(^P7kJG%qg~0}!0pJ!>O(0UH2D83tGY diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/index.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/index.cpython-312.pyc index 5dcb4462377a1256bdff773eeb22bfba4bf3b4bb..720c9c519e3752bed8df55a6423117d6bdfbd83e 100644 GIT binary patch delta 1113 zcmY*Y&ubJ(6t0??bY?QsGu<;ilWwEq#Er>xBKcu5ftyd9=b@=*w->X;k-q+pt zr>;+#PffE2srBaOALo~EnI1N74UJvFsEL{hmgFgt(!7iH@H9zlZmI2C;n9(T*7|-UkGM= z92q~?*&+@6L=->JUW$@OLMrO#7>(p9oQwH*fe26a?K0D(g#B6_1Ltk}XO*yNridZf0-9@VNBsnx%W%aEd%_U&d9rW}n#7 zr^?=K>e8bN$KLS zf*_`#QqdiVqw+=maefSH>?qD?TV!EhO8!}>8V7-v$20ygt;78PTX_1O00i&s!R=Y`s7?mfSngMo*3Hhs2!-wP}Cv?Gve`ND0VHD7cNpFmQdl3(S>oN_W#*gxDXFzxPhb)!vGiRAFQa>G(o3)pg+Fy_l zTnpRsnOntq`NWmJqs7r0p&UEc50r6$2#-#%Dj`%^G@A3Km*|0ME@uE q@lJD*(fuM+3HZB$IR)?H7~_{H`wI2FM&qk!{BJZN-+I#tsQdzNqw}Ny delta 1134 zcmY*X&u<$=6yEWVjqT0aYkOm_lQy-RsPUTANpYfpRH_z4OHm4kwrM-4Dy}_^T+MjH z+YL%i<$$KE?SlP_ZRZTN?)~t^wXe498p&_X%-s+fnjuEt=%;vAl=!sA3J&5ne}lLqRyApuW4H zCI7HLC$rl@{?i0`Sw43b9o@>FVtKr{L0aHWF4RF0aQJqWL?0RzTaH)MVS@Mpkj1z|!#y$&rDmgRS)yQL$F`o%cO z*$^C*ExA>0nr|Yl%b&`%_t0XT3|Rz46kpj5BLEMXc`X3ZjbI7)3JQE{&mi=$aS(C( zgLMX*faX-qVAy8>^RnYEn!1^e9J-6-l)ULi6|~oR^&QYifDPG-3vHpy(j=E%bQ-4xbnW&B4ct#@rufux`^$^-r8WTeMMPfpk8=;JsR+^ zEe2t4cj(zw7A*&>t7?Xqv8@FJZGjbT&^IqKrcQsuOzi7FEK|iIVV#uDX}m~262fnI!OUP)?EUSf`3a!#gRQEK7jK)&yc JhLb({4FLwP5|sb| diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-312.pyc index 366c0d015d3c6ff8dd4a7d59f5d5569a52459b6f..a54e981069c08f12ea511bdbac28e276a2756f9b 100644 GIT binary patch delta 1985 zcmY*aU2qfE6~1RzD@!&O`n4=uKdWC$vMp?58vF|`*h$Ew$>5|jtZW$JUBF^jve(N{ zr>g>!l1W;aVoqAhWSXXZNf^5mrrT+Ur?yXInwf-zc1j>jLU`y)A6(*29+GK$uN*nk z`*7}e&iT%{=NuhL4zY09FjZA8kSmo_)#I@scc#anI=wRddrJ-Pi%(^bcW*O6sZNxpf1P} znW)3Hb|*2G8!={ZEsD?W*mFEI#~mkg-0XHjY9ZsymOr!#n^@<}&h z=rCO}f1H?2Yq3>f(>lY^ES-g~Shu8OChiq?1-wi<(e= z8O3ft{-`hFjF~arW0LYk^c?WDL>g7pqWE545JX(awc%HN5szrBH1eAfv&jTpbo%jn zzkvJt{gl_24dG(Hza_cq*yPpXc&T4Wry8}^62_IS42i9Gl4iVo6<1t7>>Y@v(+&Gt zrh$MQC$*Fr-%n=u({9sd8W#ovO&R(bB+I{IRqxv3*1F8Da~?DE8j;;*SNYeC_rAGb zBfsEl88cOWlSKx%B7t0(vJo?SE${!qwXRh$}fS9z6KW!C`T#G_NYMXjH|cr{+~z zoUbeyB~>jQRTc5{2}Mzt#A8)mT&ik{xUjsSSIf$rQ822SDjqE@(a5h&OJer>wH*Fs z=qgw!58sN>T_<{hiG57$W@3nmX(pmLJu*r+=+elm;K%f+Nc*1}Jqtd(IXdREFI9Cz zk@X~_zQTkHN5_(d_`>``;mCZ&Q1nVkEi5VOu_M(}hFqfLBXcK|xs!JtPbtfjx?a`w zIF`pc!HqAC9fBZ!I+g@4+QwI*6|av+>!Ai**_*~U_BP?~ z_a>p=y1O^a!3m4s_afk{`w!5_PxhxAANjpVqYJqqJ*9$%!t zz3&ZXi!T2C@I+_^$gRgb#ZK~pV~pYt1%I*E_F-r;MU}sgr-}pIoy0^NRqnZjVtdm) zpM&AfmSUd2m*E-C0mJ#aeZW~97w(O4%svJTk2B84;G7NeA2&~MvtIsw^ERN`eXlSZ zwBCH;iU3J#&v)!#kFoK4tf!vo1#no)&;E&nHXNRoVBGrYbX9-@mT>4Az&3na>TPLf zWIGc9{D<^JugMF+pMPteu=_3lTXWY!oA~;*USvIIY~4$G?obYOG&1-NaUFFQEAtj6uF zjN-x@YSdm2apQe8LX&@~hUp%(YX!THGVb=^87+j0=BHcuf|iN~SXdkLc>aIabY)Qw zVoCMk`R&k&<^U|+?L|IwQ49ZZeZ)mWtk!q{DjLj<3$L~T*(!gA#^cme!POmv{-Hf^dN1w1?F^r_Z`h}tkiQk^+8_+9KWBYb1^6F- C3Hnk1 delta 2071 zcmY*aYit`;7QT1WhYilx)8jWx;3c`?ePe7)$C{G4CvyeUN(zIK| zl+?@hn%ph+N&Q^EG{E%_m_n&lY7J=X_y-}d7C&QjdG(VZx?~b2l1$}fgixV zmd(~b@{g?u3NP_RZCaM3Y%#y-SkVwtXOJF%j-gpwFpnxBcz9^nzOWuv+&U^eUyItA^9qtP+7zssp|q z3N=Tx(=}BO>JE5o*b4*0J{*Ceq#rWFZ4F)Pbz2@47M>jDyJNN8SEAb4?bzt{GrM%Q z@CuxEc_1(nUW?cCjqV!5Xc<*vIy-|FXUO}<^?2dUTArP`(oMcpSK-`_Qe*mdrb@}L#zq2pbogco+)YfKNF8IA5s ztds9U2Wex{OLDl z8uPX%A6+07NNInoWz~~u8h@_*v+wstyfQNq~L#J0dMljLWZas_c@iuuoL_ zi7DhBVFi^{wvJ<-)nryEs#;bQ*;2Wr$OS&9r8QX+2aaS_KF|Itsc>=cEBIZQyYot< zg=}0&Q<$c(hr(V8a}*+QV0;2cVQu^++zxFMEbfF|6Hnnb`1{198lP8UG~aU+n!!F9>#4hsFV8B9tSDVnJVapAel#nt z@T!ueN)H7$sFR0D#V=3Bum^5Vu45OxaaYLRNETClaOtjZ;QYR;);?mw@%>5o>;443 z!??UZ$zb02@xTe}s@jp8{k&!RYRmLzEwfObxfeU&Uo&y2&ItC2FDDLMJP4WDc06gU z%wi@!ZN=?>!Z#7cU%pSGw%{#Z{i7I^j0V{1nM*m%#T{G4_YW6 z!IY1h`gr|at7TQ=B_#x&VibqT-aO6~O%TJ7#`B6kKpl?rfeWH^G(mp6?MQ)%%T)WQ_k0 DJCO@~ diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-312.pyc index fdbaeb963af572631e13ed15a98cc5062fb12fd2..119e0322dc7b90f7974a82d6d99bc64e8f0bffd9 100644 GIT binary patch delta 2650 zcmZ`*eQZ^Of9*bp zgpf2$VjAg0Cv>&KHi^MTDF`aH^@j2vm8x!ckis%+XHtBhFJYLm8|^J0_I zYR`JVd++a@d+vGXoO`c-Hv8-``%Rmzj==NLsdEz_Z8~lD&}U9}p0Q+oaUUfTkt~_h zzYi>CTjQ;i$Og6nD0`+Y+a7P%#Ewij+Y#@eL?BNP$$5fE^|JS>4lNQAkH}^@;>BL4 zKx8^OrqPdp9KA}{i1Gms@I*byBljCmZ3{gC_B<^(O=zO^A}` zgg)LYd8L|u4{$!Yz2uOBsR$*IjdHj zz|{k1{{q(loZ}0eLc*kTk4Iz&TNB0?wtyw(5fBhG*R&P0I^fjVH-0 zjl0K5)L*I>FPf;GU$_5)ZYmvcbPB?#O4eU@G?i z>@9(&5&`(^ICw@H`KlGen}2kRe&Rpo2|CC0$0y>K62r%POLY~i`R@b2_(+MV+~LF8CrrGx9v&i zrgr2r897zVGv)!7A8Qz=M*hZdh>r2U40k<_&Z}aI$q;y$tQMV-cHM=oga83E8gDQ-rmcHmS=8xd*9}hE}yYd zN1Wl43#BF3e{}}-BuwEyYTiv>;qNvVn%Hg_v#%r6BMc(gx$J56;Ko!<@@y(IEy;>1 zP8YCVn2VqD@Mb3nqvGd$j^jj$Kk3~a68;G4WZ5aXLS-1rKru_Fja0Tj$<2p*^|pz;87p3fK8A-R~SRq%UYWDh-7S_tf- z7KZv*s%(zG8H~~_|1{W2@0GkQXDOX4y&8IlTE36sZz0U`(`^Uo9Iv!3(+B)Y`^Tf- zMjFGc>axi~Ei3C*wbYzJr8xvFw`x|t3+`@T^LK`q!`<}nC3DAh!GT{Er3@E^W{&@{ zb1(JqK-crmW}s9POU@*6$*c^{yxtWVe7KaVhj1rV@vxkP15{g15n%=_1JBw*1sKn@ z@$=nn)Wsi*z9(J+g1uPsZ)~FU93SZ3?|vE=p|c8BXl+`8|GfKgI>_&KZw@q}TtAsl z=NS4^%judS-rv(pFYtpseYA@|*YnyUZgZx^2wh=eoUBXdicG;_4gr(JvIqu*83go` zT>wyR)dM6YXEKQd1mr1T6}+*kv5TTALIec^Ao=VB-VO#6+z$Lkue)C`YK-8vrrloIfj^^#Ux^^f$I)}ZEv$p`K25CB5P@qyC)+)OcLn&?vRiDmH2VyR4; z*^zJg5+B3A8?%Yj+9kvs{F&h}b@B@%E-Rd5a-j&9h{Ec*V`PKafbO{Xrjd=bksluk zQ8(xXowy^ky}%A&&&$6v(r(f2oeelH^7|tZ@jP~4;DK#{Z`_407O-*?prWIc-XWGd z#9k);dt~1V*>{`lTP4F~vT2ocmC0AjWB~g2$j&m^1^s(u+lM-5S--uk-^x#J>vxRl TY4BD<`#%VFDii#7+s6L~02h$H delta 2327 zcmZWqZERcB89vAN+VMyHl{il9)QRO4O&iNZe(c}&zBh4O z;97p}InVo?_q_Lg-+S)4)5|A4zjeEv1g`h4FVFmVXvxz;&n+b`x+r0UxpLurYkKL| zkwtUr$+hP@(jDg5o9oPXrMvRo>26B6RRlrq%f<7Fbb=BKIYgNMEMX12bxlFR0oKHVteGpUg*$m2{F3Mr|F!Xq z1!prh7CNh@2U+;GJ_%eaa6?Z~ZHIh~&dHc16{CjxaJDeFznIJM>2gtMKpf3X&t+!$ zc(%Z}Ok3`AIge&b6I|D`#e#g^qBVl3@jzBDi|q0FGLVy8R6ergDGkd9)rFR32taQF z_%8X6MRn9~)RR#EhxR`Cu^M0e82F2XlQd-{ZDBO6FiToxO4`brnGNEzF?cR!=XR!Y z2gK|E&S`Q^?&9_MbYO9V#RV1*t7mT0sxss}zGdV206Dn}JVM1wqyHlvQgnT!$e&`-}N}roc{>oiVtOiDfHM z+c`UR%T><`9j-j!O;{X8oxYvhHyVPz@0lr4k0{*a2P2wvz~+#e+mt}9~!tad+o`ap+nDj zHf^MJa6J@V@6cZDd%17ZshWw)v7N3&?xJve^qd&30GdM{(h!@*m+* z`eLQMl~d^a@9lWqJ^}oyVua=ScvwzGfZ4D0J;i*l@tl2 z9tSwpa#x*`v%EZ23;GY>AbFuJO3RhDwu96)hfB;v>arNq=#0D+Yp3g#>#^r4)how3 zZc^7N)Eq%LA$N6slj`z9*ERZ2`B3+#{}4=y;~udFsl5EN#& z3Nu9*iReNHO14lIIh@WSV7bH$0=BLwA!HGj5xNoL2nhtO1~}8B@G_poqs(fDqpY>< zhT6Pgq3+O`gP+;t(}Q&pzty?k9NAFt-ZO08|KbRKW`+4iT)s6}ZQitctkJCv(6^zM z=4N$~msf^5Eq0~yyPQt4!|s30*vi>JtbT5#C0?oy5-(A_!50cL6l_-9aI126{*S7;>Lq zBi=!76u_{u`Fu%-mbu-pVkL=Id@T$$TbL=D+kB~IUqTVWl)U!Un{=oA!98|4g>I1!u24e7T?F;nK2Dv=8 z!`6tK1>`$py|hV=raEa*{(US)o25M!bz%FPjc>Hdm9d~dc|4WxJq_b$(|}neL@aY$-yew4df?e?3UuIs{7=B XQ$yabsWf_{p>vbqU}IA5**o!n^c6SI diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-312.pyc index 48abbcb472bb59566b262440ae586535bbf6606c..a9e5c980cc70e289bf80d41304d681d7fe5ca0dc 100644 GIT binary patch delta 1202 zcmZ9LUuYaf9LHzw&*t{__V)hl-ED5~a=Bd2B<5e$P=aUMfCh@{< zdd!_|S{hO`LVb`L=D|p?_~1jKsBQ0|dAyX0LSHU4(vl-62vX>Sha4#CgEL#J;J|$6 zGxPg5Gdp`L_vm^5U0L=5)_(fv%G_U(HNOULuJxQ+u@pmr00HDS16I%o*({i0OEpxR z+sud+HKI0q%$TJan$>Q!+jG&3Te_j!>@^cs(n#7YnH^TjNZIT&JFT>lwplj2tc;Pd z*>84RStFc<082!2fC+$^~ zJhA*YZUE$>2c@WI1AOLM7Aq0DB#pu(y&)xq^Nu&YeKKuIIt)>tZ;+1rG*;U1T^0%~ zLwS?_;>)iHV()`+?33JD?y7q;yPX=Vb>9n5Tq?ADAP`^g{=&7RWb2-6UCBOB!k47q zTQUelFE4+%d|&C>R=R!#F0uE=(C~HlE#-z%A0DeYYcJj}oY*d$s2`rJ2TnGfKvr7< z2&dN1-V62AeLa6RMHcf%S!0{nib|335wJCq%pY*x4))|nowrBb`2+N>d=aMU%l<<> zid$VTd>;Pvr6yo_U9gAEk(#S^?7K|u^)3H)?v)l$syF?U4tSJ`!GY8p{CEPBPP>sb zLo)hACacGTUpn&qHg^N_xH653=8&5z~?jV2c4aNN&jnu{I9Pt8K3+H3HGYEiob zpDOc}Stfmu@E2BwOgbNLdWze)T%*V0`y*!%>0B|hdLB5lMo z0{^4QEIq2nsIJRUqJ4S>`q;c%kh#fE&*~kA6rLtpDwc+(i;ERZ7H7;M3s+{)Ol5}H z_Y(h~@if9_d8oLE@Dd5q9leV^so(T84Ab^R2Yn&&Ou)W}lf1@3E>mq=Ze-Fm#w}~`;l;~2Ph3dx>_2j-5VANcoiR8xL DB04Ma delta 1254 zcmZ8fO>7%Q7@hI@XYI9jZLjTh)^@yc;wC0dTD2iX4N6JV5;&CqqG(fOT+g_2*tMfw z2O5eAph%Qc8x4X`4shr#R3P~P0wE<(qzZ)Os7Q${wKq-(6qOtx6@r-!1;I%3=FR)Q zZ)U!y`RVAVW8!zAPyo&n!ZK0P+};8P+2X_Zm@C)@6tLjF=hM z;|}MIgsJF?nbecc-fwi7s;)XbV5H2no_4rkWXx{8+u=bYYihdY@Q~4C=JcGyMWfg3 z)B7O6DZz@+2S`T1%El7^}EZV#%%VM+zQ9Njl>QR=lW-YD0eD2Pn(x_i~YnMLg`(r~Y9qpGWB> zkA47UlJu&4lclgMs7n5y2+m~PY$>~4i;d?|IET1MklJ})-6{S!midI z+{-Q)Cg;5v7FxHx-#{pmtNe^NL|P z(&Q008zHazWR9PWvbC3=jor)pcm2q{>e|~i{SAdo3lG2{vMglAFO=&DH=he!up3sj zcCJ})b=*wqc=v>YXzing9r+w?6cMhJ=8Z3qxLSrEZxea#v94^Ao{K z-jlSz{*tT)k3%2%C74_kL0DbsyXyWy%D4G^Tgq=q@KQ$l)D2w z{(-H;!<&gy8;Mg}arNEea&b#ZZz=;D%D}b(red+_{0cUAIVJe+*gr9lN|Ro=W$K)*B`P<2xYSs*2CL;1gsmydRz+KZi4Lx+O%expES-Bkb5wWgeZK zZ!j;SRJP7AkV!|*!ZO*F$2_xCXta*TMmSg`btQXDW*JQFL{HbM%;}Rg2Q8~^6$ER7 z#b01B%HS*mg#qi%DwFS(r{J3{EqNX8dyy#>3I%AfuVF(9n$^SP;yt)V0_rGSAQP$# zA0emJhsYIG^ZHr1Le|ti7$85Yy-=WBAzCVQJjg=q19p;g)w$tfwbsB^tz-=2^JP58 zTD2{ag%ke`o48RzrAEn;NIj*|Uwt{1gAvk7_4G1p{(l-Z&9H~fs$I62CFD-(&=F>f zr85|3;PjAXOk=?M+T|ZK>uBD<W3RzrAQamWu(4BYY$FFZN@GHu#dmDh?8D4m zW9;r~Bb6#{AT4B+LWPtV^+$+E5t91@HByBIQK$kE#!+oO)F5)ITaxwVk=k z`c)Wd&z||tH)m$f%sF=+b$MK(Fe9Rs9^m!oA00f5XnVZ!O6<>yVq_0E+_5w*b2_zG;UFM#k zJ{2`n)PjslXsOg{MFvz>Oj(i*X;G;JB{;~j{-9Q}pVao1OAe$%r7FXTDkK;E*-*ux zQ4*=uKMuo1qyhH0oE?edkyunZfR2quF^Z!^YWl}e;-GK(Z`xB3TF7yIxYSJ@;~FNc zRD^Zd&-4%zRpcXmxi3Ifg~OwX30v=xkrH}QbZS4HYAWnpvLJWN-%wn_Yl zLg6-LER?Q*~!ov3qZ-2@- z=kiQXwYyf>8w;+SnWA)&Bp#)gScaz$(IqXJvKgAa38)3B9fjGX+9;5UXbg82kmY{@ zB{#L~T1E;QwRotdxzJz!KLKS8tq4}i@KVN}Wee3_QhU@?oEE4oNt>wjQCiz7T7gwc zE#Lir%Ze$=*fEl3o0wfbH|nzD87Jpoju&N#X(yF|w1djZXN(B08WDO1t4iuvx)Rjc zx@XX;S2?RmTPQc2wh{PK_;Yv;LYj!DYspPp<2KFd_AzjRdj*Wa0UA!0N@E}hQvO0T zLIBsn)hQY*TmbXhtjjKEm+%Ukq^aP1jY|VPIl~alm{ivK6)aW})kY`QLofs~7L`+6 z;QWdkgW>fPUkiTP_C``i5cW$b6^X`V|8%?E0HHYD3Y7$Ft#T}7fX)O4X{tU zQlw6YBV+v%8bJvOB?h8MR(OmeQhy4aNGSpf49U1RXIZi;h9Q(<%TqY2C^|K2ig6$! zqrqfMQVbZ4#3BQTTIk|O)Q^#3Wd0M8I8sbZJC3kS_k^EkD`K?-w=lsfL)e4ar%K^a z;y8Ypq3ViF$3_t*T93Q*Rb~}fcRcTr!{`{^&6v$(v&WNVQB{P&Xbj2yY;XApv!&mfKp{HWrQ$6dczGS(I=R8f5<^`AU+|IK* zr%aa)%(?0(jrVPyoB+I`N5EhyIm0akLhlz}EWWh$nq#VXF0kXQ^$dT0>qD_@UR*aT zuA38U=EeG1vHq&->ft%Dab9eh6 zDk|R_|Hb%)AD(HyFBa!)bf!fou=ySVr%hOJ6rC%3yDZ01{h{cc7en{N5YZREW&6er z+~qkB#lP`_l6B-a#Xry@*ak^SNvQMRkIcZa`(KNCV6S`xU_PklrTOxP+46?D@}`^I zC;SZmnP=ar_8iB|-!2MIsKEta;C#)gPKF1+T{M%H5;6NRJ-Z*3b=Scuv9nhDYXj9j za&~Ug&RE=3oe7#dpA%;4wM;(OVx`axPS@F_xxst7Y?>Q>SC=5%*vj;qra-q*bF(hk z?bCd0-&0Siw_s}{{rj|u?=t9aa~#!g>mkz(sxIidUbAU#+qQJ;baxui-C3vVVaW7arYn|}HABYirG#sy|6FoO2fNA7{8zFLh7<}L zP-|Ge*s;>3mMpbMtw_xnGvxD&X)HBgazkBvLyNoh2OcHs+@&AuPe8%1FM~xzp_SU z2Q#sT2#{nadsxq+GL`9sgoX*d>^iScHOg*gU{Q_YVKLbYKPQV#m}MV$n`UX!F9zu0 zrJvBWM59Y~!wZz!#T8?+F#th$0>J^0H1KAWTM^pC9b*%Xi!Y54xNEe5hB4Qnq=|PSWgEgn2s_1AYjfmb z6xYM_qKeQh#;wo0HHT)yeT5nP#~LyA7zp{ETQu5EQ@5DcaLxAe4)+9=4d?A;Q%OHS zUZkhqAf#-zkng)oX565%PPM>88?x~{De0yfM1M=Pdw^WMXI6vv1TxiFm)4(eny%_< zTG=ADIa)XWe~#6HDVoI@N6cU=*`_v$*Bs4~y`&R+S{e_P9VN#(Nw$@pIotZYN{)J^ zl%4SMmi6Rysq9jdby?o5K*a#>0a0)TTn;r<_kis|@s{L!DQ+?gDr2lp@efzT;sVVL z+BST{<0)A{_m-@HKCo^_tHBRaH?rrD9Voe`@Ql7OuapY zeOS>AtcH5VxsB1}#tkWB_X*atAz1T$Sn&<4P5+aXAactFT5HJ;Yi%nz1^oeigg>Xz_?x?TC%y2S8FEHCNoHs(QL%2d(MGtDl1WmwpG5A-I_Ia-3{7rX`oa^V)VCD& zacaa%hxdsW{V~@lh($d>JRU#Cp3D+$BJ@y_@;;zLmp=)Qip1G- zMGO>=*V_98$Y&Gc1AmjS1uUl~K`r_L{z^VSM?Q=WE=pH+yx#M}o|Wj}zqFZuCm5zl zT9Hn(*|TnzQ~B&zA+O}rVyAjWeH=XI(~K2ZPA(qOGV@0u8s7y_5pM*W=PK66GU;Mb znNS$#kD=LgbUK?&^I1Ls+F8qBKFc}^=}E@-qi#FQ^HXeG?RfIY2!9;;#{Oyb**xb5 z&~2|N9W0wxGJFvIrV(YF<%*0CfyT895eq#T<1RwP)=>1|5p>|ORE)(uSD9Rq&MF1o zj%Mt_ihc@~#GR-c5q6@{e2~rV=NvL0Mb(hW&oD0D3hf&`h8%2@ikYWp#&YQ_TVFPR z6uo;9`jKLqWa?Ntlc`7`Bt0B2z>36j-{!}W(HKkn^g*4DS7~);x>%Ewex=f<09bJ6@LY#@i`p5*d2Lu zG-e|23wg0281FO-&55|A5+)!41C+5w6 z4mPgDx_^G`qgdZ{>9>|;%W80V-d5F%(de=GC(h_y;&oYXdjgkZFU6`7$e;K_SM;yj zU$w9LH;WSu7ZcSW2{v7R`qI-2TNn9iV0$$LtZJA?E0N@4$2IS2WS3ZL_?E6K zDULU`&Ha1LOWd385^8C>-4J_Wq$+{*WpM_U^xfESlrH#(+V#IMf%J}ds6)T(2!goW zY9HEeUEZcg?Cy7h={?CX)T4XP-0uP9dbD-eth@f`z$2jC=&=kN3^%C+@=ZNO*`Ud0 z+i)mpxarfBARP`FZiY~2dLDTdymQjIDLJxb&B{zfG+9J z2^N$>=NQ}ojOWss&MZ^Ya#~H-y2mAMB$~9PRxD8NBl$__>)Ho{)@|C?1$K_sVp<_q z^v~q;nc94?Z`VH}zA*2~=H=-O+s!Y61MkM-0stI0rGFyMJEY-bGIEQId`fyhCEGtH zy`bJ94+*8cBe9QC>ws;xo-w9oC6ows+`TAn1Pq DJ*hNw diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-312.pyc index 25b96333061d393e94df502d551e14ddc88614db..9c98ab398a537209cb060637e88868fdbbfc7dd6 100644 GIT binary patch delta 333 zcmaE%@?M4aG%qg~0}wp!otI`ZkvG?#ks*a4g(HVImoJJB%;wDD&lQLg0JFJr1apO= zgura>9N}D%D3M&zC{Zw!jP5d+-DNQN&cw{f^qqr+k?A7?kodqe*+EDH03-ibApigX delta 368 zcmaE_@2DQKGqGQDR^|PtL@hleC#`2?wVZ7iZ?@Ip^o*Cg!F1W>#e8-4ZTO zEXs?|Op7ln&5KVgjxWm3FPWUkSjxyW`8uP^W&@^6tc)6)nK^#5F!E0R&toFR19Vpr zABf-v5lSF}A4CXD_T@EU;{-9eCb#qUF*lLa7tCSAhSR(J~OW*wJ0w! zM=v=iQ?DqsFg_XLmLd+2HqOZkf+`jupWl)|Ri0XroLW!Xz%|)jNCN=n Cpl7TA diff --git a/venv/Lib/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-312.pyc index 2902f6f33226cd6e785ff9c7a1496e4e762d2cc0..d85ce765e3dfbee2fd8b654071feff143659d677 100644 GIT binary patch delta 373 zcmaFoI@gu=G%qg~0}wp!otMV9k$06aW5ebh!j;TICFUSu5UAm);izHEvY5P3L}YTj zxY*=gaqh`g;?k2hi_1&eLDV3VMPfC)S$2~zvI|fCCoVJjlDP0>T?tNZXPBBSm&uM2 zqG0h%2~|e_$^8=2_JJ_j6zoPLV+N>bEf^qT{x!+>CTAmh6CoMR=Y*|k+8hKf; zp0Z%|vYq@?K8~?yvWtSPh94uV_zbfT3?O=i$cp5Zk`VTW;!j|)&&&*LLLZs@Ca+YG xV@%q7LSYJ{Krzr6MX4Y{1VmI#&QX$J?3~=H6fP9U#3+72SoJFdh*1OzD*%BUR@(po delta 462 zcmbR1`p%X2G%qg~0}!0pJuA&;Bkw9<#s!;q2v;(*)Np5+Pj+OJ5@BR0u>`3Aff}9~ zjvB@+tH}#RL|A|fo5|7QvXeK73s24!=a@WMTwc-vtPX`J6070Oa+rLPU3l_6aT!LZ z$@j%2_&6C#Tw$uR+$JkZhyo=J3X4qkmQZF4oSZKqZ66GiPvKt82w^udmW04WgBg?= zN<3gZ6^0_4T7eQT7(dH*@IH90da6DYKKt+Xy9; z-(t2}UK~uPI5@p|Sx*TXd2_Iy=3w>aojgT8j diff --git a/venv/Lib/site-packages/pip/_internal/commands/check.py b/venv/Lib/site-packages/pip/_internal/commands/check.py index 5efd0a3..584df9f 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/check.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/debug.py b/venv/Lib/site-packages/pip/_internal/commands/debug.py index 7e5271c..567ca96 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/debug.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/download.py b/venv/Lib/site-packages/pip/_internal/commands/download.py index 54247a7..917bbb9 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/download.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/index.py b/venv/Lib/site-packages/pip/_internal/commands/index.py index f55e9e4..2e2661b 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/index.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/inspect.py b/venv/Lib/site-packages/pip/_internal/commands/inspect.py index 27c8fa3..e810c13 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/inspect.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/install.py b/venv/Lib/site-packages/pip/_internal/commands/install.py index e944bb9..d5b06c8 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/install.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/list.py b/venv/Lib/site-packages/pip/_internal/commands/list.py index e551dda..82fc46a 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/list.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/search.py b/venv/Lib/site-packages/pip/_internal/commands/search.py index 03ed925..e0d329d 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/search.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/show.py b/venv/Lib/site-packages/pip/_internal/commands/show.py index 3f10701..c54d548 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/show.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/uninstall.py b/venv/Lib/site-packages/pip/_internal/commands/uninstall.py index f198fc3..bc0edea 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/uninstall.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/commands/wheel.py b/venv/Lib/site-packages/pip/_internal/commands/wheel.py index ed578aa..278719f 100644 --- a/venv/Lib/site-packages/pip/_internal/commands/wheel.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-312.pyc index 74aebd0612a5d534a3170331b25bd3db8fef3e01..ecafdd96dd85262c029c4531d1e9f76a3324c063 100644 GIT binary patch delta 20 acmbQwKA)ZYG%qg~0}wp!owt#D3NrvVzXhlO delta 20 acmbQwKA)ZYG%qg~0}!0pJ!>QP6lMT80tL4K diff --git a/venv/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-312.pyc index cf940103dd39ab87ebf91aca8cc00774ed23fa74..cb43ff4da3591622f9b85c78fcabf7fddbd3c8d9 100644 GIT binary patch delta 744 zcmY*W&ubG=5Pole?I>+K3M9w=>_o`DW(5jqKa3{!Z65 z1orvy)5d;ZKYG6d!4u>n7ZYT$KS!|7S)9*XJZ3RZ1Yfko*cXW8%a)9h$59D#B2j$R zQZeGtJaVNq)Nea0-dwZgdbGd$>Wr(pnrFBP_;^=nC~k61*gWWFrPk41Y^4{G zsc*f(Q@p{JHTg&gJkp?AxG%JDDr|@ad}8aNIERyI$Ojl;j1Gm{(oC+v2pyn@_L3-7 z_+X5`SH|gZI4MtO8BY&0IKqw%>Q?3IsS+a+06p}@I60_-IFcIi>{Nyz{3b6={#7vr z%KFn02FDrX0RjPF42%we6XnC6ln>XH>HGvs9*k!EGaArlCj6+JgVl6(#AfvoA9N|r zG0$*n;5+rM?{#msT`B@ekFktUYqtpaj;-6O=dO-wVu#tW9?F{sL_7$m|+ z>ODLfYT86;ctFBSsUYvf8fKCfArVR4)lRduLfOlQ543Vv*NQcE3z2;BQso*Pj|E>K z8tbraeS06%z)@ix*vq0(1$eg{qM^64F+yeE}#abxlM^0Vci I2;5lcH=S=ojYj#tkvq_naU<-vF zdhlqNgWxHmAmT+Ro{ID;c(CAYB{w~I6R9Ged^3mA2m9^!-ka}x`(_VI=)LMm)k$WO~o;x>M5z3M6}CH?r44N@EvUy&+L!2Wt_`H zKfwT1R^Y$%7OwIIqlAn6P+Od4IcTsm0!pXPJvCNp4N=Gf?4oZ@?Tb@CB6U`TJk`7M zbGb_HE}R&6DifpFSpgLRGXRMSP=#OxAgRj_h|6D*OYQ~Hv;lU}v4irnr~JJl|4kNQ z3(u@%6(LiSA!E~g)hsWSA!ougRqqW3l${gQZnrx$NRm!OX}j%VHU(9=^pc#*h)@YI z`Ac&LyS!#yJTG>UMfeeB91R2M;bmDJ8mT_q+U)f=n8M#%4Zdw%^^I%SZ`_7sQu7AM zyO8$(NGl$Mk7#s-H9;yaJDCIcsbGx1B5Q&w-%)FVE>BSNSf9spO(HyZ#qbp@*c diff --git a/venv/Lib/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-312.pyc index 66fc8ce7ef601ca46649ea4686bd2b14b788118b..5b891309a85efedecaffeb001c4fee4229baaa5a 100644 GIT binary patch delta 1491 zcmZ{kU1%It6oBW>&d$!y?q+v0o84@(*^T*~tkzUR3AV9m(j*3B8Z`>8)|m9(4O?e- z>z$2K1>-{$K?KVwDn2OsAVN{W1@%FMqCSX4P!VAyrbVjwP)ul_q@efARzn^fm~YNG zbI&<<&N+A9m^eET`6d!EBys)v@|&flGm&=k!I^=c^@>_li9{tDa6%QWsQI$u=oO=A z_;S!OE8$|;msKZHi58>29CBJJv0{u!Oy;Wa*PM7IQA`j?mY8(1A2aQ}n01acEybiP z%}7+=km#VnjB|k-=C;$sHvd3n-VS<^#fKKAmL~6-n!I~!&GJwrnZadC7FhWCA!BF z5tbIQHY%Pm+QL*CV{w*XDpN}`dg1NIRcTzTX{8DA-jC;76{@!ivvpdxlZ~=mlt~J{ zR9@;x2sck#W%VUmcI!MTR2S=z=P5WDoFiHIB-jaTpeSrdI<^u=~F^Eg8a@DOb zJI)ekPpp+WtFUU_4CbkPty*Q=3$2L0u_|@3-+mnUC_YD)8-K?Oa`<(o%m249 z{qTFLpt{1>eH+s0Lg4$@2+XFR5^Xu3{(^|Hcs?^tUV#gl*|7z&$}=f*Pw?`odbw5= zbFY?ays}*9enIZQeT*US?EbqMbmRBJeH}NOelKvhPxrtx*$jM`(a8(&e#eSGnS2;_ zjCR=9dFA2z(O>38bj5z!A^r%;yJ-%hdI+(bP-%WWI`HF&M+IC(Ks4~iBoyGuY=OK6 z?_?L#I0?4W99A4-9ut_ilW;vdx{ed%1;ioXX?$fOI?<-A)M^gjk9scx<2O6v_Xd9^ zTt$Qses2mWJ%GTJ&5>+D34ux73j!O`j;sW=?XaXqx8c*STSyLm>*@(yofo5;>yxiq za4a`v`XSKKPQhEk%tLTKmn9l(<@$*ZYQ78Z$W=W45~jPu8Y&PNe` z_Psm$OFLAl(KUzN$xn$Tc&h3%-_ zYOA(7Em1UWFRyAv&?jcKo9N&r-lmJ9IetYew60v1iV}~*J^B4KU9_gn*wt~X(iI&AQbI#~By)+jie7j=l;#B} zg%0%Zl6j&16gq(5DhPR6f=ERt!a@N)iN)YSD9%So!h9QkP&05WvB~q$-?mRXi~$8hnDBDjQ!hP@ia13; zg%Q031%e|81x5T@hng`tUvey}m@EFb99@BiX0kj|~14ISS7v z-@@{Io&1JlHQr5)@(Ixb_L5*+ri3r670`HDq8A7BI&~|@E zSYqpvtY{7RDtm}$U^ClkHqP**61sV@!SHdry1^io>xwjDrefTDq`~lU`xF|7b0YyS zGv&fdEa$r5PA-Mh^-HdsYp|8eavfgJ_d+^<`jUn~V4V%u+0i;1si4FLBuB02x0a#xSNx?h+Ly0 z*NMe4g;xFpmg(#TL5tKYVj)57A{YcK=dG0w-Z$TS^WOL7&Aa4t()<|5Az1tN^37nu zEt|7X2R3>I3KZs0pu~bnh7_~hDY)b{cXGE7Qq-L1Ug1l>2xL%%GDOHw3tR8zjUti} z0)sv%F#+Xe;;lo|0AxJ&)8GfulvVMa^;;`Y{DcoT7EXP5O^+pVQ^Vvovwd_T+b5wpD8)zjvjyNWII#C?z) zp=&YN+)|m=w7EHOduI+=qNgmRycW=HN*p8TSQv2&U2A&UlB#1~i;kIyvq$IY(zEak z_9F;lP4a1EK8dA^)KfX5ZLJSmrm0G|D91O3!(7i%Oe5=_T3AOE5=@zE-c_74FTD9S zN!H1=v{{Mm@x#rndzyYxbMxLij;{IcoiOM9Qzr2jHfW`PI{$0`@t2FCdX#6E^r9_6 r>!Z^a_8mn03McpA!X8}t%{a23Ko9{>zVOSxL<{5H*~J5}XZ_T_qt$Xw delta 543 zcmY+9L2J}N6vyXHlF205#70HeT`Q}U(pbGKR6#8i5f$}hK%qKWyEsY8?3U7tdgvEe z1`$1a_1K&G0SaC`uN3i6)LR8b5Cq?gcyJ*9`OSNo-^_eSU#H2tI1U+(?Kdy_zuj@t zetZ{K&zNEgG%FzoAm*BvPVO}9Xt(rouVGh<($D>dJuS;156UnP%P5b4akj*i*ksBt zyjKpL!dTwgkXi7RFoTJ_zB(Gz)v`uT?=M$%H5k90vC}X${&>!whMS!tRHBH`5Gk%? zU#ei!Z5-j&bGQm{aO*Q);$4?~+)Uv#@zz(0LJv7|uV+$w*}DR5`_y~bIzVmFA5^L^ zHWimnCRi~0FfzBu8~_J*9ZnVi4nW*$v|-*66N&jElP*4<@iciDv BaseDistribution: @abc.abstractmethod def prepare_distribution_metadata( self, - finder: PackageFinder, + finder: "PackageFinder", build_isolation: bool, check_build_deps: bool, ) -> None: diff --git a/venv/Lib/site-packages/pip/_internal/distributions/sdist.py b/venv/Lib/site-packages/pip/_internal/distributions/sdist.py index 15ff42b..28ea5ce 100644 --- a/venv/Lib/site-packages/pip/_internal/distributions/sdist.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/distributions/wheel.py b/venv/Lib/site-packages/pip/_internal/distributions/wheel.py index eb16e25..bfadd39 100644 --- a/venv/Lib/site-packages/pip/_internal/distributions/wheel.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/exceptions.py b/venv/Lib/site-packages/pip/_internal/exceptions.py index 5007a62..2587740 100644 --- a/venv/Lib/site-packages/pip/_internal/exceptions.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-312.pyc index 76fa30016dd3526fa982a9019197ab4ab80698da..80bb83a6cc44c4f7dd3214262c7da2189d717f8f 100644 GIT binary patch delta 19 Zcmcb`c#DzyG%qg~0}wp!oi~yDJODXz1}Xpm delta 19 Zcmcb`c#DzyG%qg~0}!0pJ!>NOc>p=41~~u# diff --git a/venv/Lib/site-packages/pip/_internal/index/__pycache__/collector.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/index/__pycache__/collector.cpython-312.pyc index 4270c5580202beb648bc4afeda2ac78bfe737365..12106be6461a19afecdb4079894379aa1fa0d7a9 100644 GIT binary patch delta 2044 zcmZ8idu&tZ6~E`+YsX25LmqZw5+@EO57WE|5C@t7k`stR$b+O^b*V6}zc1j`kMz3^ zD6Papgmz4AMS2jeDs9>yE22$1FqBknR#v16HK^nCr zQnBQp&-tClckXx2JzjhR{&o)Bmy3!D6#2RS!Y?OIZk=^kLi=o^nFk63=1k81qFzf? z8?%4%7urmIa&;9My)3|c?3lG`3#`J& z)S%|!O?X)K9^pmop*Nf7fNED1RoS7imKlYG=G0|oZuv(s25eiaw6*c#Ic=FXcIGRr zo3-;MwvPK{nOm33WF6ec%h-A$@GG>|~$QAUD z?;0G536l${IUkKBr??p^#80*Uyb+PfX5tyEOxM6#?Pv$^by&T{jD_$v2dLK{wzJrVS%&L>{Hae>QT69UqnYx6d%KIALtMY>v z{nd5V9}{0DVMbZdBd_eeqDRiVE|mY)eN~TG`>KDf!e^GFHVE)Jh5~zJ(1}1lT(&+9 zoYSOoXwC28n$=NX3P;B20wzS}X`YVDboW31Z>Vz1kkrcxR}5f^p*|w#*U-4m9Zc<( z7VeaiW=nb8Nj;Lfe&6CCi8&1y&zF3jt+}{!LS^}~j|I~OD?){0TKdGEmlKC?HEh&c z3kvY5#t2?$?8bjJGThhHk8d`Gs>NyPCfW#ICRiAUiU1xy{F8Rsd>F>A%Dg3{)O7$ z72W%aKCcHCb?frly8so|C(Q^@gL_+VLjykA*5^4(x$QzWkd#kQjOW|dL5cNk8v|&u zcC70I2wN|7+|r@OIu<^w20Y~U4gpPtC?}vKIX#h{$cPf$vH3XkT9-E$Xf19s+D{oE z=^ViW5BM2z1jj7*7Es{}T)E97v0+;ayl9PYds~GnTp1aHvlxx^NyBTA;NUkDw3i@C zu#aG#ph7~<85ca3<>GUxgj_i-o;1ZyvVKXBBe+UnM|^?hy$x_3AMW+R8GNMojyz(x zFANv(xxOp#XMAjXk9=v)Y)@%$6ZL`m&Kojx=ygrhQ3^_%TbVGUCXY`E9?giv{zUq9 zhxnQdS~3$CH_7h?Mh7aL*QEG#J08~j`079zT*BWBEY$y9l0#yNylzP_9TEb8qeqV} z55NO4^Z3=y0r)324n}36&kde%Qa$1(mhPH@53Qf=GN9S+YbDWi9fF#hE3`LKif0dG zn4lwsJ#yF4J?!uIl5V%j9=E@cT1#Lz$0=W!2fIdBYv1p)(r8|k+KjTKqB;Brk8SFZ zObEt9yM8HjmajmxmL7GFk&3JUCh_m(iKg zMySB|MuS1RoLrS1nn=q@Nyn0{X`Vfl5l^;GWfO8W6kp4a{pKae>e878=x0XRerC~@1hG2 vkB0+GU5Z+GYRy%sxUH5z>!KpzmZqqci==+vgddFms`vmv!9Ns2dpZ0MlA{@g delta 2264 zcmZ`)du&@*8Nc84wc|LBorj$`O;S5a^SG(w^^sRgLfWL+oTN+Lv_i})HIdIrYw(L> zcUnTEM373|#$(x;)@dNLY0z%;AJF9w#DG<76-*nYqnm169+_0330mQ<71clkzVEv2 zU+hT!o$vR(&UeoF?(vORp!7p1-jQKYf?keAyCpPAC3;m zBy@Tk_y`|aP@8a}=qU5>5$5GSc?P<{FE4_w_cAY27i?_vniicf?X4Vj+>bgx>h`e! zA2nkFY99>AS+!%u!@DTog2sB+v~#ov9MLINc}QVf*A%9oQ}61gO>_f6>3BMfFz^Oyg9ub**CZ0(eLF+bv7WoC+85lCOigkbq`JDYp7&qD~pa ze_Qn{h#5~iM^*62i>@z2+}Q1Iu-d3T;gz5BwAVJ1IDt^qzLZI%g-<@=c@Rz*mpp?i z{KTkeRcfEsgIV-}dQm|J^drK>LWmijE``cuo zRo0Y}3RdUyM@tG$KeGSS^JCX-5{-Dv_f@!J*!>*XC17>G1L7~eOJ2mAPT1yu0(+;QI$c|g4a{URIV`#w=#{}xYfKsD>56eU=_^1 z;AE9}Uv^f(tqUr1;0;wS+I6Q`#AHhYb37|}j;HgvKqk!tC}%V2ocyrMzapMR5AguO zX@Yiw6hQ~VY}|%;Z&2S+m))91IIS$hvJ$&zQp zT%#z9psVvKjC2HWNJsaCoa){qPj(-d8{L|`(H%DDfgXK@9Ai$}>8>w&-e3hVIF6eEa2MT`#`I_9Ez*9R7H|gX>BV}Ov$Ab&k5=X z>IrBEMJJ-!ySvwr_-7Id_I9K7>mh2jWoeGjXNWt zHWtWr20^!!?~!CtknXWQ_>M6;_L>Ttl1+djw`gL4GpcWxIxa$s+^f9(Y-PcH(23S=MFw zZcn|8?DN9~nca5@K9qYWN8v4FWin-f>+(jpv-0m4IQyza1Z4A6tNs^cMN2Xh7uRV4 zGMbw*AC^F1b#=Aef*W#vY5?Asr>6>me^3VT5xL$*`2VgO^1}2q{8QG<#PA5RGbe3k z?(6d3GbiA8##i=7A$XQjG!oD$m~CFHiYMoDxfIVI&oDusU%Az;$vY3XhP}ki{-YN| z{Ec8U!S4z1|56e3(VJ~suA5HOJl1EZOW#1Yrrgxzk=YAlrfCP+&mib?!Yt=sC>N`F zYCe$+rFbqke~b%8PEQh0uZw3$`ma2Cpf7klpGt@hTFRumfxNGg;NFR)4tmZP9=vt fc4)|XXSfMMHx-22!}6DhUUVk_93Lr!=BfV=8q+(% diff --git a/venv/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-312.pyc index 23091f5033d6ac8ab4dacb76940c0629c39062c0..5b68681fe05a0bea34371d4fe64639e5c9e31b5b 100644 GIT binary patch delta 6744 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 diff --git a/venv/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-312.pyc index d9046f1183d98ea4571e68e0404d1ea3f0c2db31..4df6bbd09ab197487982abf2d6cf9bed17c44358 100644 GIT binary patch delta 20 acmZ3Nv@VJJG%qg~0}wp!owt!&*$@Cm5e7K` delta 20 acmZ3Nv@VJJG%qg~0}!0pJ!>PkvLOIQR0c=@ diff --git a/venv/Lib/site-packages/pip/_internal/index/collector.py b/venv/Lib/site-packages/pip/_internal/index/collector.py index 08c8bdd..5f8fdee 100644 --- a/venv/Lib/site-packages/pip/_internal/index/collector.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/index/package_finder.py b/venv/Lib/site-packages/pip/_internal/index/package_finder.py index ec9ebc3..fb270f2 100644 --- a/venv/Lib/site-packages/pip/_internal/index/package_finder.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/locations/__init__.py b/venv/Lib/site-packages/pip/_internal/locations/__init__.py index d54bc63..32382be 100644 --- a/venv/Lib/site-packages/pip/_internal/locations/__init__.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-312.pyc index 8f1e701ee929053add1da8bbf656ab05574bb699..5ba3fbeb0c723e44656fe64d43116cdf905fb109 100644 GIT binary patch delta 762 zcmZ8bT}V@582;XK_W!?~b2PEgEn}Oyl`NI1OC&+El*DeNgpz~78YSC`F3w83m`)T1 zFZ81$3Za{wF6t~1f~amKx~PjH=!Y&M2s%+W1wrRKI+ebQhv#|T=Xt;P&oy{74X$;k z(?+!SdGYq-P}c+3MZe{#iI7=tmd8|mBSu0F{Oh;jGyj0VpCvhS)H!fFa>^;WX)SUx@ZccAxDE-=E|G?JeN&W6LZ`gKgozZ zj)nYJd#kP}h(siEO_|+rfY7~?xu1;lgq+gcoHb|5`Lcc0hNN90`Q+N|#zKvOWDjr6 zL1H9UGRnKkhMhaZb;Ds}dRnv6Gx$4nPMHZC04^)}<`Vz`eAgl)whn@T?^|Eti^zW0 zbsEiRkP$RMdo;{^W3eMT0itp%DlvGzEn_*tieT*haZLHzwhF=$t+Y_MLSdOg2`jN? zSi}#pUvN`-eeebYtC;F+H?C>Zl5(#z4^7)WYVIsknWyj&kH_oazLJc;g$6xep|<|n z|0SI0K45wb+U2M5LcAW8?kQNtrk>|e!7n{i!d=?jMx%WzOXj4=fcuTxr?QlMw7FCxC8~+oxniskQO&xvRHapyHsa<~yG|X%DHKNwL#k7k QE@E>0bnA2&V|@ev0BaSwYXATM delta 1001 zcmZ8eYe-XJ82;XKHg|VtZfD+eF6Uf2m`PT)vZ&ET49fZu5~8gQ)0%8Y$v8$-cnPV& z8ziaF4g9eM$;mACryCIjrTC)@MfI~kF)#EZh&tcVW%T}d&hx&{^FH4>-RAq^n|wgDc^H4aRa9_9Hk>C*^WYNNG_#F?XuSnTuyFEu!i zsPJ*w8o#-NA>=ef>wpMrmW_lM>7*Kns10&Glvm1XO-23u?bjC0QvKVf2fG4i7`Wb6A|R=SgsS>@PNaL$x?$$ z4&@Uo!X=xqBV!q~4e}u-XuqhH?+bs~^Bqx6*qKp-xj_;n$-D%+JOMJq@qjpCEaMzEu~YOb&#*3sV866=i}i<}Czhg(|P z+C!bK;g+`UFn+D_nXl2Xm<%zy3=S;udYFI;_j%hOBHi_h%t7w0v1rytcHv$t4Hyh^czB#V?-r?!y$>v#Zds;_y zYv+x`SdLEL8Ep$20d@U+n{>zb0Qgb*8kH2zQW&E!j*<22U<9wPUxM4xm6~e|JVJNv z26akSC#2Teekfbrqr-ofY1>a>3Jsg`;i2T(^d3qS|1=#dhyA~V#dSV-f&1&?FovJ& zp29TV+S0|}q6;nxP6{3hqv-Y@fN|{gJ0XQ*emA_9p8MZ0%@GF7@60)AmXa^}?6jJa xbQUpK<26Ixv_@&QnO3K?dSbSw4GJ|96CZCHYD}AyHk)J_7tIO{;`jR9e*iST_TT^j diff --git a/venv/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-312.pyc index 78bea9d87a1b8c252075a205da8e17624dd4867f..b112597d3e790be3dd65a455c852db3da37e6aae 100644 GIT binary patch delta 20 acmdmGy33UNG%qg~0}wp!owt#Dy%YdKh6Zc^ delta 20 acmdmGy33UNG%qg~0}!0pJ!>QPdMN-x$p(7> diff --git a/venv/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-312.pyc index 93dec8e6329bdafe182c557c92e116a3986edd0e..5f426e6afbf5c2cdf46ee221f416af0a37792206 100644 GIT binary patch delta 496 zcmdmMciE2jG%qg~0}wp!otLJwk@vO$qt@n^0-Kn`4Ko>Pc}o;PavLo)3iZgcFqFtc~OxLq`M+zi~A0@1J0LCJT5DFcKFROzQiN{ zff*$KL{R*qpymucAko2ggIln{_va^fMg~!%pN~Y0i+OXj&f#6iG?Ay$=vp_aEq8Nz2^ zs9`Pviai=l$>Z<|b;@O*xB;ptY?+D9%VqoIb=y1Lx zBENuTN&1Sk4at|)tS*aKcevi+5uV^S!+C+|RUY*ZtUy&C*cf<(8hn3#a%E%?HTwBT z#JHFTXxKpsE;kOAgZf-0*e*gdg diff --git a/venv/Lib/site-packages/pip/_internal/locations/__pycache__/base.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/locations/__pycache__/base.cpython-312.pyc index cd98922adef7dc52688e4939e5170f94b787a1cf..7e89e931c9b5eea8f466400002ac7c77518c1ecf 100644 GIT binary patch delta 20 acmdlkyIq$1G%qg~0}wp!owt#D4IcnLq6Q}b delta 20 acmdlkyIq$1G%qg~0}!0pJ!>QP8a@C%QPLoonJbq4(a diff --git a/venv/Lib/site-packages/pip/_internal/metadata/__pycache__/_json.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/metadata/__pycache__/_json.cpython-312.pyc index e18b0873155cc75d8ab7cd0c6a0b619682600e07..1be8046f2c1e867d745be1ba99db97266900c047 100644 GIT binary patch delta 469 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 delta 7651 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 delta 2856 zcmZ8idu)@}6~Fh3-%e~2+ez&BkvK^cCz%5z;SpX9ghv}lhq^}01EnV4O=4y{=6>dt z5hbIUT2!$X?htKHFP#f9Kruxc8jvnUOQ!vwc`pWFhdo_TC%)Ep^9j<#f;Sx+7c5D3OV5jF%_e5qH89 z@gyoD6&h!XdlSBhPn(tJBdLQ_?)PdtW*>lGC zrNv^*w4JtPuA8<{x>i(JendOO1(^rl!`)H*PYMBOd@7xkd4eDn?P!w*D%SJJPj*oSXrT5I4?EGMS0R9W&^8sW^{waeo40F z$rk0yMnP!L6Bg$SLAEGQR-(xqz!vARPK|W|Taw3?YHS&>jy$#;?!XO!IUrrvxGv(6 zS4ynnQIw@XdFNG(pi%~FAE^6TU_Os>U@C#B+S4hrHph21%^z6a05092RU-#v539}D z)@(eX+0e-qjJ1gp#o#n&bJoak}>fIjoqEhnWr#BJ9b^*cZoD&W``Jc`hagn{qIc?@9> z!VdA1(j@K6*vft((K7LlJLpWHqD{3#mEPf4sy`NI+$HY1J!}_lCcs`)zXl#=5 ziCKT96n(3GfX4|$rg9ZM zEB;;iR^uoT`9Zx3>tSbpzlQhc8upyHQdOhZ(i7cguXsDyPj?D;b(sD}Y^lBo!F*Ny z9KD$NW=%USS_Ec7IxTj-Q=F<@Pv6O?wLys<77y#T(kq##>mNuoF4i@6xU_419RoXs zpdGzKoNRoTejv6r{iRzqu!CtHRr=GB8TC4(|ESpPp0F*bdrU) z;QYK~gdV0M^@LM&_)5jffL9u!+O(q9bs}tS3`yO6k8FS;^w9#}eQc2~LeUS|1uX#E z_Lu`F!e;UOGUI54jvOMtE;vAWE9iwJtz=Y-676TbTI3-~mBNepI*=-uLuIZ2zA~>K zU`ci`#n%omdF;evX~uhHmSRbnCHrDb39pV1^+n^#+VG<-Gia>>K)yr%Ge)layDslN zJu)3wo((L&Os50wS%24m6-?nspo)g{s=1#J4YQ=e(rRHW2_6*Ihwm|e7IgUA08oHz z@4gsk3M7GLr?FbdVldpk?GvDsPJl7;iM9Ba%MUKDZu;2Yb;H&5(x#iPifLDU)>S{@ z{HRS^Svg>w9U^XB!lXdK%B z-h~DI%B;O|%2cU65UO4~%g2fU3qUIZEbCJu+7_C>S*Lhtu#D<*&3g%i|4(uuwci7q ze;aCXOvznWZ;B7?kI76P_CJ0rUzh(KO#}hP$Su2f+FqBn*G=ee*uxiU-fg(p;F(^! zA-igD{nggTOzIaqo5-dG9B=ZpPyc}T=p&KEE;6oSzP)!h5 zit+Rzj?ZVVPsVZfBEmBWFC!Ep97DkJ;MmdJi*N!#k8l!Tlxsbw!!^`2;Xgx|1W=6$ zrYO+?rW&{9Cj27G@Tj>J;XQ;a2v-p>DJ{X=!xq3LLKl3>J!q+MGAB{J=e1qazU5ip z@;L$v^X1O_IL;X|-AjVBWXj!i57tZW7Z8ID)t89VOQTQf^oO1Kf1+90|iSz?)%+$98DE))j(%L{j6-w(c-7P+A zZIbR1;cXL!-5Bei#ih0u=`$kkw*An0Z6SL8E%Cy#jnX}m`O~s1v;$P&?5Je-O`>vGi?9~u~lB?ou}cN`Rht1mUY0#mg-6-$MC zwH8lC<6(BNkEO8DmE2z&KFz#XY+VCqE{4|ltqvrdxYI4RuW@<~3^EqyE@ZWTN!{)! z_`~4D`)gY0FU99;mTkWSOMEL8ETy>uO6d%7&Jf28vCR-O;4JBxCOuiw^AA#co3zi8 zr*4xcKh>Dqq;r;Z%#yAzbw(yC!KOsKOoxd!G7Ih+Wczs=L80= G!2Sn=4b#K` diff --git a/venv/Lib/site-packages/pip/_internal/metadata/_json.py b/venv/Lib/site-packages/pip/_internal/metadata/_json.py index 27362fc..9097dd5 100644 --- a/venv/Lib/site-packages/pip/_internal/metadata/_json.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/metadata/base.py b/venv/Lib/site-packages/pip/_internal/metadata/base.py index 9249124..9eabcdb 100644 --- a/venv/Lib/site-packages/pip/_internal/metadata/base.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/__init__.cpython-312.pyc index 1f62c436a8c7d5c4585a068841f19d38b64cdfa1..7f5b98894583a1efcb74cb07db806d287a9305de 100644 GIT binary patch delta 20 acmcb?bc2ceG%qg~0}wp!owt$Omk|Iy@dd{K delta 20 acmcb?bc2ceG%qg~0}!0pJ!>PkFCzdyGzHcG diff --git a/venv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/_compat.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/_compat.cpython-312.pyc index 2658dbdeb1aea02e6493882d6a6535cfb52a22ec..63a3a857f4d49bf497cc195ec4158df5546c445a 100644 GIT binary patch delta 20 acmew^`CXFxG%qg~0}wp!owt$u4G#cF5C+`< delta 20 acmew^`CXFxG%qg~0}!0pJ!>QP8y)~iQwHn+ diff --git a/venv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/_dists.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/metadata/importlib/__pycache__/_dists.cpython-312.pyc index c148ee45f9ac5c7203ad97c9dc1510a7a8b39dd8..587d409c4f0b26a1956cdee41f541317decb79f6 100644 GIT binary patch delta 1494 zcmYjPYitx%6uxI3+wQCTqTTLncecCRc6Zy|Ev4uWB^H)aVuON0nlOoh!puVJ4%L~3 zLIY}ILt26Xa(I-c0bend#zfs{&}c+{s0n}CG^Vje1qm@RFS@A-S2$g zIcM&jbMGD;FSu{H-3~(6-8ZfjcAj&GV8glO$g6cgRHE97wR%vgw|G@Cq)UpVhn27u zR~H-fh!W9dMb@KARBu!oE!|#>>2W1)aYr$sHz`dPcNUxV7Ntc`DoGlMYU_$m`8sfEHs`<3Y49|{8h>|%5X+Q3TvFfTm%`gXs4&gn> zfPj83QSRloJHc0;bYJ7>D))H1VXx*>1_dod;lwr^W){K!W8G|;T1RaduK7okc@ zZB%6~z4A57ZM9rMjgE>++c7a6EBE-Xh|q`kf}_!zM|!T(lJ7rl(2sA`uEDALNzX7j z%I_w_U?ixScHsF?7QYGU&hs>UjZ_4|z5%^O~BjY0rp4glx zHd`ITRQx)8Qoa)}16(g(XxaquH7+#Yfp5#7wFCif;asxIVWYL|Su7jqYi`G%t$HOH;sVUI1S`;ILTm)!5RvS!oH!QqH&7FY|zG820IwA zUt;|VZh#obwgtYzi5v^2!C$B)@l=X!NlPTVf*yvm3?-7_mU+n z^Tg(>aLlWC@#D2;GZVoj0%8XxAgVV3fwLG;< zDF4&t6s2j$hn??xDumJ-_20G4ZR)#EoLK3Q;Sze*&4LGiT$iwU*?D~^bjGl?^Hay? vG-M+;OZa=|+CaxoWaDpS^WU5Z+%lo?z=f^rlm0CnNV9>&1Hy=rq6Pl~A?b8h delta 1935 zcmZWpeN0nV6u756f5r`Wqsh@s{#gw znPdWSZtg}QIt{u%M4X#jlljL?WGq`;wm(YHxDb*#_s2exZ51^0E7{I%=``C-`a8e# zJLjEy?mc~Pxb3HQKcy`H8l`QKJ>FJX*4UAR8kQiP~U}Y!$4sO|ZrMq+qU` zC*;ZbLcUxe6v%eLE;|HAES4NBl%0Yz#&toL>=xWHt`8Q;#X_-MB9wriA{v6FGB5D5 zNAO_8pn4=42a%X6u^r8{jrbyuY&uejotY+xnWel7Y+M)0doiCz+VK#1gn7)7BF2@G zUKdb9N?_OCP@t=`SyEIm;d-Vi1)IZT#z}^GjKg*2I@~B`Nj6a<<+f?W>_Lr?2RvWW zTcLCtBj$iou#};P3@i9{$Z$x7OBps$oS?Wm8ps`6dQ0O{vrieQlM7kJvF8$%^FS#P zVJA@O-UZ;7iiM(G;^Vu=vOTd~G@@gW6Uury-WhJRoaXQm@@w{>-Tc%ZOEi?8&^j{6 z;hc|lgi;fN8!4InT*#F0`h{K0_e=x&#!V7Y@&A)BmT4XsG_T00GwfgC_ljaJuy$sg7g*g%}NB5WiL zHm_&iWM4oSBJ&pKxH#S%DXW>PoN`568)q%`5kvi>C`+Rc)#pgRtuVJ%!%iErYh3KK z%RqUBxu%+(uI7M~TaGO9rR^*}Oxkj9;`hk9yx;LyxIF(E2A>YM+Baf6NhTdX;E%~j zp_}Y*hH*G-afLDdEc~^5J;ql_a`BJ&tMG5d*%*IAn9^z@=j-rlvbl6k#R~|I{4lji z>Dm_%CDps3C#3j!Mrnh?%_Z%YLM{GaQ0W0rrI$t?msanbp`H!k0Q%mP{!agJ|4oy7 z#^jC^Rb5hMO{*ixtCdm+&v6p1*2(}+tRx`xf4sO8;1C`~p`}?MG=$r*hzFDV$kFsn zrh_A2xYEhrym8YyI~*h;Z;*0l&p90LSoVgwZJKL)&u^>c>xZ=);K; zPqbksp}ht@AIGB@qr>?c)Qc{%-B@uUNBJNuo>}vG~)pfqLyQNO4XOFV(2IQ(d!2Ms){R3zLvFZ9-=7PH{G8T+=&KkVe zD{H2zW-B+{Fl@TRLhymAf$W2YZmgUD!n1R%zq22p;wW!X$N-qr?CRjFRjR1bwoks{Y-Qa*TYsEJ6-d+O_nXsF=xz zm4%u#pya#C%la!o=sT*uPTpR=%>4Y%sP->LibED_r9O0QdC^{{R30 diff --git a/venv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py b/venv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py index 26370fa..f65ccb1 100644 --- a/venv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py b/venv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py index 048dc55..2df738f 100644 --- a/venv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py b/venv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py index bb11e5b..4ea84f9 100644 --- a/venv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-312.pyc index 334577d5a6f65b0015f49620d5ae7698e9dfdf42..6b6933bfe79d6f2986f179147d07de9b86477ca5 100644 GIT binary patch delta 19 Zcmeyv_=l1EG%qg~0}wp!oi~yDBLF^J29N*% delta 19 Zcmeyv_=l1EG%qg~0}!0pJ!>NOM*u#M2A==` diff --git a/venv/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-312.pyc index a3bc5888749a71bd3b1228c8d75fe4013f511fae..0df3293a43a8d90d09d7aacf5d24066585dfc9e3 100644 GIT binary patch literal 1590 zcmb7EUuYaf7@yhych_sAy~d`HvMq{T|7@`4Nn#Nz)MyPhNrfH<>*i)I>~(MVIx`o@ zaSwskN1;AlpeV(smh>S$*~j>#;7g<_hQ)$b`rzAz6NEhZ&E8%-f+Bvf-}jsE`*!C0 zH}gZWm`6arefDK-PXQ?xL(((Q{{%o65kzo^8n}$H#7d|%)Uujl6|h#;Q>=wX!z`N^ zDTrdCKQK1%U>^ltLd3jN14=6)tO3rv_1Hz=N8A zv=mu@bcu*cbpk#_rxr1YS+j_BODpGyLG_wKa)9%zrjt)j%tl=JVdx8p@S-1)079qj z>3P~@l+#FX+qavs02KJ4eYQGuIcwKqW(OmGyZ6;Zi~I&n%#}gLi55bdtN;PABa#(? zB?hCS#iF^Y2CE^N095$;cY$@006w6))E=S^RHB17G7J81Z$%6T0dm(|135{=WacIam=3t3?jtJG38%F!)=**3i$^(VwhSKU$~Or|*v6EA3eBsAl59hYw$R z^y)i1*2PgZI6k)AzHC-CyD$3C)s?YES-KX;Sk^@a5-# zt)bmx<6Y--=l10G>GPY@-^_eHv*~VWTZ`Xa`}W$_2jAb=9=oz_U18(k>=b0}<&A(z z$a@|%rxi+k#Pe>n{4ldX3?#0CItRgovETqzI5rvcJU@zJm?gNIpk=ZIOjeVfkZc0j zeUu)RX2Wt)E1CTGEU-_}uiAyD&%LrX`%Aufb9T2_dZd+h^G9#K-_ulmYJH)HK-_yH z6`Ld#4@F-pdwHzSH*3To za(M^YG3h;#dJm`89Zap8J{D7%Q6rS<^c90;rS!q0)5B@{6%AZRJ{U$caQevSw2Er;Lh+r30u$jU_PPtM=Hswf`T&1F# zDn==E2@!b-5rwK7aGzLax~>}OKZR)EP^sFCQxN2W9V$r%9v(3kGD)k9a_R+KxAm$YfaKV& zexj7PoY2cY)19`{`E@CjJ-b4~^c-az?h9oX{*`4Qd?wY`esqd|>%6D1jT$r6|g z+?rnk`2eq?1-yW)#EOC#Q-l^$8@Qzgdn$2QkYKm(6C}u?6?p-@+Xtu6Oyb(cLE9cf zYyqv><`j!%DdVKIu{1nkD51=$TYeI^jMci;vbaD?hqbsjb@6QRk`r96-OyiW{tOL# zUW7}17SQ4x_2!BN=SGn`0Xv`D&dVg6rpx zcdU$j5~=`$Uk37M5$)uTF3ay^9`v95^o^hTPlMbQtA5wISJL;jqdQOatq$BCSiAU1 z;lsk+lV2I@#&++>gQw3l6qFg*MN%f)gu75F&aIHqeoYYAKp*0nc5CDkWp=*`VimCe zli8$Sp&wEc^Tue${~mhtS@zZo`oGi|GvrW(9;n#C6Pa4a>@dW@MYKAD>O&&K3_8lP z{u|bo{fIbt3J9RubN1(+^Y?qs?{xLPH@-41SYf3Q@0w}3H`_pRCd!Nb^w9yuhW6Xf9C}}Q` fX-F93hv?iN=+r~>@?UB{p2XYFoY_S}h>rgQg>=AM diff --git a/venv/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-312.pyc index b0e549c99f84e34065c22447e80daa5bb95b7038..bc859a81f2e1be964797b928f7f3aaf6f855637f 100644 GIT binary patch delta 3769 zcmb7HeQaDu5r2E{-TB?O&*!s!{<^cBI63k~Q<_%6DK?4oQBv0+l2nh-<9xeLF1ZhP z-`UhogiT^-S_DnBh@|{cRTckOX;EqZK&TSmsG@-65Fy-GN`oRHA%x_rQY$`0nVEOK zUgEYAC*9oa?9A-$%x`D*esJv9pO5?|91dvkx%JIwCSOWkigd8$OPjXLGmSHD6q`z> zWtRMwzZ9?nrJxlog{)91Y=uh^D^iMDQKp^Hxc50`HG4D>;l8U3ooSjC<4slz$ULV8 zT}dP5W?iq;?@>s*_&dTJJ3Anjh0)-8HPRP>1By`pQ*>=Ws^pWzcWA4S#(VSF&Ww%&Zz3REp z8wPEOq#eGt7s#TvVwe(#GJI`HZ(&0?z2ud+8QF=X3rRN+$2*fNP7AV2<41O&)X1I? zRXG4`m-?}BjJ2ya@9a(-(^9ezxI1maXp@!V(dmK|Ty6xFjQW{(H*3H4AMY-f!c91O zQIs~K!|GS&1L_|M|NN6Mx~vJ!VqCL4N8kcjx-f*7dxl^}_<+;voPiwoT1~RI>#>=Cokcgk2RJ;x|*U3zf2)tRD59z|*6{Ho15|zSZCWdr(~ojzTv79GpA0<_CR}_l!Z|biLQ5OUyBBQJl1~ zEY#p(W~-GfFXXFp%}4Y0AvoFgHOVpcTxiEUf-e)1adh2^B!T1}B#2Nan$70QR=WDk-NByC6t;vL9gn2C%6W1rpv^lRG9L~3E* zh0QmN)J=cr{K1uI%lWaD&0Cj^wkzhd@u$N#jIB4l&FXx3pN~8>tKWs+VNvzVNT06< zJmhtC-QTL-i)iO5NEkx{Uw^{K8?~4kOl2#H2&1w6LZUE(mj0twU*{F z#xg1w+tY&=jCSJ~`O4I+JPc#V=`f1>)yuIBK8h7NWfk@B*vl-be%La*8;?YWOCCBN z@o+}E@0c0Kz+}r$0$axu+U!xM;$7^k>g(~HaGvXfN%i~q;gKUS1=e^q-*>m}Y?#J7 z;!^|F<0{*lb|K^$8_PsL5Jm_S7c~Tr2Vm%!Q?fE8WObI7b$qs{LZOg*QT3zo6Gasy zS@_y3K-7O*Uvps*Rc|Dc^HU)E@Y2F{%O{$kfKX9^Lg5vDC?L>`8VZO{`0E9vsiA;` zxvxW2ySBQopH1Y`u3bxdC9kyJqF3hj4H!3)*gL{Y3&iKg~1e&#r+?$0nP>q|`H z5HL%X!I-F2iXV_ZP?>AlSCB3|CuOBXxB8NLp*>Se=xY1@{g1e=D52L|Oeiql0LK0jkcPV+N!?6zE*!kTZy23; zyOYU-v?VgggKqtUo59c9%Rm}aE1+j^HUv`P1&(@0Ey2{!L00P>LWk7p&<`M;mI>*_ z5v8x*9pGg$kL|+3he-gQKe~w29z#Bktt8lhgeW*@&;VBBSBNQzV1@TyOX|Q9CLN1dmHOeOWh;vd+P7q5}N!YJ?$P}u{N8!D~*bd zF*PlVk`rqKYh!Ammt({KZ7RcFQtza|m}B>BYKI%Jg z`xmxCxShlBctIhY+1ds;X&|~*m!yywFzC~x{h(mu9O{bv6AC9xImoB z1t4`7>V=I1Y(-t)*k9X8c#!v;LsKuGE=}3;44T{)<8KY7*q_w*2VINBO|+iT000Wc zy1TE=Zn~Sjsa}MC8`SYV1g5b};?9yyx0){gCS03>L3f_;@-WIMN@tPVi-d{+f`tz4 zZg~-h7m!fpz}Mc|LjYbx^m28xiz$8vzV<6Xpg2(b4`BQ6A6z(mar2eCFKxSF46YjL z`OVKiM9rU2LC5ZMnzC75$-}FJg65IJ2?2DAg^BG`IcW=72Cq)A{yG=7)KTKA&Q2A| zC)9T{y$Ol`$Yc=3;4N1yg14CZMP}3dNtF3VAIpm=eEhiYX^PJPnqa+_1V_RS;g5hx z8KCIVR&Rd*{mUFGRrqvK+%LZk4)CdFKMr(NXN@r*ERp^TKtWm*7v41{zq;6 zhBmGq{n$TeRs)(R_^zjo1y(g6Z|g8z#o@a1<#XVw)!w5tq>bp)qvEraM-Jb mVi&uvoOt%j%dzd(gF6-qtb^RZ{Bptf| delta 4191 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 diff --git a/venv/Lib/site-packages/pip/_internal/models/__pycache__/format_control.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/models/__pycache__/format_control.cpython-312.pyc index d02a5587ef8704289b18ec03e4014b49359a0133..5ea7c3b534f3495810b7c483f601a5056ca392ed 100644 GIT binary patch delta 20 acmeyW@Ku5PG%qg~0}wp!owt!YO8@{zzy@gm delta 20 acmeyW@Ku5PG%qg~0}!0pJ!>O(mH+@q0|s~i diff --git a/venv/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-312.pyc index 524310cbc63c7df127a858a1ff99b6e4d37d0b11..583841e4ad36f2c2f46c0f2c25eac90d0bfc3c65 100644 GIT binary patch delta 20 acmbQhJAs$`G%qg~0}wp!owt#@l??zkLIsKd delta 20 acmbQhJAs$`G%qg~0}!0pJ!>O(D;oedg$0=a diff --git a/venv/Lib/site-packages/pip/_internal/models/__pycache__/installation_report.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/models/__pycache__/installation_report.cpython-312.pyc index 3df0257d2ef5751706df9f75989efb88ee007a52..d78d359fb3ee7345a7f248375280094af5b83f91 100644 GIT binary patch delta 20 acmca4cuA1^G%qg~0}wp!owt$uI0pbhBnDal delta 20 acmca4cuA1^G%qg~0}!0pJ!>QPaSi}MX9j5i diff --git a/venv/Lib/site-packages/pip/_internal/models/__pycache__/link.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/models/__pycache__/link.cpython-312.pyc index aafad7287f5dba1451b7c36f4f03108312291e9f..95b46046e8e84eccb7e074d59400c8a5944e9051 100644 GIT binary patch delta 6337 zcmbtYeQ;FO6@PcX*v;-{^F@*kn`DyaNjN@ zKuJ0Vs#RO@S_sON_)$j$t(bAtI(DR0+fmyl*b#i=_%Y&GN87H2j-%GL=iK+QSpqZt zqi>Sm-h1x3=bdxzx#!&bM&2av|B0l(X}6~d@O*sl&wG3wN7D1j(Ie$A4TU|O9wJCq zY7zy}5}F$>=`10FPLOmv*CYGYk5qP=sFcomVp?Z8@L5Fb8QT<9C$tKpeMAt`PwP~^ z)0%+J`PbzQJAgUk8fLGUDP>A_$tU@GbWRX~|6t<)J!0sr5OX9SjQgNJ8~T+g z{aol*!OM+1cd&D9*~UC*-Nu?WXAfyAb}kh2VYXAM;Sx+@0nDfs=OiV%pkF5mJNqgZH!aqDQKS_bl!)*u=RYcnPQ`?Cb~Ca(rh>rW`4j z0#_O5tm!d{^F|CwM=l#A-g5S=?)>-({b2)H%}UIN%%vdStD|oAjJb?>**j(*SvyWF z*~H|A5$a(DX^TAd&{T}!K&-ous$?L@MgTWH)XSo24WyNwNoysw>|DE(*{w@*Q8ZnG zumIU{{gJiPT12+8LBLw}bhDG4wI0oNBbNu^D%M+VbIEo#Y%2rS$8DcCCD~5t=tAUP z10dsSpb|)E0oa${9*pc-ACUX1gR;L5e*J+^D7se?zt7Iw>&&&l0|F|UJ$*xY8FZ9c z-O+G=FeE9ao+t$~6~oSGFhZ+Q;!=bfb}+qic_TJW2&)hr2u%Qrp(`2<@pqpRD2i8= zDaIB;1-q0!Y2pLL>?OyOM$~&VJKLPghBKZh<7+_p>tHF$ah4n4D#LtiQ)Vp*vf)hM z9GtD_!KSOch0|)-YnjEQmwl31+reMg3RJI!;*O+k2pbSKBH*T0t!c;BCWIP<8xf|h zxCy%m0T#?E&)@@`hH8Kp$Fd$+t45Jx4929etQw-{i=&W;LiWfQ#5_>oSILm${ryoI zlSIBal1%+T4vi0Fhl%ZWXeLAD%bWsZFA(;!jM+5?d^3AD`xtv~_Hok1_T+kPJ*nKM za|?_iAPliLa%)KK_`h-=Bqk)#UUnkC#eM@cy|ZW-DG~O!{B?6MWE6+LJ0t}n{x}W! z`vb8)dH|^Ru`SN~)D^2A|HOHg3`KA@;j_JF+J!>8ak?4i^#`a7!4r{Up=dXs&-s)z z7>h^LQL~>){h>g&Wp++47Ej#BV$wev5t|YZMg<1$I z6iG%@0~0nV;|A4=lf0f3UU!lTSum-D2eRSZo$FvSJnVOE_RM5T>?~EscoHuKt__&P zVFG`k9@!+5WYpeU2Jgk{1hSCdK5r_qcFvdb*p_1FkQezyURXfS`M~c3N(HpN(5~d# zP0RD8=vXyltRiKsI%!p93UvXeT0nNy6cv06bqCi|CsxA?YmzJrrdWWZHc4HWLaj?u zYf`9-lGNH1YQ1O$w^Z=@sYXv7ylwHIUhl1EPWP);3}Sj0LM}`9=6U#jreZT2P46l-_Kt0<``ZA4)(715q7Vy0Mg78zPOIm zv!bdZvW7KQmDl#8Y@_O$A48kojli?zJvfx6=zFCY-^!XL>}XYSAJ3_NWNqhMbOpAL zA{+xy%so({coN|0!_q%UrQPu$m8Rt@_OKKSh=EuD^o3G}ue-(|R#;s`46LF0-=O@8 z1z!CSU&LumRVC?z_-4#E)9$7ZVHXuuERfY=!B{XF;n`a;g`&N^5>ZxuVPAxLNXjr(InKx>4dqIoAm$L(z6R})@-4;1?kJzQ8WabG^r?dhX1#sWhcGIy_1fT33CZ7YV~p_ zduMTR1z%XA#@CD`qW=v%fv^NQi#8yO9l)zs zg*UK=n+i;Lw59j6b4_{VW%h0p1-shUoFS9!>ouN|q*(d^PSh?_C@Hz|S!45J;Epvf z1C5?;_K~G)kk!Cz3cZNZk-*c5CP1+zs}JmoX-OF^^TD_?58dVRVR zW$Zx7s`d)mMQ?-dRW}BH$t`6G64-LKTJF(`%ztcYTO>j$MMQZelbgyL|s zn6ZZRc^K5f2D9)bHrVO|wH|A|ZH1=R=fFX~K;XK~6aWcT&{W}R9GBrQtZ}^uq>N=b z*}(c^3(n(g9l$qa6?kkq`1tXJ;%KT^wzADdzF@bstpOPre9yNnY~>-6$_2BOS#Y1l z?Yz&%17GVUruX%SkbC#vwSTl{D(&*B*SaBIrR}eOq8MFNR_`aqpezO{ed8L9KHK0U zS6I%*3QeP%H&!j@5_I%!WKN$s1I3y_pS^vO6w+$wRQD_P%0@USanr7B>@|Idliy;2 z_UsCt2(h1x78GQHnR~irEnldeZ`sLq^zpg&hV5Jvq8=Y+y2t|TgMr8{Nz_&;*(b0f zGG>Ee0o-)K;hA)Jp2(SSR85$x)M8$!nYbMlyk_;;3!7XnBMOw-@JyIJ zw01nPX*sFUlxqPQu=eFB>N5n4YQANru6e`iM*<(aWlJS-usgS`aPfEIZlLP`RG-|g zeb`_hY;o!=I`++$x*@y?drh0+*}mDkLK+y-`*!%)^f6X)eD@Zg$HtLsXY*4L5zsF%7O+0)#A5XYe z9N?LlhYwF5Wk}nM@IHW&*4DatOGis{)3z4+AyV&0_!!|5!lwuhgr-hJ+{tu4!aoo& zu<6$b-y#UGC#Vj=fPkwp^Sj0&q#>Yrvd$m~Bf>{)WUJfKXsr3ro{=y%vZuD@-wM5i zStyu0R&u;Bfn$j@A>TcwKk|cw6?-l?=v1qj9vH(8`lipZ1+ME#JXKd|d{7IzgjioB7 zR3()r(#Bu!IHa>*5lqGoqJFA51mBgM*}c62R57Ve7GKtCjWsbeKO8r3f+_VJz_ z>vY!hF!0%b;GtL8^S9LwIdB@LN6HJPUaf?vHN5};yCxkuIDzx7L28CtS23m(6IJhg zJj%LoA|A0I8u2@ff49u#&{H_@Bo3stMMPjP-fv}D;VjeUm@u=gfgVtpzel( zUDezVw2OTaxWpdmnr+2$tlpewv&`<2p~Uev-MAn9DxK+@_XmWtvNC*V@M{ZsNv&wc_Kn zF{@fRZyoJW*J$lD-cJ20>UZY!*HV82DYuqwPuGZ4LUe%M8TSxtSq|NnYbA#r6HqVqd+9#=AqWZMbEOnFGsP&PoO=MFO&D~5k zD5tp?@KpwGuFH5#Z6>A`$=EYyS6k<;S&wa*X8!f!CCe|@GNbaKHoYsPYwGSqY%;{P zLy-%ScuM3wYGnhW*71m=nQZY}xKBLeXl4QNsw2P#Q~&L#V0Isk@J3Ny*z4<~reTYP zlHmz%l8K<(2)y`sK#Ujmvwh<0g+r`IytuS+w=BF1+IB-5 zb_bS$uvgr4)v-^BpSpS+JwzbJ4q+=kz*@v7iff%4z;iF4TbwIy-?AM|J76cE1h9+1 zu%1dJqI@qkzol>pGR1q*0NC|uEM3ev)R3pwgBv#AWn!Bc zEbC^c#f7p!E$lb)Lec15>&CQh@%^#}HX+_D>pm*g>?5kbfbYlP0l+~35|AT-%~c#i zYXr~@I00C({*&kePKi)?YpEQNG?+ntx>5eb9y3S`TO_H)baNqj(#-~o8|<8pfR=GU ze~nUoYH~8clbRZwpqjoD3x=2zZiD5Z49a zSkq;NIbx~e3*xmkUu0nsukyEz|34zeB2g_XhsTI(PP|mr#d=bAs-9$a5cq_6qI%GE zgqr?*9tR~MeqFt{Rz_vXDqHv^Vz@4b+}8@ESC9o{OI7N9_YJl&0U=BZ@jG}JvQz@Y zK}(@U=$c`VYsqLLEXDA+_(82_yG$fI*Yv4ql0$-=uUn}_{!3>^c~Fb%Q(Oz4ol3xq zB#_S&$2Uc_=fMV;0&Ur^Jl*=;McRf(#h-fCv5n#d&wY+7${15!^Da?RH#e(Qs70D> z%z`qPtrV46DiymdbxoF9okOk4Qr$V!wOMLS4z)TRE zTWyw^DrMFPPnKGrL#?A)SbuuEIAX0RYsi$sQSS=X=B4pnsL#GkeQqSJcFmU7=p&6y zEBv#KSt;wJ#uZMgy;*CTAw!j?30b|4WV8^amDLg#a%2N~S ztm+0**L_8~z(#wHDgG|e<^9P%L^1y~U@hP?fX4uj13nAb4d@^UI|wo#;+%q1`Q7tO zQT~jH*+66JL0^FNC+jmTR|_vHj}IuyMV4&L&~D~s4tl0sv|m($nUGg5DyLg%vujF; zSeap;w)m~7A2+^jJ7zKR&S=v{v8s(l;*t0`C3r~J{cDUuJxO&&KOad>@HI4VRsQOe z(MXa%ih(NtFF+m(JB7#Z*=*RT#%bJe1cM|u84U8v;K0faS5O-t503HBcub2Y`R9n{ zcbW%NpYZvs?WTXk7Qc79Q4lmu3I=s2F`@>T-<)~0e4dCiE*z4b8C8ExB>h!_KZtAo zuXeoaa9zz`a#Y_q_Lr55j_TJOeYYEXuUKDmG`#Nd{=KJj$Rt;baEmQH|*1)_!&**yTw1Yw|1W;Ccn+x<&_PV+lpQG7aDov zT2j`fwDZK)j)qxza-1Xvj*Ryg@_w|x1bB+TaAc}9m!+^^ayo5>89>dG2S^Z8d` z6Uyq!-tz@?u>_+4=TIaWNyO#pW!R&M@p0O5o2s3f8uz=*b$t{3SQmc=@NIxhj<2I7 zQ{o#61wDUUJl5Sw*Q;CI>)5@i+ue1HjQgmkhTRW8&*Xd8V=Z2CxU^GRTm~63{G=<* z%Z*{-lerfMBcDPi$%Da}qI8tVUQ8tJNznc1?R&PAoq(L&8<+_6c|7MS19hmFQ(iAy zd&7F|+>IlPB@K&?2Hqpy+q`)oeQS{h}DH<6ed$~snl;bw;TSI-lD6~ngK5*N8dm%ds>_s7@*wv&cFu7ekR`B^@4p1 z7_W#Ych?=*hNcS|@=PHh7)6sjaas!}g9wbf?xOq)G(J;qW=3vVeqOLWoR*#3bCbOy ze1pCwQw!w30r}~t1mtJaO=yFC>}B!P;Jq{x!TsC8GFFe0MGHn%;lBicAkPB`5%oiE zTH5BJ7WQ)y917FS9}hh>B!eK&d|F%u|APeSMH%c24^sE;mEZxAE_3u$GB4JDC!XH- zJu^|QhBZ!`WLW8n&N)OH_H&`=6y3g8Z>trP(-DQ{8)9L9Aal{K67TLG+?qD;Jrcuz z4Ujgj62$#0CP9vL|C>TR;G;!eKJXXAKf_Gi!aiU-$U`d;Dr<_4(N!W1hdz-wj|*=m zOw-+W#KQ-7kytz}-#WOlOa@QxWYI8O!`>5H2vPOiB0fCTkxsQ`(qvc?y37oE#OP{- z^Pj9%FG>#u*l)zvLv2z|qqur#U8b!39L&WZoAJ{_9?!q7)KR3xg{v2y+Obp;Sabv^ zDPV5x$avcyFcmf%PI}e_&3d9|f()Z8LH3=IYPKw19)TAzpB-+hmJ4C#fpXWX`w!P! z-e=;0!?o#U=hVXEQ2Mcr6K@~(SUzCl!^3X*QVmOlANfTI9Azy^34 zkOI5__#T1bprS!nxa2hNn+5SDfD8)kQ@Svrg?pJqm%$47D-0~<(e-d%c|+Vh=AGSP>$>eKUAEERWxKMb?#A(jo@a^| zoBEdOHZ4_dUe3pWL#b(8X!>H^ashgUO0{<(@A{=>CwfInUGu^NOP=m!7rMntoo~4W ztx~1TePiuH#X@+YddVGFDs5XX1HD`+EdG53TDvTYIC$UJQr_c_SX}?5*lkCd`P0MY z)bsZb+h-TaTBAsxIz=f-6+FSGWt@%Bjd?#-bO3M=FboI-R06|!3|I7{=0kb}WII5{ zMm}0600=D8KMqP$4#=m1r0*p9Bg%hR#HEL}nZMUKQa^fVuf>Uy^_xG^$A2rzLf!E~ zOhXCd@?6U^;{sOmB?8Kl0&qxzx_Il;%E+7DUr;6-7`Zb%%cR}PkHL~8 znDcQ(rbib4PmpA_ZvnlC%6T+$s#C6*hs9p?-MX5|$Ydv7@9D6LhoYTR$w*Z1j3rbp zs`EHiqRL+>8wAG3hHW)Zx-@?*2)%CIB&j%u*Xx$I+FA z;u2c(0A!5mZ1{)Yhc1?w8$Q)U{J_yq)=fpV?YxzS>7Sy1S5%Jeas0kWVf}9_+rIYT c7^}EbKVoA?*`l-Ijv`xkPKo*P6Y_BVUp|g_c>n+a diff --git a/venv/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-312.pyc index 02c57148fbc5a3e37ecd0ed55cbcc0ac824650f7..11280768e786f08a1210d2ecdee14fc3a7e12c24 100644 GIT binary patch delta 535 zcmZ9JJ4gdT5Qb;>p2=~E;wy!Ph#-fZbx^eM0b=2!Ig4;+H!37K**lA*iJ+E(a)nkF zb`l#~D|=fDNhMm@bM$1g=^$omBlXz2u9D zuy)8VcOHg5<)%YgDdvS=uD<|5wi=tXPkBm9<!r=Jv>YF`qviAB<()Q`980mGc zJDSL%X<7Zp;DL}g76ZK+F)S%*8AbXr^A(>Rm6!RP$f1{?5X_>q6+%c%HKKlHfK0w; d7LTo12WnkRy^yhQYLQGEP&x|GTr6#J=r1BDao+#{ delta 652 zcmZ`#J!>055S`iEy$|`M^M{P=V3HIu<_Ne-mDYtxNQAJvYp&3q5<}u*B^NRW5=4ay zrwCUF+!)-M{DkBO1o8(GLBQC5;A92TX6B^pl7V^i-tNrJyPY~8yw>+>wE`61zFc%} z1;8DPGUS5Ho)8&>h6vt(#w(0az&>a(0&RV!DUL|=WvD*&zT$PZhfiDW`SBe6g_u1f zGKK^qq^}8$k(J0uX_464qLh@1(x!B@+wrwGl9AJQ!%FrG2Lp@74cjt`!Des>Cbmg> zC+4`>=A$y$8Bfe!5{x0m6yov@Qb7t!nOdY4e*%z7Qao8isz?=Y@tk!ZLTnoD4eg2S zCht1tf3~{p=5Z0(PjS$ixN&@ReAJ8M)8MfEHhG`ymIrIp+1()+LcR*JYK81Xyc(Dqv1>2^6;oyKO5kVjz9tyKR0!qfF05<~U*ytPn>Q=7%Q6rR}~uh&_}@!BCx`3bg!V)hWLNN}K31QZBAssfZ&iWVfZ&5YeG>s|A9 zqmo`yiE=?gGz=2A9=M?(F1}YBkvJfrs;Ui@5S%z5HBn@*L{|s|KXNvh;GT%7IB=^k$lg1a^7pkPJ;~2;B<|$f_Y*E-YMoI;% zNOKaEMV%h;hdNWzQdZxP_Eq6KvZ5@s4}0_l9zpokEyt_sTl}(9!vQcuP#?c#d}Pc{ zBll+VsWb~9OD~1l1+eu$Vu6?SeCf6S=W8f^%@=gr`d;6xx#Jt<6Xt@)Q30q>4D(dH@D2!E_H$ll@BU7>$#!|hHqePU#k``5u zcXYS>@D#d=0$3qNO;Ul-dZ$q9oB9fWR||KQ zujyCaliNTscmW}w>Ggs*PO=~ilQ`}5a&bOMqTDH--B4v05($q}_DO;l5x!(VJAe*B zbpj0}=_d#uvVCEc>_2VhK7HktU+S~h-rTADB#z%cVxrdgU`_w(uITl~;+diu_3@6u zgSh17C>adGcmQ)~!7{n3cz;oNzB>vaRfUSVbN}a1DUeLLm2HivOz0bp_NUF++AxtS zO1s5Xfu(t~wOyvf`B6CP;tityaS(Mkvk@_4Q`k+qanETzl*$KlZl~ UasC{?%ZlZm$&C5^16MKPKWK6n*Z=?k delta 1267 zcmaJ=O=w(I6u$TU&wDeO$;^~YQW_^}GCY4$i%`&34YZ~PG+HWD9@23-_s(RRH}j_V zy--pD%_55uqEPOl;zkfRA*hRh8`py3LhDLiHbPhK#s*pt1kbrMX}j{mJNNs}J%9I{ z`yS5yUaS3*%ee&BPd|Lodag*weI!TA7=gpD@6_7wbPGX&5{+; z8o5B2y+xR_r;T*wb?RsSLb5Dv`q8cCP(PHJ5joreaF=irP(}ic(Liq#rhP>NgPTm} z7PlwCf*FsI$sJ}f(sCf3u{R16Wd6t20o%-$Zv-xba4n6wTSnk9kK4dU30elrf;PME z_&GVH-Sn~$S>#ZR?SH9lYh@3xpHJO5X^14g(MeW>E#EMwsU<%)-+$U(es6wDCndLj zy|vstYA6Nm@mctbQ-E;XY*pC75~=gUp(Q zs<(|#bE39?%091Gg%4If6%KA%s?EQW>T4p5u{6vkrMpO1W$M1nRI^ObLytP$e#q-! zs2s%Z-maUVsxBdMD^f zx$XIuy6A-b&Yh6Id9(Dr{fC}KX>I@C?1$7kiJ|iHlwFpqV?V!j8tIcF%YRMqMxTr$pIq&MV``43LlKnH!$<3y;};Tx(hsL~*88+g$%afIe2}~v429X+9qbL+}$X`Tp2E`(X zT_P~K8nD10Sc!1}@h*rh^0%Rx&I5;xzqYv~KN~;ys$x0a9hG%qg~0}wp!otJihBX0#OqtxU!)(wmtlg-&)@Nwxf+J0gH5=BBlH2`RC B4G#bS delta 49 zcmZ3>x0a9hG%qg~0}!0pJu9tvBX0#Oqr~Jk)(wnolg-&)@UiJK+J0gH5=BBlH2_>t B45|PC diff --git a/venv/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-312.pyc index 6991512948303a07c9ebc05fbc1824b054e558e8..3bd9fc4515ae0a9e4e3199ebf7f2c3c2aff41ddb 100644 GIT binary patch delta 84 zcmX@3c1Df&G%qg~0}wp!otL(LBd;t6qx5ENj&>$SugROa-Y|wtUckMX(PeW8&tWFU lh|LoG#~B$5CqEFl&B(NQk6Fs1^{I$80!E4 delta 84 zcmX@3c1Df&G%qg~0}!0pJu7X)MqXJCMw!jp9PLbu-jg?Tyk25kBO@1J7n~`Pn9>GRN{sKlul}`*HvPcPN3;=4t83h0U diff --git a/venv/Lib/site-packages/pip/_internal/models/__pycache__/wheel.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/models/__pycache__/wheel.cpython-312.pyc index c1d583d0428d9fb018c19c718e3f52af952ea6cb..a86b0f286753aa51c2747d9fa75ea7421e190adc 100644 GIT binary patch delta 87 zcmZqEZPVpF&CAQh00fVF=cNg5@@6yF@i-onJFKlwIi9i#5%D6Sx8M*GQYd6zR9 rZVu(+W?>AOoG3Jt(RuT4p)f|qh{-`BCmDG+%ZPe1GIC5#6H@>HBN!LU delta 87 zcmZqEZPVpF&CAQh00bv?&q@>6$m_w*D7HC_y@iQUZ}M% 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/venv/Lib/site-packages/pip/_internal/models/direct_url.py b/venv/Lib/site-packages/pip/_internal/models/direct_url.py index 0af884b..fc5ec8d 100644 --- a/venv/Lib/site-packages/pip/_internal/models/direct_url.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/models/link.py b/venv/Lib/site-packages/pip/_internal/models/link.py index 73041b8..2f41f2f 100644 --- a/venv/Lib/site-packages/pip/_internal/models/link.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/models/scheme.py b/venv/Lib/site-packages/pip/_internal/models/scheme.py index f51190a..06a9a55 100644 --- a/venv/Lib/site-packages/pip/_internal/models/scheme.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/models/search_scope.py b/venv/Lib/site-packages/pip/_internal/models/search_scope.py index fe61e81..ee7bc86 100644 --- a/venv/Lib/site-packages/pip/_internal/models/search_scope.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/models/selection_prefs.py b/venv/Lib/site-packages/pip/_internal/models/selection_prefs.py index 977bc4c..e9b50aa 100644 --- a/venv/Lib/site-packages/pip/_internal/models/selection_prefs.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/models/target_python.py b/venv/Lib/site-packages/pip/_internal/models/target_python.py index 67ea5da..88925a9 100644 --- a/venv/Lib/site-packages/pip/_internal/models/target_python.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/models/wheel.py b/venv/Lib/site-packages/pip/_internal/models/wheel.py index a5dc12b..36d4d2e 100644 --- a/venv/Lib/site-packages/pip/_internal/models/wheel.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-312.pyc index fbcc8583d87a35d77a734d7b081103bbe9368da0..b328ff34d5cd4fd6a87de235a5eda450ca2c6e6c 100644 GIT binary patch delta 19 Zcmeys_<@o8G%qg~0}wp!oi~yDDF8g625bNT delta 19 Zcmeys_<@o8G%qg~0}!0pJ!>NOQvf{F273Si diff --git a/venv/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-312.pyc index 9e00a899be2357307c24965450bdbc29beed3d8d..50145824b539a7c981d67960978c7ac715bea235 100644 GIT binary patch delta 2157 zcmZvdeM}Tr5WsKl_KrK?L=Hg?6yeSaO8|ufg&4lXL{WmAAE{7MdK@cK@a}wj)M`u7 z#>SYcv7JOpA+}PR7{Bcr)26mHP3%XETA?wxwF)+AZPGMU8~aBa(>HI6kj4%CZgytg zdo%Oqy}fe+^b_E`;&jHE`18~L!<$OZIX{pfTRSJIFtdm&)fkSQrU{!VBMU#V`%tlM zoUw!qR$&;e_v2T#att9SONUq>k-PRRuZ&#RZZBtsi+gUaGoDuMAN1bNK z77p>M5^aeDRCQaJwXvtha&?9bLHuh*Wt zO4-Z`$YC{yYUY?svJ!t!%mjuBuDwu*{jO5z#$ngM)9bM-X#u>Z9ZM=R^Ca&j*TA#5 zAjO;OrgyQ$lhP%zx4$W|lEsem%b zkpdDeNRj-vxeX$eG`G`+WPK6y-A$GeS26B$XBSLW*hAwh3GoCsVIhI~oz)W>sGDO~ zkw|FA$8HT)X&KycJZj{(9UF3ZWwnD)+<|Lgcl+?V5laXgc=2l{Y{EW;oM#MAPU zj3a#5WH)uv6w|xOaDRjax$10@@D{^ctV$!<5PqCn4v)1*xd&nXAZbK7dr1;UZ6`^h z>^&s);qg2Vyp31$>cFa{<%g}#<6JLW7&RBq_fSy;sxij576!1%R|E%ezpuu2ij1f6 zrmq&#wansbuzgONFSPa&yQM@dw44+d2`<7h4mrW-pG%}L29Pv|Z~>2&ehI6!_OcmL z*0-cN%pp6bjWGPkbQuqoZ-w2Oz2YXoHN0E72(IJIs#S0vpR3v;UEn_WxFSWnS7nAQ zQJiEN_91}+VJRGw-FyM9%YtxO>sZzdX~J3fiQ>uRJc}@dcWc^VL|d^Oq~6bHxWx!u z987Tzu8`jiGNtKpYBUh-R$J)U80(6hL<(XJjhxSO==N^b6$vm^VWXs@;MscwDge7p zNaxUFg5gk92}N}ae!VgihVlN&3fBQ{;q59epC8Hf4wlx=v0WzdIyTjMU<7+==fiDn zsJ6!pW0+Z2R6b7Dsc!h0UMVu3(zJ=VLbY%_In%%JmmQh-R!(yKwg3yYghMUGiwe`V zvvnbJ!&JFM>`#`^rH;_1uyLM6_EYturqmtE%Rwa)?FfftY5M9ITH}WM{CK1#s)3i3 zmLOBwc=8>AF4c?LnydWm?`lZyE#`9=cSkHqPwo@l9%12#!lK*7H;GYrx{cp?QH2@% zA?_N{3>Rsn*d8ZI*9bES-xI{9+$JfJU?+?as2pZ?UtCZ9q#%rG#r}s-MxtE8#6|Zy z*%}GE3C)B(guNVkJm3AUj@AOB12pZ0b*rI3>`f2((9Rnf(8VM^K;jxSGNp@%_2aGe qbNP4CWa57&mExVS0Kgw+38aVdn6RNWb}hW){nHc&YXP@!Q2qt~Y7-{_ delta 2185 zcmZvddrXs86u^7hueA>fLV4B)k1F&d$b?FS4WuC3L`e{Z#i7m>`iW?z^?qd!)aho_ z&40w5KO_Q^$zq~zPWQR6Y;$vuI5RaeohEcqnSX3E*&jGGaZ8-L=XN|aHt_4Y=bm%! zx#ymH8#x9yj)DEW-EP(K&$%xStSvif@0TE3J1MCUTfmj0Mvm>eVY3Yf%pPnpt*{hv z4V%k>7fn^*!T37IHaF=AdHi49z_C*|B+0|^Nmrz#VWVS255|~2$B2%9oiKmqIB6H+ z8TYy3pDOGBBK4?2XG#=yBc?H_&lUBEI-W6z(K%_t{tm@uv$gIiu>j?G)LfBRNEt{R z8T`YtxxhU5(41qcB(VhZEKclPY6Ka}<5HvPTj$dh;c0x!vI^#7-;}ie`xXlMx3vV8 zXdc^bNGj(B5mO-8(xR}4(XTYMx3Eequ!mr&cF3-W9AOZnD&aLDpQ^qZWPbLN&=C>BT?eGhh?i z6W)PB+@DYkVH`~8esV#!IkI7^cGyv(=X)GZS_ms}R2&@M8j5+;}YU9t+G zoYrVOG5<=!Gq@`)hw5w-bdtdb8gu1i zt?uQjjv4r7P9h$3TVNQExOYPr7RWO6;sZGs?%*ytQwnf1?1?YPlz|=M@>o-m{*k7N zI^9Eeu9_nD-xjqNNsuS&$4_$0;DI)h+X=IJN%It8JE4m3CPCEw4U)R>gS;$2{2{Lf zBrS1H&}cu#^|FCckFm|zSr`H@f@c}@V7;dh_Tp~OLep`Y{1^v4)!@{e^D4mfHEGUh zz9O@sNG$X$DNYj-2uC>NxM(MRLyD*aNz(}f_+Ih1uvqhz#7dbzlI9?XY?{Lxk+DiQ&h8w5CnJexhi7e4dTRj!3O-YlBSOZc&5rq(x6g zEXr%mN+{eKY?GzOmW>#jnc`O;yHdCLy>Vhs?NrFZk7_T9YamZ&>9lGFA(K#q`<6O3 zdbt=ehgdMAu<+~R7m-n-5fgu+!U~I?PZ~Lh<~U7~I4(O$mk3h{R|(>fu9Fl`FcYZ0 zj4Hxzi&yIaiG-V4e%&aPkSG_id8FP!5HHnEl2#MmChXye#PDVav^M2O8{(AKxO@rt z#p#H9I*kn71bVo{?~!;NqgR>UC$TJ>Mbd0SHpf5a(v3lXdq7#h^q|x6Kb?AwW5fUe Zck~iSqgJ#uG?`<%Tz7Rgh{5&-O(tRw(Pj0S!H diff --git a/venv/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-312.pyc index 452413628b08953654269bc7353e5a95c7513279..b2778c28555de7d1655538328ab87443761cea45 100644 GIT binary patch delta 131 zcmV-}0DS-3Lft|Q%MA?*00000Y6&b@1E z?wVkv*7*@ogj!0N;6RWn9%>_G5GvbNq6iu_AV5%2H=%8|g|svkq~V82Dw2|@^qg78 zYSUiZ-~G;a&YYP!Gk3;sKSq8ki0568r$B+{uiyXS1wSbfT+95iOQ) zFZIIPW*m7gvS3!zYNCK?H)_lP4VXb1ly;sGGQ+f1a)(i8*3){kfi_6n33h}wO71e6 z%qWeT8r7toZ>%?)X|v=7#s;&6wn*+aTFo}vCV8RJZg$WP;0r|e7`K?6v{O2YjE&|d zx=He4<5n|9W0HG~&E^)mMRK39)$F2Ol9w3WW)JO=ywvD5`)HrpPy40qH@2Arbbu(V zgcrgD%Z#`=NC%~_+!!*4=`c}ts0wpVKY}Iu?}v>pk(@%evnsX&ekxcsyN&IbR4c)O zf0H&udOPIsP9GPEuF{@$tnG!0B{kQQC{v1F`7EJdW9962jAdhbRX4o#YPwUeVY?<( zJ#ffQ?}QAt=^tZ;h2RUJ8$Ck=^rnXo*_Uz&6?&Jdj3|2TAw{oa4NJD1O!r8&9@K^# zebaHNML=t0Q?0ZDoP! zm&G&PrJfsuq4TQNmMOPAYbX1~E6)8y7ZF#z_X3tvBUz`JxZg@Xz%rw*ovz|x5VOws z&iVAdnG}zU6JA5*eWJ|QPmYLjUx>uTeZJP}T@c2xaQsdH3sZ&pX0-1Tzx35sA49qa zp$8yqGm`ga?En*eOkDFlN%}I6muSR2h7mD@xOk_ut>hjIF0fcyXOoFJBh9}h3j8O6 zGbrcjbLOn2xp@lX(+Il}#>D&nM)D2ug+EG?B2*Uf9R(SKtfNqZgUU)_W>497?J(^# zm7B=ZnS!b_giMHY)r%rr=n@Mx9i%|~q~_bAEbv~H9QYHMS4Vgf;W)xm;#wf-_yDL? zC8mRKkwI}wXlv|r-N5N}@xy~Z7(G0?5>&kY!|rPO@;8)7xwaTg5{2`C+ z)cS1|LoVB!uDl_S_)%z_To>0vIyoQ`;iiH`>;vJ9cr5&LvY6Rk`=Ux*;!1rikN1Nv zVhyjYL&D!fz}jne{uc5D;f^%9`;kiDuf=k-lDseOj{}%mY?iX*mE9Vzz)^~xi2|>+}i4Xgv)Vt`+kOzZ_536 zOe}9(M{MH4w*79|HXnVP9j`Iz>StI+>P6cjq&7EGR2Fq zn<{ihk@=C~F#i7@{{%eH#>^B9XNsRdeIvpw!Xbo*5G;Uf;T$*Mly03( zaEoz2G|#$L3vOi{>3MNtFh=Gx=LYKt8OW%^9s;+5ccjmYYr|!QmND4|v3I0$0RHDt zco*6y5qbf#`39fcJCT^!$M{hc<+*nXncV5;F~+%@SymFRpHIX~BZ1H;q=8?>dKhrU zMhLm2s>FWTrI6A;DqivF$loH0T6VDV_r$+U{7>vULqaR+y@WU(jbBpmec7g{;T2VU HFlzl9h%<2z delta 2230 zcmZvddu&rx9LMju?Yi#KwR_aD(zV^zuDfGT7<5ebD0?ylHbDbNBdNQ0vT<)W&+UAm zf(e?C_{5(mU`z~u_{h{mubL=I7V&|KM#YHMC@LWVg@iDT;QRbe5hK{GpMHPe-|zfR z&$;K`z69jJL&Wug%atqf*MYseM{~Ek%H$v9?KNXX1u9Wx-A)24fjLc0B_$QB~; z(5}xl{M2uh({d4K=>a21Lqa?B3Zs%%8dbDP#MwL!(}>Vcz1oP%}vC&4`gf7xAHCmSe59QuQt2pXyw?O7&|)qq16lmz@rC&HJhWuCJ7( zen}19C8;5;YTB0RL{|&9g1eRfbf;^CSH-=swnmFg+a+l&mea6EM0lc_CqkGIeo**P z?$>DH3$3pbuEO0~EqKAbTDbGLTc`QQpNE967}{;lthKkwO1(8`+hZr=a4LHv8G&`q zD(hb7kkj46XGv#w58ayDFp*?&_|c=wCkU)7>>>}q?!q96!)t{NfmOVW;V!UY4imRI z#9A?4%>lO+2IlU-XbqyBBW=^iu20)JM%W7IEZRketS^fclD7gYVu(1nN*ard#lM>X!F*P4KU)36au%g$b6XZ z{+-h4Tx*wivz;$=j&C8^W3BXkMu-Yk{zvR;?lghD{us%FS^ss8w0$Zy+6u$v2YruV z>qikIh@FUCh}{qij5!W*Y5L*Gz`JA+lEJpcGnXBz95__EY+KI*1KS2p2P99)w!Gg? zD_J>%`K9u~0NuY#riL zI2d|`?69_0JSP(eG>2n3>1-o$i#fJQ10(!K=|TKHA0qH#D0cQP>dg?3MDza5eFUfC zW#nVHFH%q3us8B3*Q=`=gyYVkC->S=PKp!cWf8x<1bdw0}VSh&X92uHPq2(AZq=ySP8*u^T%Dqs#<0~Pa>0;oYaykJB#Cjh+jCA z>`WsZ%p}}^S#Y%Zq^uczzZEE!~^eiyhZj|_jFdvF>$Z$ z#;LN{X8bxA40ZrRyekz)=3DSzsPpIX6daES$}qR7XlQJ5wPu=Q6Uhdq-8iM0DFVTz z8+$|}ar!>xb!qqd^@(J1B9%z-N^|{sX2*mx0USCt_W%F@ diff --git a/venv/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-312.pyc index 60fa2687ca22207500732bdee8b19418b7befc6f..9b31e04a9e2ed784ffbba1901409b9e60ab7f601 100644 GIT binary patch delta 20 acmdllxL=U_G%qg~0}wp!owt#D3kLu`ECwL} delta 20 acmdllxL=U_G%qg~0}!0pJ!>QP77hSDZw4>` diff --git a/venv/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-312.pyc index 8e967f7e779e0e026d7396c141d2cf9e30027fb9..ddac780e32bf4a255c51d543e362f55902c2cb32 100644 GIT binary patch delta 20 acmew^_FatoG%qg~0}wp!owt!YhZ_J!qXt$0 delta 20 acmew^_FatoG%qg~0}!0pJ!>O(4mSWs<_2W| diff --git a/venv/Lib/site-packages/pip/_internal/network/auth.py b/venv/Lib/site-packages/pip/_internal/network/auth.py index 94a82fa..4705b55 100644 --- a/venv/Lib/site-packages/pip/_internal/network/auth.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/network/download.py b/venv/Lib/site-packages/pip/_internal/network/download.py index d1d4354..032fdd0 100644 --- a/venv/Lib/site-packages/pip/_internal/network/download.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/network/session.py b/venv/Lib/site-packages/pip/_internal/network/session.py index f17efc5..1765b4f 100644 --- a/venv/Lib/site-packages/pip/_internal/network/session.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-312.pyc index ad3244a9fed0b6438bdc887c9f95138680bcafb3..9537a0480d6d8b325b7b8c29a2148a2ae422a5a4 100644 GIT binary patch delta 19 ZcmdnaxSf&vG%qg~0}wp!oi~wt4FEJ_1;GFS delta 19 ZcmdnaxSf&vG%qg~0}!0pJ!>NO8UQqx1<(Kh diff --git a/venv/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-312.pyc index 44f9a903be2690a26e0dd21b0b00fd01d01e8b44..aa36d3b7f8bd97ce65a95d17e6d031c5e7c2ec03 100644 GIT binary patch delta 1540 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 diff --git a/venv/Lib/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-312.pyc index 69b07164614478c121e8f7e7f205c88d58ff1fcd..e2548f70ad1bfbd559b8208be665936e58892c2b 100644 GIT binary patch delta 403 zcmezFx80xjG%qg~0}wp!otM_Jk@puP2cKtNSz=CR%4QCx_k!$`fO69rI48#|=}-0+ z;i*?A>rT|2AiscVfz1NF3;c!`I1GP$;bh>E`ozG* zYW_e-3@XpOz~#D%$wd{D3(BS!_{}bHn0;UcD)?2*4>Y)mN1kE6iX$8IK~_c}nal`r zKA7YLlFSU7y+jwYF~&`PCq0jG?&e;ZMa+y3HXA7TG6Kcw6r&j5Zoa8Ffsygw7~J0`-;Xmmlz=mP_g-cbA*M12sM9IUPa0PHMjegFUf delta 308 zcmdn)|J{%GG%qg~0}!0pJu59@BkwOpM)uA8Oz#Dm>KG>Xi^?dJFoR@4poX!81;S!r zSj_}s6$wtx5s~0ZVXR@C%`lfam;uDKNnwIs+}%quQQ%u7x!;sF|Ui=!y9JU%ZmH+AxH5f=}8pil$D4Po)=HWO_ceD1IdPS9Dx zeuZ7*hLG5F-HEyrZDe&I@>E)Lr1#yTGDXBo8!W zbGhg?HpckLdNT7EXKg+!vxu4T?&bmoUq+zVKE)`;SDPi3CNMJop1ewV3*(*5@hXu_ hjE0kUsvQ$yVbs5%Wb}anNN*_q45B{pO`fc-0svo{T{r*$ diff --git a/venv/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-312.pyc index 83e435ba8107ef814aead7bb40aff7fe1b7cf027..6a37c67e6c2f73aa5e0d678fb339e1a95c0dfeb3 100644 GIT binary patch delta 4648 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 diff --git a/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-312.pyc index dd7fde3f79f17ac362738f455c3fb2d4090e24d1..fc31af615b5b33d53c3f73bb4151897e716ac3a3 100644 GIT binary patch delta 19 ZcmdnXxR;UpG%qg~0}wp!oi~wt696?q1=9ck delta 19 ZcmdnXxR;UpG%qg~0}!0pJ!>NOCIB^c1>yhz diff --git a/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/build_tracker.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/build_tracker.cpython-312.pyc index 9df515810e7eaaddb5c1d5f9b6aefab086e023e6..769bce65fc2eefef836afe717f0aaaa2eb717294 100644 GIT binary patch delta 1601 zcmZ`(T}&KR6ux)<_J^7MVV7YSSa$iTuxQIlrAiCPZn14r>`U9!QWY2G0t?IR=I#>O zN>ees7}FSXO|+@~(Fb2h)MQ_pSfljShc+?33~6d=jPVWAH>1&e?rv!z@n-Vn%=w$| z%sKb03|$>Gel!d(;^)^ZH>ST_GosjB>pDJyk%cTJuP+$mhLF{~Z^1wA$4Ej%noB^$ z&O?IhxT+biCur?fIALidY`KWra!0vgTCqH<%6ctmyg~S6h21Ocl2!MN-IUN#Wa+EO zGDvt`u4Qf%S|8W?*QJ^+asej;f56L$BzBBbG&@Bmvs3e@E)+>pW%Ia2S3q{u({`?4 zS8m~93D>cQ@}}C#gM5|ml~EbDF~!}j1-OC+S)aQ%0YAl2irMlk1vf{_7iMM%bySN? zF3!+6TXDC?Vqgi*kn+UjVlHn@l=;W!38j0vzPs{+`(xYzF0}Uv^mC!4a#-cbM=8A0 zUbf`j!tu&%-3ZotK%=v-^l#$bASO8^B}XZd{4@n)3F=NHXpCJlI&p@5VZ4C***#-5 zw(U<}fgnr|f;%(?yow7EZ7e0<_Do?WZVlk-*cRI|~^i_Zn4kd*{ zf*+pXn7=b}9CQYU_t2J(JjO@*2l^Es?Psh0P3&jy1bX_!FYMwjjxtxs*;OubHTfv0 zwb^WGmRKd|X*KhmKo362eh;KMwPdhWaxnYT*Tl9Oylf#j*13%5H150WTtk+0S-pm? z%a^pWhdmDN>DqH%K8u!c2P%t+hJa2)WsJ@uTUkO?>$1c~Op~3iPjbTlYBBa%eTE%2 zL+Y|Lh!9J;5-x2SFQYk=wM9ZK6&k`(Rt!bihoSy@osRLOj#4NR+fgXVTFeP`?HvH6 zx zO1_&?GXs^I4XtGdc0Om%iz+Cv-p#bus47z+^0Z6;m71T zL6W!sKNGZ^Lb|7!K$GEcF}$Pn+91BmzKfjH#KkZwX0(V8h|6;hqToAE26daF>@3*f_*W6yy_0lcqrTB0wL&egM(BLm&+Sz|c__d$T!m?l6dg z2lStM0Ja&4VrVDVIlifaT_)$t3t2nMmj#8JPNx7~0uWV+g#c^>r2%%Y`Ef!R1jDFE zM2~R0M^#u#s+;3o2k$MXQiAEJSu(ZFwL@BupT3;R2^q5$Rp E0M+PL!vFvP delta 1637 zcmZ`(T})#|6uxtNds}F4|9_!Cp$N7h;I2Tj{78XaH-X?rFk*?qg*%i&dwX|UvMfT3 zit$ZD#uweVCaZ5eXwnyrF|s@v_rVwwH@O>)i800}G5cm>;+$z=7ZNAo>*1SozB%Wf zGxNdl8zag+MX49q`u3|2SAX4CqNroPbLxeHGvh>pCTLP#DY!B&Zd>#2f+yqQww(7C zd>J1SL;;KI9iVV_;lKf^GMOM2*1M_K;cvC!ux7`0tuD&8Rwb=|PdccDWg;hDOW@() z9-`)a%p)oa&k35cCulAlKCsl(8#wD`tmiZ;k@)jBukwT9w53F&f;I7<}CM_sI|FAtN`xrs| zG-&UQJDF)phFV@D;AYDCVm6D3Y1Q!ZW|p*4&ED430z2L;E-x-`=JMKNnPswp3F&2g zvhs=jeUtzf^7IJ|Fr#E;u*bwF$sp%xrv4bUR;CZ z1U5_X5#n*uLYI_wG(q21x@C}ALG-#iK<_CVO{an65=0|13~|sd2%B|vpsRG-l|X~^ zw(FHXFZVHRD|xKyn?_RN?qrP7Bn>dmpd>Mfv&96u-0f(ZUUP?-K-T>LdFg~Fb%B4n zB=a(*^=T>)BNQ%h@DD?wwcLLYllXpVm8Ni!j*w;3JNF7I_w6R9Bv#2rKp zIpBKTdeZe>x$K~a-X|P=Tb7rF8z>=^o%Gn-Lfbrk+U83Jp^$T{?59hj5Y;x|q+p5Js4_jC0U;c}&d|WK5rfqx1VP0Tx*|_vDW}bPK zexnnCQGa;gerWiI(C`-#9jF*VxR$jXI_OU zIOk+6Pg6AOYnN>?r#(KMI}Od~O?sNC(tq>~`uxFAXasjxD0M7vQ1MuFBfb}eZ z3}C0R#>m2DFnJy@2*d$!nh`ICz|&~DR*HHVZf Z^eHu(qW01I!szcp>Sy|H(>oHR{~wLpWUBxG diff --git a/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-312.pyc index a7055d0336a86d3649724e3ee24681ea4ad2a255..c6365ee47ee45ae6279e53d16532d1ef15a68797 100644 GIT binary patch delta 20 acmX@bcZ!euG%qg~0}wp!owt$Oo*e)_cLlou delta 20 acmX@bcZ!euG%qg~0}!0pJ!>PkJv#tCx&_Jr diff --git a/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_editable.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_editable.cpython-312.pyc index d0a97ff7834aaed991c88949bdb7642617d80b4d..33fcc3aac2824380b3e3d7cf52596e21cd8af629 100644 GIT binary patch delta 20 acmaFE_lA%AG%qg~0}wp!owt!YksSa-#|9w) delta 20 acmaFE_lA%AG%qg~0}!0pJ!>O(B0B&?3I;F$ diff --git a/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-312.pyc index d7c9d8cd863d1fc550f5c43e43dbd4baad553bc6..212d4a632281804b9139185ab44438a97d0e99c6 100644 GIT binary patch delta 326 zcmaDYepHwbnUyC0W}e3-0pyATadGqH z#VmoGe3m;jcSv90ah=S_YQo0CvYy3>WwSM_DKn$+q(OuX zh>!&lia_EPOJY%aagi#B$(mYJlwVZL31ln4K#@2|Mld}!FSRJKBsD%awInemu_Uob zd-EF(T_!_ykTi2~Nl_8Vwp%Po`T03T+Cb(?hR;Bf0j&QQhfQvNN@-52U6IvfFYdW4 HmOvQ*#FIvE delta 319 zcmX>q{#u;(G%qg~0}!0pJu7Y6M&3V+j9Qbqm{#yhm9T?^K_G=Ci+i#(lZ@7CMuvt80sxfHImKleaS~v9qP+7v(0FOuoT9pGy)b zEDFTM?UNf>0(p6?uk$!vQP1$F>Jh6aBC diff --git a/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-312.pyc index 41352eb53f58a863fd0f93727f965474f72f6d49..975ca674eca197a7e59bd57a433caec34852ae2e 100644 GIT binary patch delta 417 zcmX>t*DS|-nwOW00SF%V&P#i`k@q4Cqu%8EEOLU{DU3Btvzbzu<}%l^*07c^PhQ6= zJ^3Yv?Bp0$USsAGPLL)Ls9{*m2w|nLWVwfM$5^U*(^nh zc!6q)KngWEZm|{T7nP)@Ojctr(^mlsDFAWtLLkw=@I{D$S9pSHw{L^%O>Ti30$M9f zR%l!>a=XCi-obo>gL|?7hxFv-z-Xv_L)&15`Uas7%#6IIADB0D zaBOB`QwJJXq%rv**H;BS5K{q2++xqkEG|jOEGh!os>xF%1(H#ne34sx@>_0cM%~Gr zJnoFs2NEk8io`)|Q6TY)!zMRBr8FniuE=q65Z_M#Usz;Z delta 542 zcmZpcJ1xh1nwOW00SHd)o|X1vBkx5P#<0ovS>)8sQW&$CK@zB-hG{h;M5LCrhP8xs zG9RlnHycb%7U$$Ota5IZOeNefp&AC5h7{&(7Y2qRvlJHW1_MzVMsCIGzo0NPM0X5xhmQvNVTty(4YjWOVE6y(}Nlm%M1~eo$v1IZMwlZy1pp*g- z7taO~4Gdp|78E7Obca=v12^ zGNJS`m+S}j%?H>wGqGs^^%rSQuH^bEtq)=<0*PDfIhn;JDVaq@AZs*vilip@af>S! zX@TUpz#fWEEJ`oF#Zz36nHQg%T3no%o?4_g`5?DDqs3-U9(_he#mSbu8`wbli!3I; N=aph~n#{%b696%eczOT; diff --git a/venv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py b/venv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py index 3791932..0ed8dd2 100644 --- a/venv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py b/venv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py index e60988d..c01dd1c 100644 --- a/venv/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py b/venv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py index c5f0492..3ee2a70 100644 --- a/venv/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/operations/check.py b/venv/Lib/site-packages/pip/_internal/operations/check.py index 90c6a58..623db76 100644 --- a/venv/Lib/site-packages/pip/_internal/operations/check.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/operations/freeze.py b/venv/Lib/site-packages/pip/_internal/operations/freeze.py index 3544568..bb1039f 100644 --- a/venv/Lib/site-packages/pip/_internal/operations/freeze.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-312.pyc index 3a78514c7728f36e22324ff9f6e7b37521c41fb3..9515ea87b8fc084451f026aebc6675d6cbd26bbe 100644 GIT binary patch delta 19 Zcmeyv_=l1EG%qg~0}wp!oi~yDBLF^J29N*% delta 19 Zcmeyv_=l1EG%qg~0}!0pJ!>NOM*u#M2A==` diff --git a/venv/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-312.pyc index 5bd8a21eb72c426fafa0f6f95dec70596ccae33d..f553875f6f0f174f42a45dbd6f00f1267c9ef75b 100644 GIT binary patch delta 53 zcmeC?>*eD;&CAQh00fVF=cO@k HVw(v7cRdY| delta 51 zcmeC>>*nJ<&CAQh00bv?&q`z3$h(?_k#F-(mKBVG3xR?km>C%vKQb{gvOH$sn_R*+ F698av4TAsx diff --git a/venv/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-312.pyc index 603da57f7625be101316114e3309f1031781b4e4..c1914cc657bcfbd7b3589f70fe953153d9b2cf75 100644 GIT binary patch delta 3661 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 XWL!YGGblHOv#y>VPvN{FFm>cVn?QCa diff --git a/venv/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py b/venv/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py index bebe24e..9aaa699 100644 --- a/venv/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py +++ b/venv/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py @@ -1,5 +1,6 @@ """Legacy editable installation process, i.e. `setup.py develop`. """ + import logging from typing import Optional, Sequence diff --git a/venv/Lib/site-packages/pip/_internal/operations/install/wheel.py b/venv/Lib/site-packages/pip/_internal/operations/install/wheel.py index f67180c..a02a193 100644 --- a/venv/Lib/site-packages/pip/_internal/operations/install/wheel.py +++ b/venv/Lib/site-packages/pip/_internal/operations/install/wheel.py @@ -28,6 +28,7 @@ List, NewType, Optional, + Protocol, Sequence, Set, Tuple, @@ -50,7 +51,7 @@ from pip._internal.models.direct_url import DIRECT_URL_METADATA_NAME, DirectUrl from pip._internal.models.scheme import SCHEME_KEYS, Scheme from pip._internal.utils.filesystem import adjacent_tmp_file, replace -from pip._internal.utils.misc import captured_stdout, ensure_dir, hash_file, partition +from pip._internal.utils.misc import StreamWrapper, ensure_dir, hash_file, partition from pip._internal.utils.unpacking import ( current_umask, is_within_directory, @@ -60,7 +61,6 @@ from pip._internal.utils.wheel import parse_wheel if TYPE_CHECKING: - from typing import Protocol class File(Protocol): src_record_path: "RecordPath" @@ -288,17 +288,15 @@ def get_console_script_specs(console: Dict[str, str]) -> 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/venv/Lib/site-packages/pip/_internal/operations/prepare.py b/venv/Lib/site-packages/pip/_internal/operations/prepare.py index 956717d..e6aa344 100644 --- a/venv/Lib/site-packages/pip/_internal/operations/prepare.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/req/__init__.py b/venv/Lib/site-packages/pip/_internal/req/__init__.py index 16de903..422d851 100644 --- a/venv/Lib/site-packages/pip/_internal/req/__init__.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-312.pyc index 6944b1178f3946db11dabc81f74d0a8fa6d2c3f0..dc5d6c554055b992864be02b674e9cbd5b6ba46e 100644 GIT binary patch delta 1005 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 diff --git a/venv/Lib/site-packages/pip/_internal/req/__pycache__/req_file.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/req/__pycache__/req_file.cpython-312.pyc index 8bab9a9182f5a48053371c15fd3ac7908ff14454..36cd9091c16eb1b3b6bd1e91b9bba545470b5a98 100644 GIT binary patch delta 5149 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 delta 5208 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 delta 2916 zcma(TTWk~A_1+oViC=LNCwAf_Wbz=aS#a1bBBV`HSOO`9r7GF(wpmd#cy64@j>qQC zn5XIFgifvTprYEZkoLKPpR0Tl_ULMk8d)tCB_g;kE@=kd%0=!Q1 zrTkNV8?VWaJgsi7^H6d$ip2T%IMS$op^Sw)`p{8{pG@sNBQ`WSz)+ zs2+u6C`rgBQ4-r7a#nsee*?%O_&kLbG$kmwk+tC)KBY+sTyab_<-}++dw?HcKg$Wd z06!5fe6t0>JbKc( z|5oDHGfOkS((m^^?i`&*w3YqDslV0+%S(bK8YZ-`EXQnG)uRG!<|2Hhri0ya_2V}7x$6XOz1Lp%Ei83& zo*oYRIAg_S{@)J(Y|XoS!s-I8}d=i?sH82i#a;2#7uDpnk2uX{QmqZ6J1+|6{)Mcm4sdOq6E4FHdAya{m2 zC1)~3SC%RPjsk5fz#n?Eg51LPp zB`T*DmJ#y9%d@ljeV{I)0-EL27oKr+?lXig;{u))Sx;kx-SfAcy)2kKQ2QweW_=Z} zHUJtjy;Yim3&JmuA`~z{@l&VbP@IbEcHOe0%z;r=wJ_`F7K&iS5QHm z<#~DG8Ar<%O0^*w_?ooMy4$wvv3>9sMDW39Q~aO0U-snMr~_Rq-f*BCiZ-0d@6D(g zX+}0AgJ@7sM3KxHB0=|(pf~A?Ocm);xnoIrhm@X{@~30cN!{j}&YD?D09B0|)10bl z(gh-^Nj*(L8)#NdNj3C6=9b1pF`de2s;rx_{09axr8JeY83lTtv{jOZWTq=#NzhKg zEn2ez{J?0+3Db5YBPTwPlSGoU<_s)>+_d_ky;AjE&!#RAs&>N>&O6>bSd6_9byzM+ zWFxIxUP>~WoUl8vZ) zzfiSUeuft@M%O|->vzOCT%`7i5G;>ssC)|O2|`^U1$~hBUdv&?IH^@PP|D5p__kRw zNzB-sO!c^C&!2cDR3i@C7U$yjG%{i%S{eqCF%}!CHenSN;pl`x>)+9r^XT)?VWiWrBkb%sGEKpT(Rnt#EdJ@Q>?m53g~x%PWg$Y{8C^wsV1TEnrA98 zik2wrIm=yhG3qF{bv_B{`&>u_emf7)Sj+Rw>U)KB=ihvlEh_HZqxZm|u>oKntp&rY z!NHZ_;B(aN4qZLA7HVJA7Br@>hW4$5_FbJ=542z3b93}b;Enah$kWL9!}lJZEFpXb z?^@f{bNxGj_PvEmqR@T}mpr)rEH1fFhqTt&`_HhiskszEZ5@k+;zEJ_a5X%%5*~US z9)6Aj{?L!b^aq^vM0= zfW3vcp(k+3DRxcZk`H&i%T0FouSo;{YWKH>o;gALvmS`X9>h`nPE_#F28i}dw3!aG zK(N2auNw4q4i0d@j~8`waFl~_4!*&`DF9YI%)ShvW{&dnNbUK+D}kN|uv8iM_65Yp zsT}YwYy1Jg74%GSIgjF7W(o1{eRC7O>`rhgR1!Q+&p+BEXW36%F51G9EwMfcPC*O~ zn69L0tlVr=JsGQ2k3n5*p`~Xx9~f5G|7Wh&W<9&t(pTicS=}}#OkYBES&L;&RWo8x zcJ}oT?ug~;g}ak^I-N`sN{6|WODq4_!4aU8?>9W)|JIMB(n?k%V>AQ5yd@bhW>87Q z82<$|Y@oisqOQN8k--f#yn%)Q+dzk&x+7P^tM15(J97Q-V|V|&>));!j6=^6hqm_r E0i7Z6mH+?% diff --git a/venv/Lib/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-312.pyc index f7f1ff8076d63591eea20d90ba893828c1c52edc..f6009fa2e1fbbb88140f47afd7554737932f4a43 100644 GIT binary patch delta 5579 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 delta 6124 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 vrPj;ti|W 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/venv/Lib/site-packages/pip/_internal/req/req_file.py b/venv/Lib/site-packages/pip/_internal/req/req_file.py index 1ef3d5e..53ad867 100644 --- a/venv/Lib/site-packages/pip/_internal/req/req_file.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/req/req_install.py b/venv/Lib/site-packages/pip/_internal/req/req_install.py index a65611c..2132785 100644 --- a/venv/Lib/site-packages/pip/_internal/req/req_install.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/req/req_set.py b/venv/Lib/site-packages/pip/_internal/req/req_set.py index bf36114..ec7a6e0 100644 --- a/venv/Lib/site-packages/pip/_internal/req/req_set.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/req/req_uninstall.py b/venv/Lib/site-packages/pip/_internal/req/req_uninstall.py index 707fde1..26df208 100644 --- a/venv/Lib/site-packages/pip/_internal/req/req_uninstall.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-312.pyc index 751a91e84173f7f0740ecdad853345654260a089..f6fb04d6d359e897996439a8455c903c906b7006 100644 GIT binary patch delta 19 ZcmdnaxSf&vG%qg~0}wp!oi~wt4FEJ_1;GFS delta 19 ZcmdnaxSf&vG%qg~0}!0pJ!>NO8UQqx1<(Kh diff --git a/venv/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-312.pyc index 4d09774be79cc9f3e819b69e3889f94c8e6b4c78..7a4acc37d5c4ea40a22e32cb9eb094569fe43c01 100644 GIT binary patch delta 20 acmbQtIhm9DG%qg~0}wp!owt#@g9QLKCO(2MYi;YXz79 diff --git a/venv/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-312.pyc index 5805230ad5ae7f6fe01f8af82dfe820e8aa2d2a5..893f05d9518e077805ec123bc1d4ae776cff090d 100644 GIT binary patch delta 19 ZcmdnTxQ~(hG%qg~0}wp!oi~wtGXOPa1=aun delta 19 ZcmdnTxQ~(hG%qg~0}!0pJ!>NOW&kys1?2z$ diff --git a/venv/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-312.pyc index 9780a65df20caff2549aea9514cdd2fe42e4839c..423a234425d0c6b64cddcb1a28add5ac730abc68 100644 GIT binary patch delta 2565 zcmZ8ieQZA4^!OSO$|)0kFidMquIm^yauOVVn) z()*or&pr2^dw=(w`!2ji?p`CdyV=G%JJ}Q)`2PuH<#U8$KAG=d)M=~o%y|${Ow8u)9ajlwfr64*C+9J zBtu_q`mb5P(o5YKhW0S%WiY@X$Y2YDtqdv{^utHF{rYZHA=}~2(QKNZHe(y~ID92- z%yB2eZ0>G3aWwWlnbw9v(Ref&3MJD&a`^RR9DeRf`Svi!XBdnlEZM1i?0A&QN91@i zl#r7&1YHIG28{s|I*6-{vH(j0U0HiJ=j$M=me&9Z{zk%(D(ucRqbrZ!@+St4JI|$b zuWrpte^%(@i@eDqv}-M5Na^sJjM`-hDIJjJyh6M^(dW6CJpcuwLYORGr>TyJ&?*(ppQ&FX~B#R8ltt+0OZ95=&%n|qE(w)EA~cX{H0!+wuv zHe0L=$EX~RoM2frE7XYb@DaK534tsA)1(-x0;5R#4+GB>e+MHj8ReNI4JT-bb8}62<{4GniyB1^w#|=4n^E7yGl~*Q~=WSAp?ev?c8D`*r_zJ;?Dc zGYBQF&0y=IR|a^LyuasvK$eE_$oy;`704g9}alnWlcFF?j13 zrg83ef_dz;VIF7O9@)~rEDw;{V}#2o{3l1u;$o5aCp%cSi%${`4Ea7^G+4mhEwB!j z^LNV#A|}n#iklm|aBwT_MBGC+BTD>APE*t=Bj61k)sD%|pU@$QB5i|zRBj{Lb7 z{JN@)jHN%X`bjAmW@6ZnZ68672_=UQ5vNe6bj_ODc1RI--E9AhB8(WN8xw+tvjV`#~=p!k3+<4Y8 zhSMh)Z)?p6zv);9H=B+VjUW3-VLKPmU0oeM1vSlw2oL9**YkQT6vp7E%@2tI?riKJ z#`M#TF`aI6JX|l#Pye7Ni+FX1 z@^I$=wUrDyLk<;y(vycStkTnO_j-6Tm0sB5BrTITgH9nx0^P;*Y6dX|tl;P3?SK1E64|)!ZGMX@7~nq$7=r859}d1wNa*$0 zPO|dI@!?2hg*c7J1L!Xq@r5`&RGF(0Wkic8u9EcLPzTutUkx3^;-4I@v}(tA2R*0^ z7lupM>fjHs_^T1u98km9{xhhpbQ%#)5e>rfWL^W$&3s)4l z+&bTPr8DEHSFOh&vRmAsjZE@_p+%`^Q#q73BFjvu4zod2qz;usc}u^{gzAFy?uM~4 zL#5(xQaO}2@|KxUhe(YfPw_RX9FwgB%S@`zl3m2$*7n8}+?%^v6*SevS!{|;%$R-4 zX3a1O9iv61Ea9}HNo1?kM?c2yk`OyOH5H9d(cyG*w1jWdl8qhz4UTI5ENz~cHXS({ zIUbWY)4yYvv6Watz~`TkM>-49FBif`W78Ak^AlJ0UF%oc1~W}Nl(HQe_fCa#;bXc^ zdL%RwQMlJ|pzERI9okT@i3Kn-=A_$Dy~Cq38YX*7ze zigr{heA1S-Ta}7`V61}4e~bx-`1=V(i8iLyrMN5a7)B5^&N=% zN1DS9cw^iKP4%|Ss39s|V_P`DVt7CdvA-L}G+CX#z`~KhlI%QPLC=84TxL0a#u;9X zI74B+B;~+ibJUpBFRs#~fe8H7{F%8Mb#&pUJcb(?5vS3+X&gxyNA71@ezx!Jed`?? z6Dd(+GN(jshF%r4FqS!2XBF17yq&@wtI69Y-YLoVHi~x|b&T)K>u(qDW>oYyiFccH z{q3=@GjD07KGaXW4Eh<2Fc@Yq$Y6*;4TAyreeNF6Sj+NXtZ_MhViX#!6%O`RI*xEE zcfYKxt{ju;PQO1C4n_R_6S1(>r6mX9VnMXx$4u}5gM$dk94f!|dWgzL<#5EW$PqdR zI}2USow%nM5u96tvI~+1n$~^FvVFPQK0@)6X*jXgGfRD)sDz{le@`}5dcBWa0qBx+C!qU3M`5L+IMmHv`6a_(7a z0dk&_0;qN5iKv1dw|*!D4Zjj!91a>G=%~_}q6U99tUF3Ikq-EcqlR?ApB$6$o;7Oi1XX>5dz)`t}C)HWk zdEx+*dkVdL$URf>3aU-&PtkU1bRYecKt9(|Z>V;hArllcaX}FQG+2~0$dcLyssXF+gYQ5SrvT5-p zEWZ1;@{Q6fr#BmV6AitXq`6j1(!6X;(yZ(!me|E=H`%EW!BX^{Kupg2CFMWetBS}y zRjhc^=VHlNnQ*TxW9%jIUOhp?j0i}@@T_K|-Gc&y^hb!(v=>nl(@9H_r_AK58p>^& zLtfD!IGwZ$61DB+{&%pnT{mc18PqVyWWeHwdn~HvE#1EwmLIbS zK7iw+@0cn~qXb)m%^fQplSoq^;R}OU+r@EX(Laa&fBsa-Lalei0pn1<_=kMmPwtQm!bv+b_S&kWCq-+vv6s$p7`O@NxS`J zT*X!;2p<0Xp*>8B!E2D3eDo7aboCF5Yg8R$&=Cc-s)4gc!S32{zwb~@d}5YHJ%mTwqx==sMyxyHo+`&0vZV z)oRo^<5IUOApOj!O);w4ATZVZvRhXhceSbl(wnvvBkCxr*V*C~Evmq1=WvQqb(Z*u zu9&}@G5GG{9jbw|M!}pN&vqtE6)6*62*Ts3k}{U4+-!*qO8xYYI87Q>R+pAS;U(&e zxuzYWl_x24%~gSN`7W58DYSfpE7;u$d7?2BZK@1T%&hsRu2jYw`Vw{Cc$GI%+#eST zuwzzAPYhTY_sw=yMEcNLxGt_wZMfI764q)}hfDZUM}^9SRHL9br%cFwA11Paj diff --git a/venv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py b/venv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py index 5ddb848..1dd0d70 100644 --- a/venv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-312.pyc index fbf7965cf380746b1a07d51da06c224e72b1a7c9..56b86afd2438efa4a8ab9836681fcca29795bc08 100644 GIT binary patch delta 19 ZcmX@ac!-hvG%qg~0}wp!oi~wtI{-EM1>yhz delta 19 ZcmX@ac!-hvG%qg~0}!0pJ!>NOb^tam1@Qm? diff --git a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-312.pyc index 8b2d07d8bd2867de631b46a1c44027fa7838714a..1c9d06327cbb199c544d23079b27de7de17eca1d 100644 GIT binary patch delta 2470 zcma)7eQZ-z6u-B9ee36YZTHdjgSFdWTM@^{1UA?lY)k@@DiIVOYFGDOv8=D1w?*Az zvKc^wi3xIJz+fc$-yDCq3=@q18x#FwW*V02B1SaPL>-w4iHXs3ZpYZbB{u1==l;&Q z_nvcq=iZ*${aLs2g~#J0@cHr0_tKXu-%@Hvy_Ap(L?=4U5|e6_qHW1qOsi%!B~3DI zn$46oS@70ug=yF9!j`fQ)2TUyZOgh$x8@eMob{NBrkJXxig88OYx*>wu_d zy7x5EeG`^4Gg1B_T0r>x;H$jj(`xl9L(!{s2do){HEUqa&;}70fI!DmV0gGT9{dHD ziqn!qPZd)G*;Jtrm-trN#Gj*$l=8Rf@3I#nn2(>eoS|W^T6c{ef_OR2@*_rWU@;T% zV_O_7yaC1qVi1k$M6(RjYnc$;&?hxL{m0}z#ghA^1Q->(Wz zU3Z3PCGN{Q02T`ygRCWY7k!BLxKnNf(xMJ5`AbI#pm-nYew3G@F2oQge?f|2zvm=3BwIUiDh+B z;u`oCuo2IY8)|q)3eURzrxLTSD(AUFXS-*l&<&fH|Lu7JB*`o1p+hFU?Nd9{b=18H zXWr3e(EC8R3kkdhW8_aSQ5&WkI%kxwX?quoOig;LXiWlq>@kEDbHDY4*X><4S6Mk1 zu`5}W9hnWMpgUDIo z-Z0#=EYTkRM`d;65gZ>w5Y^q4=>T#FoxHi~gjYBOSMDD~CQz=`XZPT2-`&|S8ms`f zqX_h(h&NHhIkK7GiZ=Gl%MxwAST|4L=cC}YhrimqU)Y})7LdB75R2>F f+OKKgwxxj{pz{QA!AdN(^Mbg&pC631N?7o}@;U|u delta 2627 zcma)7ZERCj7(VCr-hSQowq3i9w(C|lzRJfy$EJuImK@&VC7-9_mFcC?NhL~uKe+`NLm@&qs3aHUU{b6QiLgF8N-_vdk7>PHz&w0Pj zd)}{e?-v_he8l)N81xf(u6}l5uq$@XSTLqgLe3LL7%dW;n$%WI#deu4TQyZ%Gc}4j zrRcUjrbp7QqSyABK1r)Zzpb0P9WVou*NQ>gFbz9oh9vJUhV6(Mk+i4SU`Nd;C6;Qr zm^T4YST1WUg2bSLXvQqf(yc(9Yh*sl$NUzxe5hr*6(4l7z$w*iQpgsGE-Rpd z$6O#~A&`YNqp&w6?P6f(MZ1XH+&t2ljsK2hRuenv5>HjzQ!128 z;uviYE7jn3>tHTFve)7c3NO$<-MEi8h}V?Uv{}Sl8^`jvd*<=hiRqI-oF^7BDI=!B zC}gf!Dsw@iZkd$Iv_UU(Ltq}u%fifaO1)g)Z2CarwfszFWKdc9u3l|IM#v@FpLOvJDEUH!Hh`>JRUNB1c!$`*BQu$8nG8<>RrL-G6iS84z`$s< zuUv8}JXa`HI%b4TVB%nL#>teMB-_uZXN}2tGc5XKWAcpps-LIDDz&hKF9M^i%3ERK zSaKc$sQLzZdDJR7RwYZTu6)sPFo*ilnq?1FMn=PP&XtlD@spaNX`yI;bSy(x(rE@M z%nmZmBE13uGj*_P8B9nd-HT|O*x>Gi?ME9D;w|_4LB1Gm>gS5xo;JEvJm=}A=_?<2 zHqqEB&}MyAf59n0`ngix;)d|}+8fijMhufO_EL5crdN5A7D`^jrf*Thn5LGY3Ga2G-EE zqARe~iypHIkBXNAonx}Z9Fyk(ge3q~JzvZ@j%`&Al^I`-Vgq3f!u<$q5gtO=3~-5X z^eJbdR%a}B9A4)lz$r4NXj*DAv3Sab>*}uB+Pmed8vC>?nIC<@X$_Q9260D3U+^f@ z{^Q{5GzuN)x^lu;MgyJbZ>9qug;vlF;#w#nd(CV6MMjX z8Y?wUelQkJv_1Td(KF%gk(;~YPk~~d@IG(o9Fr;&^%!D*HpsUi^BBTbfU0+hmxnA~ z8R0&ZVQ^I!+%vu#S=kb7L^aemGbh{2`n_P2RjRsE9_D##pjap!;Xx_mw`Oo|{lFpN2>ZmD*m4d1=FdeM#aFTK z++oz!dV0N4r}4YGh5B9M-*}4VMXG70yN8>;-^x%muRYda)R@h@qm;8P8)OciHctLF zNT_Y1?ZI!1brarowNCb9C-3d?QS=zO)k^^zk+8SMUZKv=AUTP?-Qx!*0Hll&Kc|Y9b?V+qrvP%^JkF7ZdSvywXgr9 zIku!W=!cOiBH;C`eYJ8(sR(j{hmbN>B0323T>u;oj_@qJ&d*}9xz9C`$cl9OVhm@t zKbx+)D8s8(if$T<>2~@TLA<$BywTdB HVvhd-wm1~t diff --git a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-312.pyc index 5d1f60a3d0fb3217a182e1554380ad7279e0ed5e..a04aa8e056ebd7b67b02ac2b32ed0b44a6d798d6 100644 GIT binary patch delta 8801 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 diff --git a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-312.pyc index 706b1e6ed7897efe9fd0115d5316c0de6dd2a617..23154697789527e5358091bcd43f9bd3f24112ea 100644 GIT binary patch delta 6493 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 F{{;yl9B2Rl delta 6383 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 PM&}3b!+)DbG2`T4KbOM% delta 1935 zcmZuxZ){Ul6o2=%eQjUc_5Z)E+q!n6D-ITi!;SHGiGVIHFhYPPxQ)JBcv)XN?(38Z zglUM;50WkS3!13-!DMEdkPJWZMPg$7L*lAY%p)d#^@G|#z-UbLoZEqz@RIkt=bU@~ z-E+^mZ%+Ju!1uM!r%LdBasBPm)RHerVoSMBn_(|3J)gWlBu&z6Wsl)4c!9QSjI%W!K&?#(JP-Ml=A}-Wq^YJG%}0}33vJWj=j$bFVIQ41?>eHOmRZ_Ghc#f{~A?n5COLnalq%j(Y>=Z3XLs|gk>lSSn?JL0H zS4hme@~PEtm5A&_jq#$w_hciSxPMSGz_T>}$vqe?0cqm(EJ!zN-<fX)w6v z$#$GVNejS&^rJs_%imY`_pQ15n8+*6?|BZ9(CV|^l#}%FQn;t36ZNsG5EWd!72ZLX z_^t2&>E~+XXkRm?u z$LPJo7o*n)hR{$P$S&M6Ovh4Yrx~r(#1Tz9NFcWbmPXxXkPrCP*sEQb8+$Yo(H;}% zL;hO)*zrNowOnI#{u#!qjBP^G%_y@OdWB&cmhB|1u>evb-JCozU7V>gfXU+YoJsT1 zX2C^=?L_Nc2)hwR`S!#v@*F>x;3Ulh$$m1kx;vSZ$yfYT+l|;qjui)}!FNc?E91>3 zO|BkJEy_a)knYXf*i*1FY*~hhf&k-KDg zH`e_dmxsUe53aceVb<<+y`B^9Wwr&Bte{?lf@*Y@Ry0~E>TpzhGs+ZyKNI%vLwD;9 zhtu#`W(&Eq`bS14n?)Mfsq6s2`VFyB6wIL2!x2Ksah~hWlKXtD`-pfD@=3njz4<~A z_s~6i2?6gx+>K?^p)A{w#pi_6cx-EJ53%&0KPs=2_xappRt0?flz)z}{ diff --git a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-312.pyc index 0119dccddf91c7503e3f7c6e6b95bcea52ab7ef0..5e2b792f1c304ecd966b669bc1348d1c8dbe8c95 100644 GIT binary patch delta 20 acmdm~wo{G!G%qg~0}wp!owt!&PZ$6{I|al5 delta 20 acmdm~wo{G!G%qg~0}!0pJ!>Pko-hDEeg)G2 diff --git a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-312.pyc index 3644088fadfc59ee6079f4df1376f473cb81a9b4..a9880e4c159563aac9ef0054e765f4bdf56eb191 100644 GIT binary patch literal 15336 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 delta 20 acmdm(urY!AG%qg~0}!0pJ!>PkngIYtg9c0h diff --git a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py index 9c0ef5c..0f31dc9 100644 --- a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py index 4125cda..d30d477 100644 --- a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py index 4adeb43..1f31d83 100644 --- a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py index 8663097..a1d57e0 100644 --- a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py index 315fb9c..fb0dd85 100644 --- a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py b/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py index 4af4a9f..b04f41b 100644 --- a/venv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/self_outdated_check.py b/venv/Lib/site-packages/pip/_internal/self_outdated_check.py index 0f64ae0..2185f2f 100644 --- a/venv/Lib/site-packages/pip/_internal/self_outdated_check.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-312.pyc index 821bd378490c0b594331bfd707364ad268849e76..56740f55b225f6e21ae241d6a231d7125e9fae4c 100644 GIT binary patch delta 19 ZcmdnQxQUVbG%qg~0}wp!oi~wtIRG=N1+oAD delta 19 ZcmdnQxQUVbG%qg~0}!0pJ!>NOasV^l1;GFS diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/_jaraco_text.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/_jaraco_text.cpython-312.pyc index 8e11be7cab3b10a4a967484e3ce4378940c57b42..2c2bdac9279ab26cb259723663d8136f8cf8392a 100644 GIT binary patch delta 34 ocmZ3kyiA$*G%qg~0}wp!otGxIk=K=%F>Z4(Z#d)T)qH=L0IPxuUH||9 delta 34 pcmZ3cyj+?0G%qg~0}!0pJu6LoBd;qjWBle|-f+gvEBXF10RXJ43T^-Z diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/_log.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/_log.cpython-312.pyc index bc4e105dd07ae9df3c8826dd3dcbc22ca653ec26..37ced3f0444c28df259b4066a7a6646b035c51d8 100644 GIT binary patch delta 20 acmdnVx08?iG%qg~0}wp!owt!&j~xIz&jpA8 delta 20 acmdnVx08?iG%qg~0}!0pJ!>Pk9yPkA144oqy_;1 diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/compat.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/compat.cpython-312.pyc index 30db2699ac73921edef71ff03ca8040fd0b4355f..d6c046ad0c28edc276ea6fb359f003572fe54143 100644 GIT binary patch delta 1196 zcmZuv&1)M+6n``OrCm$jm8Ceyt%G8RCR?1i_z;X~b5RK7koM39!V*{<%}Cv~tQE8C zU|J%obqNJxry7y?)$y(H}l@y zFaI*V^J}SO0n*>!JZ$+UqEyCId@YQ61mFQM@PH9UJH(?oDxQ*~>Zv(uo`$G&^mW5C z2(*Ez-x04sfh*zExahygtvweDOY$a|#)~b=^j*~}F@sN{ZnsocK;7Y5ICt+!b!UwN zh?AU#XAZO8g)ft?oq zTPIx1ZL4p2n6vl#@S7yA6ZrpBR$e;?ut|iC5o-9sTP1RZP00wawng1)I!!*)NJg)I zk_P0r67BL`jPG`@0L-_v{sy~CYc^5{zkwut=WlUF6{K0K1=L$ zO`ow#GFct7+4R2taL1)j6|_8^kR^=XYIAM1&9j2wakL?tDDiGHVnMf^>0F3N#7$XX zOd1L@eH0>l0Lj=6A+F~*g);gWr7NnnvrX<``_MS%LzR(jx~)8>d$I}Ar{F3dXGGv6 z=1~=L`L3Fo!Fn$eNhi3Knd6hkIFO*jV^Pgx#Az8nC)rVEEU!|p^Lky#(PUFmk9Ylq zZzle@ig+I#m++5QkbMa+bSTdZocX>pKXBZ><32k3hqLtLM&J2pU^n`9W4~yBd+yQ2 zp#sijG6L#YL!hQ5PNj>+(sg=A+eljHm*tj3&`jK!%Fydcq`8IWUD7FaxUo?#`$IW8qk%9ObNP4zU8cVn~OMzx_;1YMFL+IWaiNo z^P34R{n@BDbaedy;uJzYiI;^B*CV#k;g`f^w8^&}|ATC(5JH|&LZ(JKkarGX@&L>O zu>OP->1<*7=5Pg6W1v*}O66|*cV%|JHaDm(^lJ-)+QmM8>h!Px*T{A9OwlxJzg!*W jSf4+{#ic{May7@l%!#iWU!NRl82fxCy-`?JIc~Bh?hmfRu>IEc9oq0S$%m$HPkua-%dzzDxlC&A`VYGKY6ag2Qy>wYEh+-8ME zL`06`gc-Rk&7e$iM?2vQ#$q8KYp%=cTdo^xLA_kA)XHIAVo21E_@yyFD&G>W5yqra zYa|SXkDJbFO5B{Iupp_D|EaI+)>$*~*1{!WQPTu}f%j0P+K diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-312.pyc index 4d1f7455dc613f601a8af363fe7f96188a007948..679a9ab78f6a4680e6791832e4ca01226c8d414c 100644 GIT binary patch delta 20 acmbQuI-8aIG%qg~0}wp!owt#D0uul>)&-XU delta 20 acmbQuI-8aIG%qg~0}!0pJ!>QP1SSAC83m>Q diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-312.pyc index 7a06429f61ccff3270771ea84d27bb811a3062f5..c37ffad68f9a8d8003a1067f2e188eca858476b1 100644 GIT binary patch delta 215 zcmX@9a8`l$G%qg~0}wp!otIXM zz|GFd^+AY%SKAR}!u!g7JZkB`aT_gbX2>?vUIRgLy delta 211 zcmX@Ba8iNyG%qg~0}!0pJu6LnBX1oKW8UT-9!5sSJ(K%*tvnwJOMPT!;I(`pX#0Va zm6PiO9|Nz%4Ib?etjs_T7Xz;(R7D8m13^)^5}_MBeh?+9Vxnvfz8?%Wi}KxIOmJjm z^kjU%!~cO5%=*B_AS5+Id7|tGb_kz?flq8ga%b!ZP6(fiL0Ec*@kHGZ+z>tw1CPiA X=T6%XybwMg0~^;DelWX80O$(L zoAH;)@PQUtjHk@RL5y31~Uag7s=HyX9*+tFjfi+(3N77r!%XwvZk2nM)q1nG=YMxhLnc8W`T- zm+Y_atiR5$bdg`_0-y2%!v#^x;}*tUP%+uyxFKtM{>J?4X8sq={4baWT;K`($h`S9 zt1crO$dN^&lmD@a^C*H0V+0ZkMRJoB*<~43Cfl>?Fe+@$Vee)#5C=-!5-Lh9EKMyg zNll3_N-fJQ&dkr#WG;f30WwGmNc>{7)nqJ^n5@pVB}4)w2#PdKt|CdF+l?)%otw;vZ)BH(+J2a1|0LpIeI2bh8(?86%^@JB{A7FG1-*Vwo9uR5CmzgH!&VU{RfsLn?TY{7v3g9^Fj5X zq8=39%~L(8^wJQ)g9opIr<@{z{0&-q%gLDyY3hUdz3<<9Gt7^~IHCMf6xqY%=l2iQ zmwjcIkQ2<4s`RK!O^SbfD!w6MT9@(M7r_t><0}%qUSH-d|I4W`^HHaIbY-49r85g2 zcWD<_XasvSxf+_M7aI1vLOtS6aR-KQLib1%lS0BB+oOSOY*9Y9AjR9}-a?x~*He$- z3t>|dO{t#1zOYTaI1%oywf&vmcBl8C(`zeEt7O)oQf}ICl$(;wlx*nBm=)LjV{g@l zMzM)c#0xpahy(06ek@40Z@q7i)UBbq^*b1SS9o0*1+`&NJBfcveN3IjziEAKl+6#b z`3r%@ybHs=E`4-iN*q7C+aZz+46Ngy7%B!*SiIwd*Ar(#h4daN=ZL)cLrxWQn&^t9|4rDFM@ za%h6fu*t*3fGDqVJG0Dk_}@rh%51x9SGNPZVOX`p1GvK~IfO(5C;H3`vwRA diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-312.pyc index 5419ec6d06e985f9460ea4def219827cf0aeedcb..ef2463eebc115d25f5670ee503195663944d4eb6 100644 GIT binary patch delta 20 acmeB>?~vy{&CAQh00fVF=WXP!?~vy{&CAQh00bv?&)Udc%MSoI)&;Hr diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-312.pyc index 3f2d267d2fbbcd4e6a7873fe23c12da241b151b1..25d90eb707762eaf5a50c6a383eb289b9a28b040 100644 GIT binary patch delta 20 acmbPeHPMRuG%qg~0}wp!owt#jO%?z<)dhY4 delta 20 acmbPeHPMRuG%qg~0}!0pJ!>O3n=Al47zK?0 diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-312.pyc index 6885c3f89bf47da16e0c010d40d25d4dfc5f1742..7867d27707fc01d9cdb36d464942d1ac44591680 100644 GIT binary patch delta 20 acmey(@tcGDG%qg~0}wp!owt#@fCT_WLO(0Sf>{hXzgn diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-312.pyc index 945f1ad160a52ae431ce8ed9cd814ba1952fe180..a8e58a94137b6f8d8658a2380c2182f89f0fc7e4 100644 GIT binary patch delta 20 acmbO#G*yWEG%qg~0}wp!owt#jixU7g!38D& delta 20 acmbO#G*yWEG%qg~0}!0pJ!>O37bgHW1O+t! diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-312.pyc index 7cf445c174b0e6bf3d658262fa68c46263b5d37b..81a4104810e4cf0743c023bd3b8b17d629faa884 100644 GIT binary patch delta 440 zcmYL_Pe>GT6vy9pW?g6J->$3Mrn7bk!T(DKFD)VwiIA|QEyVsXmS{FzoLOadg~US_ zJqUVOAKTGGSINuo)VT=4E`kslA|+9sOz;{sD?#t@h4*=1K8JUa`<}B7EK8?w&bD`- zJ!)9pc-iP5e&K6E1G(g?Ud-2p?i<4JO<`WKh-dk>ut8-dh=!dukNmiZhqtIm%#+*x z3Zg@yDRQ-Sa$|c+%TFYdS4AtD3@>>P)h3r!*e4@f36@JjnAh0B+|>1y(51C DSrTlqnR7*d#XIC43oICHt8xN^CpxWQs9 zIXt<%QM`-{sZ2#YKsBs647q$!d|)}Y9L8M!D1IQDJxU;*A%$ZRW0W8hgF8bCXA46L z*J>t^Jq!#{LSQj&pcqf8&}wF=sBk5tChtoS$4`@yZQ?1z$*hb4JerKRIQ;U1QcFsU z@-~MuMlv(XZ(h&xg^^Kv^AffrjEoMGGdZ#u?KWTKP-0|s+Wdp_FcTy9WfB++7#%4J|7e>aM z$;m?R8H*9{Nj5U+1#ilZHOcoTM$SApavA8rdYpR5_9xYE0R+SN;32Fiim zJK$gM|KETA@AzN;{Eoo!TLY!Poie3J!SDBXJ=`BTaJqDs8adry#7hjt2v}26rSVc# z!8mA5O_jyV#WM<4aR*@is{-vD#CY#V?cNDb}*o z^7!)9iuekNms%@RtKzHVc&gQrS{+|4$7NP$YE68NsthQ`w8zx=P=Qwg-ewbJTx7&fM&i5t2oQJ3SOnqShAW*| zOmTr4F`7<><9m!|;4Q3hCwOEI<2XO*VffbXAxw*!wG zmr0`=;mR`L*BHy$wbF@@u>$x3VGpLiy#37;6w#pOKYvmm}kTuvdVZ%;~CU-SAZ|7ie7zt%lJB57&{G z&=fJ&gT^LU-T=Jc*of*}=~u`GQ#XhM0i|0pt~#k0o7l8`$>W2@X0UA`R;*YV7WlV< z-!!(tNDmgl#tHfE#mpgN*w~J_9pr?p!cMq6Bx&X1c(`V47q~1RXIH`T-M~{hoT|JB zxNYo({MFb4-2*CCc5Qy0Pgw2UkoJR*82ccTo}hC-@JtRzn#f0Jj)QtQB2||QEz&S{ z4G7%FW!0|*?o7ZB0C$b+Sd$DTWF&xRu|rCYnjam^?-7|g9jWVkI^b`C3p-)hNXj$} z!?*$2k(_SA*~!pY{D{#{rIq`001TtXh%t!2M`5rRJKej3FFHugqip3*kzCv`&{ND>E(h&ZZj4^{4 z53`mF%VP}Aa?BndRb!(cQRqD})hje~S5I2H4`9Xc;Heueng(%Nu0#yiCM(*2Px zjQA>1x3g+|aB5UlSBk@B?Q>Rv>Z#130%#B-rq(<##(z~drbbp0zDjgYk585JO9&@m zi)W|bqHY*pQGT5oy$*y}fNu~F%~+*|#9K3#syjvD%(~WViTwZpV(|(FbsLH2P6(KW zpKr9D7zi8_@tL;TCH`?{YitO3J{+1)=7FGzFu-x;Oeo5`#Jq}mD^oOU6G+o^E)9em zdGI}&$jcRSnUjO#$0}Y6%%mv2kmKsESKzpbRN7#Cv*@d8TYi|NDN&pgpeT42z*7@W z1b-=rd>8{XN#KF;f2#VSuT{!=Q9I33N!?+5jkvvbcHNa=dPv%!O<*^W#iN290RNE_r46_|GZGSD%jbPve zUJ?H?Cy7M2&GoPtrfAx-+iB_!QV`LTE{W0|mXFPwsyjo8jP4F5e7pP}%$^Z_S}(L< zU5Vdn|F%wg_ia*iHz_LIcqGX(qzkc<{t2;qQxnNSmK;jh>4a%#vM#6coD=WXtx&th ztLGh2)$a*0zp&UOz$d{6;t%r=kyAUW#Nh>d7Li{5eFEPF znCLdlw&f+lC4NF2XC%!H{y2EQ62DnE56*wI z@K!Z?5`XiFF6M?gI5oRf`pRVK7j^Z%tfjk*zX){pcwf`Q!Ic-+ zVc2vGlY0@<={K>nNgY1{Fd;bJL_`9M#md$}r1;U+XIft(;>!SDI60WLhbEQNE9SV_ zu|#Ns|1-Ec$H$ib-G%e$iuUTJHKgDM0GvE>hrWXGq{FP4I0$r$o7)q)(*AGz`zvKZ zqRcj&5z`&S@{&hksE>9iZK6rO@I|DCz;02q>}sUgS@xb6wTjEU=smT99~he zY%_+~m%k&*TL4~Y5D|GHS2wM%?aCJ7A#h;)g%zs;%c%#JZu6Za7|C$fZyx!2R=ud{ zB&>8&xA-}**_3nK9t(I8D?Kp4xEC_*{xp*G4#@o90VXEND;eRY%M$6V zOS|xWOdnIhQjWoKty@lPITd_0RCCIBGgO1)wrurDb(y$#_1b!AN97-aH5T-O zNz0LAFUXmDF@@qUs~4*`iH6QOaPRJYRU*;Z9`#-1ABy`sYa{Yz`9!?XS)<-5&UDfy z{Bvhd+sDxBMKe5|VcZ?{SMMjF`R6=s4*&Z2fJOw4i{Uj}{mbry@$1)>tEw&TUO%gb z7P=Qklqm-V7|k&3%r8jjzZCJS^^3~nIu9{Bo8n=_etP_?^{U!xg9BNMfWiwXB@^yR zucR+)T1LWVE=s^lFnynB-q;Dx4{iMM{zBj%5&M_wT3$p7iUE!WJC-cLWgkwav$hM> zQ)mWnx5=t!`l_?sO7!z|DsQ74d`}2|0QuwG~BTWKTbv< zLwx+Awy>|ukAlw=&up!zl4Y5~nSl!_?{_1_-V|rIntqw9#Z;Vut!I;>$eOZlET$*sXZae+BnG+D=c)cngs^V|9ACU=O-kn?B~JBlT|-$6gJ^uwSTHKie^POHLm}z?XkbTWMl)n0PMZ z5`e-oUtvkref4jY)V*3f|JBfZ(z)~9DdaFG%gAPxDBD#rLx!x8>JY?mcT*?Wu}cf% zm92zCVppqQ6p`7zM4Z`mc^zKj6dR>xLTr2~q$Ma5D|XMlAk$wVO_Fc?iU}g(b}*}7er4S$U9NMKl8QX#uUko!mV}fKJt;f#wuHDIU45qxX5Bu_^MR?Tl0;2{FC%M9`TB9`dFK{k|V2_J+HUE<-y8I-te^^Ea54~7H97gcqL2l}ei z--w^|)%!1_Hqt}j8u1@}aR_ZpJ~>xj;9FraQVxSMv6Rt_Zt@WmEzc-st{3+X%!dch4^*ie3dnW@06WpN(E8zs zISMAJ!wa}e@vm*dAw!&nxL;h8x_v$d)>}k{*$#c1%^L%1yLe^j$4nl8K`-oNaiM$B z1bT1NO(ggUu*ahQzM(O{k-$v^P7=78z%2k?VImhOX_>8DJ}MHh3IOwPmm$-^}={Y%_RKPCSls(IW0r?^(E zb;8yB0rG9Kx`!vJBevp~u=n|cpi>k2&91)cEUfwlWsi`uwK?DBs;`J%m)yG1y{(Q` zf}i_GF}gI3nz(DYW`!*9QxU&hlSTN&gwT$mn&pf3gt#GlrTT{Wb@mFsRMQ{7#D=(S zI9BrmkT0ptlOP`5Af5ih@chU-bkZ&tqqZiNk5rF!!B#BTgJx|u__*9#fu7y5nP0y_ z=(g~$kr^~9B|uw+)2Yp?2vD!jX*qLRX8b+^R8CGs;FLVRo4^wU$SrTmqTEhQGRsON zaJtAviz#KTzZ=_0CxP#b|M$o*0>xcs`|A{nhP!b7;$B#okzze7{Sr&{?~A@+Sc~i=8=}7A}ZV_8=S)?ceA>sF&m?_onp4z z&kg35B5e#hdTs4$(>Bs0PE*cCN*~pD*49W|ceE}8mlL)> z*IoERFHk(bG}Cdi%z+O4b`P4)1&7nNHLB?u^x#YyBzHBQPP_RCvaW+mSxfh8!(+bd zzB5qN<3-S>W=+EjkC=9Qn-@ur4qzm&QC&x_c4lpvmYi?yAk!L1d4trhC3RcF2bZh` z2W_p7r-vBgU_1qP=_8Sb4|-ZMZTDLyz8cwM16m&&)Q8P<){jghh0dshx0jaDlSBFd z(^9&PKfFoHq@kn_(Q!P*8K>%ul3`0-cEFTOr%()o8I*UF@6uY0QL*4D z?CC~_Ht4z;2ahfU*OD2{=q+Y?Np2lDONJ>++8(GOADf#g>SkIL&He{4EiJ!YX=Xop zr48BX5p85pcO|BCrWtASm=Z9e!zz4o#()V9pcspKN-x>Dk8D=XGH2y@JA9M^B92 zbp0v)^@2(w;Mw1EqUU@dQW*PFFdB~F#QpoDbHgvK~nLK$EPx)(s|2euR`5`S3ut3!;6Tgm3A7SeLO`C8^)yNnFbE6~ zXdr-7Op#wr<(E$SR5=G{D-jwnXGQ9O9VoUw75ldWJgjpV1O78;!+ z@IHYL2!zSK5(4D}=y~ryu^VZ0;i<^wv=blCvlhFYzXS>VuQ&%#rt?8nRmEf9s^3|6R+)WPsXV8& zzoxXGRc4)2n!gB?sevz)N#IjL|Fl3+SD#fbKc{SXP1*3iQgcq}J*$Aya#mUY$I#T` z!103f^TsR3%%D1N{H+@uRr|D52^61N@TOY%MPQn`_`Cw}Sx^bgIxo>ivG?R#(>_{gPxGJuGBnSpvy6_F{Xz+J7Xiyf4rG zLYA;uLrm~V2r-=`IEf(;LIWWrX+#>DP!igl2AY$`#%XYWNCQ2<38zUBF&rqTY5U#z zclCmk=A8amcjw-@bLT#0=H403+--UKQd|%Egb?1H6n$M*v zni|gbEyJ%RoD<3Q<*EwW*03$&_PJ%-7G567^W{ZW_*O*nefg4R4;MrVeTA~^2(OH+ z@~w&#`HCc-5iX9D`0jh7E9nf^MmG31NNQ%dE>iESm+h=@L!{By7-{k~MVfuhlI9Ax zL^k?1%64{mQ)IJmb7YHei^P|Ow?*jnGif^) z&~DK3Snr5MTXELr+oR<}PLEb#@}mbB{WoHz@gp{^5L|uQO4h68X)5ql!1tyk6rtS@ zEgQ9Bz^0^Dl2#9BvsRkMzPb7dtEqOTlBsCARt9n9Y(Vp{O17IOlER%@#aa6kCZpoJ zQCq`GQj@O5L^mzKD}fKPL2cbdRjXpFpkAR?&5~ZWlXa&o@vz-;aF$kc*5Mm6Er8uN z&5ObNvZLCylM;P;%hXphhfilDA(6+&>VeM8qZaX|~8oLA3U`kdM>xHgzxj^c5 zkg91N(6E!Vgd~U71sYp0b2so2Z6~7BV@7BVn63wL)S~n%TJKp!+r`}Jko(4%GXA1y zDqoS@Ee-duu>~sHv>VRa=7K&B1XQVXyRGRQV<82FToNDvXxp0JoZ%QvktY4kMa7y-|1 zDH(*10zajV(L#~CJp}x;c2XNZYfJiWhu{H(mF0^=?IOZvuDa>`MYO5%Bx0JPkYN#wh-uGY-F*T*Z$V}XwR2{8^w~61`K;U-aEQqRIVzQvo8wQ>>hx)ZN_&jyk0nR8_ZBE`LE)}fV8l~PC zfjD)i+(0->gD+A?dR!)#J_*dMFT89iAS(@9LJ#OhMnd;TVjAOnguAGDGpEtyD4rld zR`6Q^4Aq}-;FpX@n=wY61Rj_?#5L-%DSM-AEaaHy$RJED} z5cmf%Q5wr64Gk++gE%u(IAdMisO~nyL39T@8A|90!G9-<*gGq6)WX z0K<-X{-aB(@>v>no_aESP6kE zYv%cild5__bgr#wZU@y+Y1ZC+tPkVuI0&j^guN{X%&r}wP^2+_| zNiP2qf%^d#s*p+cn3F$@t`Ee6m8<2zyPIf`kul2jcp#DZ$iQsV5sAcPjBEUB;Qeo* zuUnIf&aHv4czA!|%=gxXROemj^g8%CQB}RAdiSG8679n|I21H%*HfX?_&fR@j=H#}(F zI=|TLp@bIVh9i_131RzEnE0Il3yk3#h)AGLyxA}Y*A6s(tMPdvz5rm@gJToXl8Z7SFkW-$(tQBya

OMpR9dXV^LMNAc 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 diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-312.pyc deleted file mode 100644 index 6fef7b56cd100af2b7dc794efb99bc3c0f7e2a34..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2695 zcmc&$O>7%Q6rTOHjejqe$Hl#^pK@(b%QqdHtZBSci6GSKn%hGD?87G^rz3%Kf z!jUWGkV84qTOv+HLZVSGIacDrfkP!Owo;U`ssxA=H-nLodg8rZuSrUh6Kd!1X1@34 zt>1ey?;HQn-X0?`9)0^|c2g$gHw57T?2r0cnAQm;NkRoGT0&BQS+c~Ol$3IEQqCz! zMIa)%OsKp@sPaGz9FuBEOsFfzZ@8vqx+Zh9tj#sbvS!}QFK9WNGRukmj+@sk94rbd@5BBVNyktaQayuxDW)|@af!LMlX8j$o4YKv%<{{rYi2s-m@Ye6Ffuod1?Hp*W?@1%^Dg6g!TXjYcgJdyP<>4baj2@*nX8956$fu#Ssvz;(=$@-8QG4HR-&UEQ}GnrU1U77J0xsSKlF>RfO8{D&EP@N7-hk2 z`YeSl9U5T{n>9>Gf|wik%8S|s#tqlzo~r8>6n<0mGvs~X=-_9yAW!}ptXGa6a4P88 z0~_kEfPgcJcYksF^V=IYzP|F!+*fnk@ySYb(ogaQWXE5H7&x}4pA*w{eiXo-WR8R4 z;AFrB^WXz0@MvCm)C*A0|3NH#D;#BEKkf7VE_*T4 zG4qaV!19LW_FNVA><4-D_cm7KP1%jYhR zJl zwAE8NbFF&nx(_NJe_BUnEh;Eu8^d)1Q%x0=DclUxy%|(Z{l6+%Ilqyq5t#0u-I{+m zy!F9%a%FO+`o{ad^3jRE(B{|JPb(4O_!Krc(k&I>zgkd2zaD-a{TjT5yO03=x;%?c s2S@TAKMgv3iJUnagCeQPDnS50a0WjB diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-312.pyc index c14e484bd77db6a05c45678b64edafad114d2d05..b844a7839376a3264de498e3be4a1f8888a6f207 100644 GIT binary patch delta 961 zcmZ`$O=uHQ5PmP&-6q{^&5xU8lWdw)Y)EQR3zmw~A8X@5sfQMXfYjLcS^{aKFR8W% zsY)*%iqv-$#H)e`=Hj7vQx83Q5E5dQB1OD-D+q!!+ZMIpTlQn-`)20N%=$S|IWe@jpi$`Z%7D)IPVr-A&u^Bfq%nO#n+E%~9rVP1^t}v-@f-i_XMIPuEnx$sI?vfi?54Giv_V&C9z6by`v?`w#yq0wdOcMW8L_H+|?}P{G8Mz+5N{3`Da+Jp9aKuz=AP>|Fk(;U?BSkO5 z351YrCLZK*!+()|;KCpVvY47x#ep=85DNfR6(9xYE^O$zJwUhRmVKpHL;VPX7r}$z z27s!VB^CjkgI6W1KfXE=Ir@hclVac8QDNh|36Rgh^?1wwCdR zhCaHx(h=M!KCQr4a(3HLu2(AMhPyOha|RK3%QGVI3K0kR={Y-BVGCtGC|1D5r>;H) v{NbjQHc3a5c$>u6B!Nvb@sUh?AQN9nZkvp?$nYjP=WdbX^?RvBs$jw2#$?9~ delta 996 zcmZ`$O=uHA6rM?TH%T{J)27+xKWVLPL$p$aU`vs6yD~vE_Q7Q#;0ZI&);WmPXKW__w6#ra^{pO5N-i{1w0ZU@) zvXl#3F_#fU9#|_2;z5YJAs+cp{C7rPT4EZ=qAs%cV^P)$t?a#epAlmoL;Y2dwXt^Q z1tZ3xcd#(( zV6q6b+`UK>u}|QWY{F@3vvV^OXVS+f(o-k0lVXc@3Eg&EO;FP@U8os+z9{b7n$#=q z*>A`ZNQ&2cq%}%)@m%iKLO@h)$i{hCY|AM+EP9ok+lxF!9_U+2K<)>7P&`zUG%DUH zuX=Uxc^iPKRE_i8s3mM1llbl%UpNAC66n$TrsKUz2kOtfk0?!wvae4WM){Cf^F`Wm zI#a4%ER;>@%6y^5`@|bxN*zUoiqJ1qJtUI)ppB=*oIXZJ#F~DZj*4&k0U8#uPM^F0 zy2<)b=Ox*55K{&a1`#^MlkiF=wVONwF7&J+i>V2j?@2=izYI{70pf73!!lMPN9kAb zGIHvW1LHjiE(9ln1OT^U7GDIgc6%0=n2C1D*MQj;#b~ZKiaJ*&%g4dU!kNt^_Va0Q z_zXff!b!0e-B@Zz6U&%tx>735m)RJucBhGVG*gkv2Z z2KeqADOK1)(KyC$f{RaEeGK^7PAP4W)&_Akh`T}Bnl=};H3`5MgdM+5X!0YO*dU{u XWPF1h{$Tg)IEfsqPsOiN2@CuL2N2FQ diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-312.pyc index 8b3e6bdfa81109579fc1c01d46d300377baa2adb..5e6529361292f1b3a5d4468ebd7e6481cc61ada5 100644 GIT binary patch delta 20 acmeB;>y6_+&CAQh00fVF=WXO>(gy%QR|U)f delta 20 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 delta 2874 zcmb7GeQXoS6`$GluD$-Ycl{MRah#9@LlTk@2$YX2~~FY)J4)OU$CnT*8{P#caCFC+tZ_%#n1)oJm*Am2}74I&VyfNhu~_ z#2^I^Y$`3Z-Yed#xHyXW6u06Wg+a_Oz*-rZNd#g6#jiL;zkvZXfC6WjAou#rZM=HX@8O z8)QkbtWNR(Q6rbjUYO#8$FD?WGnks>z}sA`c8#YTFPDLJ9pq54#s?L1DF}U52xe_O z%~T_$Yy(nZe-z(9+xo6hi8wfpL>as9jbSvxzKn+P7p)2A#DGxRJ&ayP7f8u68lD+t zS{b}~=9=MMj9X?7@V~`)?~KPJGPsLG&9So8UDwy-0a zIM67}l9^E>a7>ZJ=rkKOkn@(&VEid)|Mmj#N209ifIiRlemi+mRz)IN4>dLe^G$eC z5rDI3#f&)P_YS>r=-lz~16N*qzx!UOeom^-4b4fd_YK=g#`+uFLb_~?+?T-qTQg^E zKjiT)vO$V9Q$nTgqBeCGm3LFv1CZxN7IIDM;JyL+{+XxJ zUook#5z0?M))Pou+lMq>-^(;P>T9vC5vedG+Hsov(bqz5`2xDs0SIQK+usaQ*53g5 zOaBlV3{;X=YAoc#fY><3r#aQG(HBy0X}+|GY^CHFua&K;&_Iab29Z>46nCUC7_RQ{ zm{Fq}rZ?b?B|cRl+r~^<^_tE!P(yH|P8*2R6{=9J&tz;YsWH0n z-LzpKO7=CBnN&$YX?9>UIa()r4C@Pm(NA>E7OIIDN|VRT>n{H@8@!F$Vk2?Yi4Eqn z%whB<)?CHd5K0?mXDOX+Xw0ImmB7FbeGPNkQqse5;-H`PaoRkviw4YN8txuC!S#i3 zA)~#tN*Y}By-hLW_`*SL-}>UE1TX^4F$2<*(_L1=YwhS|FzRK-48y1zY4xRPP_7MQ z0y*UmGxjw3AmBTg7OonKT3Up%V@xYsgL|=j+Eurle`( zf_cZ;_5#yNa@CQ{qBk%xm>rz=)-Izap$nfoxajgt1hc_&`#*7bmprvo>bz%Du6fSW zFwQKAo{6?>+r;kd?kQ8QYF=zO_xzGrJ2f&bEr{C-2JC4qu*l_KF(Kc^obj6dBm4Bo zb?N%Z{KgmOy+`jkk1jeq7t`m{7tSm>%PzIvcV;T-a-nSKor(fuag{GhzK^B4IjJtk zPaEz_+X{Y4211kJ%i)}NKF~D2f5nSj!7DA3ZI|07pS%2Au5~`xwBT%B^aaMx+;i59 zpIPz*E^U}H%zJ7I2)nlCyh~Eq$5QQ_1i9q4FGww)vp_#|x+hH8jOiWoL#H?)WQ9w$ zQyUhXbq~eB#IEeFDbIpfyCfaFuKiBxeAI*K-V|hv1nWiNyzm3dKR@lqsQRn;A1hVJ zANdpsuJRQgd4dy1vPTyEFD&{i7yT8Jmdln!e{eSK)xOEbvn7*J9fSXgI{m81KtriihiNP&fSSrbqL%n%L6kjaKOykSt`36oi=W^ zvZ~X>-DRluu89NYu8nH%I=Rk(aMxp`a>(7;$j;2x?_}^E!fm-$`wB!@tX>P1+5z(B zc&eLTf3#ldWv9MQ@>{|@eSg(g$m^7JX7zOn?c`YVkMXPIar6F6o=s_LvHrJH9X%h4rB91f)vswi5IqFC z*hlbZhpK3iJvQxzKL?Z}m_ZQ(AArAuM~(LTo(`)R|nJ}&ezq^Y%y n>EcPeb#HZ0Xt$wX)d=lTbi?LtuVru4V2V-i^9*|vW59m{Yipon diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/urls.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/urls.cpython-312.pyc index 0aa7ec432163800f32b4f352c46c50e4b5a14135..c832f88b523b0c15c1724bb9e7db9d8b18a06222 100644 GIT binary patch delta 492 zcmX|7J4*vW5Z=AJ>^)+9BwC3eh=xOaG&Uhj5=n%+XOx#Hf$kS~WXOKH`2}MK->81U7F^ZM%fr|%B5pMu_VdG%F zU58lqJ?Oz-2;@m3W2MDm)Wk7AX3SVY|GE944-9Bxf901`Zbm^8%4L{Cj6OFmVR|tqm1z1*=li#h)MwE#k?7UQ%krLN6g^r)|n68{bYWm0}fo z5eioKVDVIMN>Ad^e?ahJsbH8W9*RhAfq3f4_qHjB5BAM_-+c4lH*a>m|LZ{Rb2^=5 zXrDg5p8IJswnxdK#d<*(UgXZMGFS6rRdd$l%++1Pi&w2#3*(qbxTY{g;yBXh3^%@J z%qCqcLKB!LFt>Xw%9EIvZH@>6@tNECn^Q9dr8mG+CJ5Pp z)moW$56!?p$FF+_-7Dtu750z=UuG+8@n2q#?{Zh$)(#R^C#8#Y`aj$5cQ#XNsWfWraD#RBRTu4&VS%)F3Alv@nS3!*9@jTLt1GeruiczVL!} zYpf5!gNCGLWCT*gvWZocKJ|qmMEb+u+KdL750m&pVbUTP8tSqfiZL{g*>lv|6;uafrvDyOb-I_pdkXO zOu1aI)aHR+OqpfBiZu_E>4Ai3($VdsHt!fvk4VJ6b-n7l4Nu&FD~RD+U1Pyrj5<2! syu}hNmTs|Ziw*u@!@t;Y$JF`Qrru$=Y*}x!Z_-@~JE?FlK59_ezhX4KG5`Po diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-312.pyc index 51ac2f88ade11ff27cbb78442da9bd59af2e5d33..950984e7701cf2de222460b3a29543296eea00e8 100644 GIT binary patch delta 20 acmaE_^j?YkG%qg~0}wp!owt!YMGyc-83tSc delta 20 acmaE_^j?YkG%qg~0}!0pJ!>O(iXZ?-Tn1|Z diff --git a/venv/Lib/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-312.pyc index 136235450b20ec9ca302f5e0e300a34a240b7be2..6fa432269ab5a0882420dc7b44cc78e944efa105 100644 GIT binary patch delta 477 zcmYk2Pe>b45XN`*`839CTunAn#B_^-6|CZ92^(H-f6}4*+LPBS^T0ud)ie4UG zRK%;`p}LfMD)ih-z}uo;EIkVq4^g2rdvaiYy!XvF@6CIAg~p)q+c4r9#qG|~((ak@ z4Dn{#3Ce$`Dy@HnR<)=PTGod2TiD034hPyNSeNRD{uiV=5|ip$oTR&`l&175giY-( zA*G}Co16&;u9CUq{^Lx2;Qhtti^ck@smo-k9xFZG36KsnJZ{_S8_~YE7E|J1q||wA2(rPSSOdDc$&YzPhT!qIwryipJ;ZZR2&}dnfP%VDjJ8G2 zH<4Y97b%0<*!AQPzihNeSb#^OY~|G-3_&0!LX&thnec*Q#^A`_)H_q!*Wg zxer!wXwC^3S5K*#l1+7d&3H=)h38|~T&b1IE`}|u^H^Q3mh*aa3?|6o=>#5vTRI~I s+v$FQ59*th8!NKHzl!aIP%f5TrFz}J4hV} z)G*FwNSXYARdn)Fre}<7lY5x0SeT1TiY6arUL_(4R3HMx#RWj3f#CxWE34<^W)>G) zPsTfZatl-zh+R;(+f#hNaCg~`j0^Jam-##{aCrRwz|6?%$@r@nq_s)elwm8UqYU#t zNk?(!gW{}?GMiY7m>H!e7jq~xicFr)VaO=4`6S0LMhPjP@**t|Ar2&pLGD&iP$-g^ ze49&-QGfF|31asU<%7>FKFOw>aYC z^AdAYBwYW$hBp?7HY(az|hyWS7lA*{2#Fp6nN>qRm E08#yPr2qf` diff --git a/venv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py b/venv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py index e06947c..6ccf53b 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/compat.py b/venv/Lib/site-packages/pip/_internal/utils/compat.py index 3f4d300..d8b54e4 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/compat.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/deprecation.py b/venv/Lib/site-packages/pip/_internal/utils/deprecation.py index 72bd6f2..0911147 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/deprecation.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py b/venv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py index 0e8e5e1..66020d3 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/hashes.py b/venv/Lib/site-packages/pip/_internal/utils/hashes.py index 843cffc..c073b09 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/hashes.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/logging.py b/venv/Lib/site-packages/pip/_internal/utils/logging.py index 95982df..90df257 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/logging.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/misc.py b/venv/Lib/site-packages/pip/_internal/utils/misc.py index 1ad3f61..48771c0 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/misc.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/models.py b/venv/Lib/site-packages/pip/_internal/utils/models.py deleted file mode 100644 index b6bb21a..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_internal/utils/subprocess.py b/venv/Lib/site-packages/pip/_internal/utils/subprocess.py index 79580b0..cb2e23f 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/subprocess.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/unpacking.py b/venv/Lib/site-packages/pip/_internal/utils/unpacking.py index 78b5c13..875e30e 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/unpacking.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/urls.py b/venv/Lib/site-packages/pip/_internal/utils/urls.py index 6ba2e04..9f34f88 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/urls.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/utils/wheel.py b/venv/Lib/site-packages/pip/_internal/utils/wheel.py index 3551f8f..f85aee8 100644 --- a/venv/Lib/site-packages/pip/_internal/utils/wheel.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-312.pyc index d03ba7ae8b1f95befdf7db5516bbae051606a8a7..ee429a0fbfb8490aafac6987a163380c02a08dcf 100644 GIT binary patch delta 20 acmZo=X=UL)&CAQh00fVF=WXQv#Rvd2K?TwP delta 20 acmZo=X=UL)&CAQh00bv?&)UfSixB`cgazRM diff --git a/venv/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-312.pyc index c41c3cb503a5b949792c7419693c463a7c89ed0f..ab46236f67ee0cf9379b763de05e67244929f217 100644 GIT binary patch delta 619 zcmbQJzFnR7G%qg~0}wp!otJiEBd-Pv*FPX{IztU}7USfHEK-vrS$yqTQkc^jYuWMy zYgkfPvNaeOikQ~rnLuhvI6L{4{wkTZg_n&}~H=KthwH2Mn=`iYdMq{4JKdUkdD&_ir-=@El5c$Nd=k#H}4i#aY0nIMjK1PW*}7eUlaUdVTw8_WcUhyUbu{%S`5$;<-2+&Umb z^gx8!)FxChG{N F0ss}Roc90# delta 510 zcmdn4K2e?bG%qg~0}!0pJu7YhMqUjT#xIl2SPHC}Q0PyWbi$Jja9fX&8ASfJCm&|(-~~F5p@;)WXtES( zPL5z#WYphW#U8=Ps5bdBhmwvVP^OAIxFj(zB{3&IFIC|dOHyWDN)?lCVUYn)?iO2V zK}uptDp0q^WJOL<4t0=GY(S&zIHkpOfSh8GKNP^ANF2y4GT)rf>C4DyF?lbS6{F4O zA6&Z`In;m>ZXrd+lXvr&FltQxz#|Tn=it?4vjypJ*lf+4$0%nEWWW3m1e#1mU}rl4 z1vHt9AZjKb=ex}fW=etd1WaDbU(FaWSyRB5TNfmt4HYETnKNf*&V1)F`|Zo@mzSCEw%6-2;rHR!uP(6ZOTI9>d#Puv#7weDwiI2OTXJh2 z$)kBCuh3bGKFu%rwSW{5V_R{9)+{w^K`E$(q>#|riyO5~(k3B0iY;1L3TqK5qD7^s z7L#IHT#9Q6DWSDWt<0p@7k9yHV?k(VLA%tpIvg7(uhxH3yV<0e7AMzhX{2=CU=6L* zg*Mj3eQ1jl-)|N>`_t+R@r;eDm`L0 zO`BxjMU(7T;x{ZS2c>bl*2QNY-cCucI>St-Su${kOb#ZQ;owT8n9V8mP3DiyECm0x z=52AD+fhGmo3gNtaMRhnu>}>^P1hOUf`U%BYU45Z)R_)FL5e1X^QQL$!R4i84^Pz7 zP5o@M8TlHKWQI<-}69$ir~P)oSl0n-pAgZDTR`jcb%02EUuLME!zW zXRHT4^9-;k^mseN17tZ!5Jk}GzHM#f#Jo4jj=_uG8m@Bq#+kDVr_j?Oc+%h6wu4se zL@+G5Q*zDCl?A=Opk!se|6tO}N8lU&PBsB`e>*zxw!fbp2U{S=5^!u=q<$fA#k_Tv zc39iSTP|g|QeEPuTv=A`G1oojy~o=4FpLEc+egTFA6yA`2M&;!A|THAA-Emf5euQH z6EW!f>c?X=-w&;!2)kI{5qifwu%9#(1jALxu5y>O@b!B>K*Ctd7WP9>T87&av~)W{ z&Wf=5QGkfDzkU~f)^fzsb=Cs!w}s%@h^M3KST#CpIcw+Uv(^%m+3V&T=7#<`3p^d( z$t(cjFIud!4L%8{m>pUoofgOIP8f}BV@*(wyy3@Oa?kT@DObppvYG-t(aEDzxCh39 zI5b>)r{*SRGBZB%k#+QN#0KePAz*}$&{2+oLm+6=etN6BTxtgzaDri znuxA(A(Du$++aHN%~%YB8IPsxZ=q8E1P;VzH@p{Z|5obFowp`_edOrxqE9XFhnul0 zm@?CGGwUj$-8y+uhCBsh-Gv8^t-sklz|Il1cPMEwDh2!z$JgxXbTymTx$x?~+OTm&SE@8y z$Z|Ppe}GBi@BiH8&!g@k$CfH`wyHE7TdF{1tCbysrLB}9?&QaeU4Xy!b~^Xs(!Fzh z8aAgA-Y?PK}~ePlKjcl$^qYWHcVq~hLvH0fwm?F77%N;OkhbSk)&;>Z5=`&18m zw*H^gGgj<$Umlp8^wTOcCsU(I&s8#77CF5~dq7f#o#dLeskFYZ5!dc#*N=Q9ggwW!FMoF>nq zUPRc5ldA zd*t>l55LF_Yy0{0rOA&yGCGgsUGtwTx#{QmZAkT63q< zTtO~$72`-D6-AJ=tvE@Fmk7Q?KvzIo8{VS4E_cqrk9S4cpWy9XljwMKY$sz^VQzQZ zMoNeWVlzj>Yw*JE6GsIll(mg^TqB7xWbJUnSt@g_lC2iFgcIo3{lg6l-qm27{~Rao z*WG!{{KI?N+1)zdGsuEHw21NBWP$+{|1N$qKHAcRSug4Z6UuH1gt&O#TEIWi%TB=1 z#N0W`37#Yf6Ff#>C)iCuJr#4PnALSnsTRsIw~<=(O?q=0uSye10Rqu4M1MU`!;1tI z2Y!iw%8ttfqUT;m$-})gzC~~bB9py-QJ|Y?OfXVEGP%=oPPk3uWWV9Sn#-%Dyx}P8 zeS$KPXfM+eKrlR5!9{f*=eVx$I;ngsDvp1i6uoM=v0G)uwG>^XnqjY=uHdFz@F6Zq zEEr+z2z?p&$8^Xo0!U#q!mxWL6wp*X$HmoMsN`-Kp6Oy9_{vN-d~GJ-<3TdDHJtbX z+?Ji=|&WZ ksC&*4tt>AUm0kP}4k`5dr?71{YWbsSGwh%Jt(BPjAEHgawg3PC delta 3079 zcmZuzdu*Fm75DYyv*UMS=i%5%n@5v4uG6IJ(x%R%Nu4yIqutglP;bL?>@T)cf3|x+ zXH~6?WL>2Ol|R;<4m1#G0)!SifrV(Xc^C;e!SB#}xz0weCP#R-5Zr4jpCrgXR zVIb`B4bx3~f3eoB)v?jND>RGk)9Ym2;)zeL$ZfY+RT^tY9pmB@Ja6|vUu}&g*11dY z-WUoFYzw?bRDA>z2Ru*fH@A1Eta4AvCI=UcDf?AptXHo)rAs-k>QYX*`Icc*D}+Y` z7C-v{Lqc1IFx_PqbloSFGnKG@L(e?WU`m_(C^%ZVVwyBCFWj+o)iOLrvIwnglfntGajHp0%YlI}cQ%HHX+q3X;&*>auD)Sx}U0DV|Nm<%>&+9B;%` z&7GD@aV|fbRkMYBT+Jkcl4exp+yW2M=3e-bb$~U)hINFUg)SR62TjWfe%3?9`^4iJ1;we>}mL>qs#)8R_6q>bl?&?GXxn|t8|oh z9D^^qd@KUrc6G1`c-z&6*S_aE#1-1Fw6! z+>g+(mw0ILhb{m!(BN8#i2jFLoKK32B*Z8>Mz_J1U<@UmfCVS_y#A}v~%ZB)7 zuIO~jhI6_U+bw~7(-70cYfVoW3@PJFz7R9PL0^YUdfj|$GZCLN?VKsm2|){7_5B!5 zH%C{Zct281lxfzf$=Q?B@#)F&DDOr=(5{&iJWY`o9B39LaY2sfAoBQX!6~sG5B@dqJ~cr=c1KkwycwPXxpR0lyz3d(0n_?x0lt z0J8oW|2yHqSCea}e`oJ_*VFoId+Ylq-N-l-0{Er>WeorMfSz?KxML6bMLJ?T&FGde zthD&qhw#;wAntmz<+ec@B6$}qx9#gZj>G%4G~bUd`Q!OQUgj6z z=WTrwk;l{U@3x5*a$hrM^9uz|RmR5&wn?bERUjQRvXCg1xMoVp^Gj(SCdC}VqXc9; zUqsMqmx`%GNsg;a^GYGLl#|th5nY%+7M{W2)dp)}VZ?^{;9-PPUzxEbpsx)`J z!&m_R)A>;{O*btOkQ+hcE^CE3Wt6U)9(dz(xTKm8M4gBt(IoX!wv^12tyCw~aTFfw z${@c#>6&3V;`csLgP~c#KXGeW3WrOHw917s+hWbcWmPWGY9_%`L1`DAL?Wles**-l z@+%0t?SVp1BRd1vdMGDaf*XuI4^pVZGKqRqvwR8$LM@It+DTRgEj$8Gh5~K}NklDE zH`W^9&;1QfK0_+iY~>ShD-^0D>QytsW}Cp)wGrxOPgUFppE6>TQ~INwPTHjx{ZXq? zlf}4_Kz3BBNa}U?$FIZh`}eUje9(^#4~heSVo~_?;l?LKEjn|BbbKL^&B>{FQc2C? zSt6V0+O6cCpi`(|_9k}{C1odtVW%0r0&g7t!wU6N{xyWD*>%Haha?f*xOIVW*H~>` z+ZSlIAqrUT0JR*IA zrX5T9%Ow340r`R4R;|PFo)n<$E!PuwpD6Z!z+XqBXnoJv5E~Rsxx!&JQ@9i^6^c3e zSvfZ~i*=I7sxsb85!@Bfb2R-reEG!1Il-eu^AUo}1e8QO#%h*)fh&T_^SFSgZ5yi@ zkOz%%{tH~#uCP^1_|J{Ev42)p#|N3Gi#9QSmsGYsIo_HWX|!Oni!xc&y)Wt9UM}9c z2533i%Zf04a(0D!GVdXv&kX($0ksuAMnKtviI+>Lsv?&%g%qd6tF}pclB*Amg+?v{ z(HTTLU7_g<1lI^&B)CpMrBQ9Mui?nf?KFRbpbXv7UYDrLR+mkvTBkG_iE^PD?B;f$!xGX-4zmci*`kQrs}?%M&i|~qccoZ z3%&=xnf9eA^qLvJ?TXk?_%LZU3DMl-;}d7kP4ZVrbdNwp!cQY|S+j6ComKJi;}qs< f2#KYSEW_1TX_Rl^l;W=5hsS1`AwTn5BT@E$4B5Xk diff --git a/venv/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-312.pyc index 173349352bcadb89e81974962e2eba20c24e3dc7..965011922ffe479c0eb7e5924f5e8988d90583dc 100644 GIT binary patch delta 20 acmZ2yz0R8ZG%qg~0}wp!owt#Du`B>Vfd*Fq delta 20 acmZ2yz0R8ZG%qg~0}!0pJ!>QPVp#w|#0F*n diff --git a/venv/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-312.pyc b/venv/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-312.pyc index 1e67c58048fdc51bc5591121b223d50fa7d40c79..cd4a9687db36596e221a3c1b6a1f94953930faaa 100644 GIT binary patch delta 215 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 YS(Y>IC7?bZEpZ<;6W?6{k%#5~16_i~MF0Q* delta 6114 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 P+cw2U{5J(ezVH76Ykaii diff --git a/venv/Lib/site-packages/pip/_internal/vcs/bazaar.py b/venv/Lib/site-packages/pip/_internal/vcs/bazaar.py index 20a17ed..c754b7c 100644 --- a/venv/Lib/site-packages/pip/_internal/vcs/bazaar.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/vcs/git.py b/venv/Lib/site-packages/pip/_internal/vcs/git.py index 8c242cf..0425deb 100644 --- a/venv/Lib/site-packages/pip/_internal/vcs/git.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/vcs/subversion.py b/venv/Lib/site-packages/pip/_internal/vcs/subversion.py index 16d93a6..f359266 100644 --- a/venv/Lib/site-packages/pip/_internal/vcs/subversion.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py b/venv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py index 46ca279..a413316 100644 --- a/venv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py +++ b/venv/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/venv/Lib/site-packages/pip/_internal/wheel_builder.py b/venv/Lib/site-packages/pip/_internal/wheel_builder.py index b1debe3..93f8e1f 100644 --- a/venv/Lib/site-packages/pip/_internal/wheel_builder.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/__init__.py b/venv/Lib/site-packages/pip/_vendor/__init__.py index c1884ba..50537ab 100644 --- a/venv/Lib/site-packages/pip/_vendor/__init__.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-312.pyc index 836b743bb8e6d242066cf5c1355acf3b5525f756..f91411a5fea4652190378f649c43f7d2fa4e5e72 100644 GIT binary patch delta 113 zcmX@E(xuFInwOW00SF%V&P)3wG?7n&anVHeMa+yv|2Llb!^~F6T*<6yw^@$WgGGQn zC9}9BCo}058;DVqzj+tuM^-K~pk_uOE>4`hm46yfKo7eVGd(rNaanjTg?bk!oa}D z0Os4H@g30kj%a)*1izBGl3CMv^Enm|mJp8Q{G9xv#N5PN>?xVWB{`W%x7a|8qWoLT z#hDdVoIpY^H@_^kxJm%d)GIB@0jjJLLl@C2NGvK&-K@s>k(J8=>{bSb;;zYx{L@UM zuCPelWZ~(Eyuu<5q9d-bh=J(P7Jm>GeT795NMGQUzrvybW~g3aQQLf&e=j4KD-#0? JZ;?6BJOHmpQ*QtO diff --git a/venv/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-312.pyc deleted file mode 100644 index 71fdeffce05addaadea1e83738ff6b501bf52ad2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 41256 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 diff --git a/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-312.pyc index e37f67c927aa681e7f736ca7016813a0b7e1f93b..3b2ac1a275f2667f78f78e5dddf272b9d2da8643 100644 GIT binary patch delta 20 acmX>pa#Do*G%qg~0}wp!owt$Ojtc-kDh0;? delta 20 acmX>pa#Do*G%qg~0}!0pJ!>Pk9TxyUZ3Wf< diff --git a/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-312.pyc index 25f0f2c15da3299e386a32e30d1711977beefef4..b7ac479ce088f8bef4d7820a1d00e54b30ef481d 100644 GIT binary patch delta 22 ccmdmNwAqOFG%qg~0}wp!otJibBd?ky08mf|3jhEB delta 22 ccmdmNwAqOFG%qg~0}!0pJuB_UMqV{Z08wfOKL7v# diff --git a/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-312.pyc index 1f0c9fe696703829680ba6900fcd6f536c71e119..26599ae22b1ec2bbd5c30fdbb88af3c991c188c1 100644 GIT binary patch delta 20 acmca2dqtM}G%qg~0}wp!owt$uBp(1nDh7T4 delta 20 acmca2dqtM}G%qg~0}!0pJ!>QPNj?BWZ3c}1 diff --git a/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-312.pyc index 39e365ef6e336ab6f6cade0bc305946928ffe9c5..81444982f369063e20fbd63b813199780fa1375a 100644 GIT binary patch delta 1023 zcmZ{iUr1AN6vyvx?$339)a_1Jw#}tZx=`jI^S?z!8kw2-QfOnjyE)T)^|wu!ER`a& z!paUI7`Xz|NPLJr^c76xxe4S#HWdZ z4U5Idv1fC3F?6r}Wx7?d(AZyfz6|ZLW4wcb*e<@XdD4kkNGqCo1ijF99RPrP}or)}p+HCjPUC`I)HSNfP*~YTTMKs6-)j9Ek(P@T1 z=F5qg6#eI>&NOa}$g%AJ7S3qZO2+@1&?jgoA|4|!i9Tfz^)z6|54F8qM50Q zC5f0qsK*1S9>H4EL)|W2$?rqZ*8EPdPLKjyOO?39)-y)GKNOF}spR+5JWRlQkTDD? z;c!F_XEf|^hSPx-o``tb)P?XMmJx1*li?5FJgfxcLsBbE!-LjD;c){g`^6#EO@9GT Ck?(8( delta 934 zcmZ{hUr1AN6vyvxbJy#x)44kx>D}&7XWk%nK_&AK1%ZWTMZJjOR^DySbXR{~Lu>w{ z?9WR?2O~z#D0=cC?7jp+5SRoK1ikH{h`^U#q~3(6-rV@+A-s|+4O$7H8wStV%V zIKoX6Lxk>nMJnA@IBwOl8&MgW10GV2et77z6_c5w6gTXIg?fodu-52?b(bXadEam) zycZ>?afy7&c9BzyfR`@7fOL+CU`iX}6IM9SZ3|qbY=ZkiiPFym+J@*x^dR~W=Mfs5 z@FhtEUiq3x48Hn~lOd>5V&u6wqs&=J9RAey$Qo7(d5>zNjTlD|;}ESIAWn0=?trCa zh$+2lF})01fupRc+|Wl9^LoQQf%X2|^plUHWeB#LKam8yYw_}iAFq8%dTfLqH=5P#E*n2bdx85Qf=C{@}ge-#^ z@{tUj4td20mOBs`7z@?xJ3kHu_MJCE%G@%R7EHMpm7%uCuv2<<+K5j0Q~q8(xjX$0 zdm?G%g$%377GX}c|F;QU!FDR*DFRLO8H38xh#L>NaSJzRV5;p>wT79Sh&e=V5sxrR z!&cjpO|n(}J_PgaANbr0GSJ=8puS-FtUVl#O&XIl8V*w{8gS#;;t@R_PbA}63tPj8 sneGsXihHGAgdgz|;X}v_J3{-Yu1$_aJLzlK?3^y2<%#l(L*|P90j#dxivR!s diff --git a/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-312.pyc index 2fc995f0bb02b446d15b730cc1c2237818d872c3..56e5225690839d36681e5635ea763688d1203eaa 100644 GIT binary patch delta 20 acmaE-_)d}gG%qg~0}wp!owt$uu>b%^%m&r~ delta 20 acmaE-_)d}gG%qg~0}!0pJ!>QPV*vn24+iA` diff --git a/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-312.pyc index 5aaaa6173668507a9d009d87161f82aa01b1dd4e..919982ebb522dc06c247bd8e2c3471c73a9bb6e7 100644 GIT binary patch delta 22 ccmbPfGSh_jG%qg~0}wp!otO4#BQK8>08DfS(EtDd delta 22 ccmbPfGSh_jG%qg~0}!0pJuB_bMqVB%08FYkqQW@@4OG?9JUZdu_s8OY7N^T(I&e zYgNG2EMRYLI|98N25@so8lsUXh5M&P0L9>w1M#SOiP8ww4@9lpsmQxWNgBJu-F+&d zjj*MLZQGAyA1iUx;P#b(gJ6CUFPhFnCd=*c;K)v@X2>G#X3+=$-f?eBWLVX=rCnD8ftzir7L5#R>J9@%|E7UP$DBu-!_jE} zaPOX~`Xt~AGxgiKrpPRjQ`Vrr3wXS=900~bVH6Y&NUs3Y1L*JA1{#2q|JrxNF6Z8; za7cBVPH#%$GG#<|cgh5s8M#YSGH4cLDcZJzR>{8Po@Jl%s&GBq$~%OMm@$8`@ZTC~ c^SPl285vX?X(#)TU+we@*pGi9UFfa+0lZ%2LI3~& delta 2261 zcma)7Uu;uV7(eI!YwvB>^|l4KS(Xx5unq^?3L^rBvY{c7E+Q%`VC{PDurTR7w*%XB zDGxK5e;&YVvZ*mFAt58iMBNLCi4lD<;RW0S%YD%|<*hIh3B>64-Ik4!>z~u~cfNam z-*~p6QX66N$v&9SQ;{k{8Tbi- zi4#&qa-Bz6nTL5=!TSW2t)M>|oq#e3r078fY!$-Piu@V*9CWSg>e}iCQfw@Mkd1`P zl%UKI`S9==@{Tw}&QS31)`J}nk&+=&A`jWPmf~$d-@?~3C4gLR_tsk?J|V!<5>mTw z{RPdIvt}-zx4oIsLYA4C)77}lHvnyGuVzQbjeVRKxUDcFS73(iIc^lQ#Ui%@Nx=N@ zc(LvfSL)gCgg~bRwmMv3rOZfv)Ud_VP%{O?Sqwi>^NMQQVoUUb_K7x|n9~r7%+U(h$q?!BRJx~X^F(7Wc&Ea-hxN=;GJmc{V4 zkNaj4CueueJwLbO`ufB|c-vRUuN1!@S_ltb_YdB?yN(3g?hp!V2(`Z7UlYN4a5qMR z?RSW%w%k@oq^0Ho>%NHze0NQQSwJABDr@oEo6+^+5w#2+XHoc~VyO`uz> zOHBt3c0dSUj}QT{#j(N|$3xGf2D}GljExuvYa_sSmfv)^cRI zT)b;}bOt6`!hL;~)Iv}(z60zWN;R6Jzj^`uHQ<~j@WWvJlVZ24V)sQ1X($HW6dmE^ zH?HC<|4+ppSH+$$ak*)P$6s!>l&jKC@Nr3Jud7t=l~q#KpUoH3FW}G~gjWFIpgLFH z@}aBO{UA`L41iLPmoDL|mH5$m5Imwfsfl}er*%y4Is|teiA&CICO!3Rrg1$E`V0l@rTHNn}1g$U`60R z0v=tEwI`ft$Bpi!0l&hT%*c3goEw=8hhqholl4(}x@~ph?t6E=RbbO(5gPzTX$D>Z diff --git a/venv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py b/venv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py index 3e83e30..fbb4ecc 100644 --- a/venv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-312.pyc index 6718a1210bb7bbcc72b760aa43ff90bf6580ee7e..54419af9e12c74c31f31090d2db30c66c848b71f 100644 GIT binary patch delta 20 acmZ3+yo{OqG%qg~0}wp!owt#DHX{HyMFq0} delta 20 acmZ3+yo{OqG%qg~0}!0pJ!>QPY(@Y$hy}s` diff --git a/venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-312.pyc index 16c91d7e24d19dbe6a6f6e7c2c51728631023ed6..96ee3098a87127896ef4015c0924b5e09c15f570 100644 GIT binary patch delta 1954 zcmZuyPfR0K7@ybw|0#t+3v?+IgbKK#xEx?ND6+_|0va~#7TH=luXJRlg*Ve(KqDp+ ziOFsvdC`Lh|C|hR(4_I;iJLJo!FY0=#CY&zHkzziFP{9qH%N=wCi9!`egEI@eQ&xy z{_A+?`(V%~!SA=b9~aI=_d_vqZ@+JBNAqU9M3N=hsrod3#xG=-8qk87pccx6#M-Sk zXyHtlNYuju;OkKvwZ=@NuzA&p)|6=iIU@UZ9hqjEG%d;gT}cic+OVJ`WuihC1YL+m zY4Ff-qHnRK(76E&VK9VF4XtvM+z82HTefub{=;O-ZrWz%%;3U}`Kj#W3saLIlB6m=vL8-XtF1QJByUj+V`7zX8mjZL7F zD|?$M22DE|Mzbl@IdA3E3N_tyb6sIn7uj?tSTGZ&`YD(ojQ<_%C!^JKp<|L4O?$N5 z8kH5MvoXx#2Cb-|wLv`WL?P$hyKa?Z%H%doC%9j#Y@vv#ssT?@ZM zCUFDM@dO&gVPJjMits!DvW2qPj7zT+3d*Lni8?xlBfVsgFGeG6~P@jA=iE|=S znvRunS+)AKD=-n_s24HqApa|Je&+&+rX8Z#byQ{mpe_66Y33H0aq7OzzfUR~WI$nDmBzT!FnX1&F+u_S_-zM<_K4ED-Bp@@(}sCAgfCBpmg=mCIT>4DAe^gQ$t=Q+y}&G?-Du*>SbmN9bS zIgrwJi;OtP)|A<6JF=$B4kmFy;B9(Vc`n}RU8P2Lr7UlK$~R(10~!X;0Gt_77&Y0t zvvotym*PX@bN*g@z=8YVN6{939AD_7m_pZdI7iH;WMZHWAeFLeycxEUDq4tQDPn?Pw10Y_rnJ2ST=F3mD{ zRZhKbp@ipZjk~y~anqO07Ai)C(QKAsLG~0vgx~Mz2{SjyrW-%Osn zk7kNDCfYLApM**o!@V&aDfSpb5J7z7QYeYaf*9P%|K{=^&$w2WD=NLj-U2IuM}Lif VnTWXuev}4&kz)M2#FRMxe*u~qs9692 delta 1868 zcmZuyZ)h837{51nNiNAHOVc!MnkN0bc4=2y<|@c)oz~jcy6#`GTV^@3++~fuB<{Tn zTdS^uRS_I(c^Pc`Qv5RL_Q4OuFAo2Gk%2J3D2$UbhKPbp94dmJe4h8ZCOQN8<$0g~ z&-4E7a&LHTIP`Te=ojE~`_{Gm&(XC|6S=+Cb6}YWnxMH2U(uiO7Xz69KYI+N7|aBT zpvzPNyVnR6Lzxh_$;Pf?I1>iBPV=ounL3v+E@=K0K?~e;VF5wNM7T}?T~Lqc{+rUa zzMkttpx*`h0O;$TfT$MH!jP|60GcPog|&2{NR7rDWn^0yOOob{QBxzYI zOP_~xP19(dU~h&K6A|))2h!Tc-wC7LtkW{)+b)z6;6OU?cw`zavi~}ClPAx)jY@0 zRPFEtOGTd;?+2x=m{t~8S=6ohvPO|_&JxE^nnIXBI1aEO&>@uZ+G+bEc$!^_c90mm z75%`&&F$<^!^1caaBY(Zd`)~_Ip1bu$>qza!7F-8xGO7{l=qd@<5xPqlasu{^oCTk zgX%2{3gH!mIfOidicsw?i${b@@HG{H72%;vbjyGEi91D|Mzhdpd^6JcBpEyi z9%<2;yb)xFG-9=Vhb$tPIPux}rhc-{t~Y(&w}9^B7+=dVpp51`ZnX?sjrWu5?6Y{E zgsrkK8)Hmtp6SkE3Z6$pNe9?j7b2f7=C)}COsTq*FyX(MLeGFM?fu{78t7g|cx=t^ZlndYAY5gK60Oc!3ydc2)cHVZ z`*PXbyslQLK}XopmRK75Fhu~qMRW;+QMJk{zD-qpyU_}$KVqvbdo>&ons0_5hr9`t z_=CqM_3cawUgnOMg%W1~rw-CS9kczany*+Ds;er+4(K34n6)Ll*le=hK;Z8vPI{i1500Jwhk1X?!^N^zG4v7oI#>yOO(gAaA|d2YSsS_=G%qg~0}wp!owt#D78d|It_9ry delta 20 acmZ1~x>S_=G%qg~0}!0pJ!>QPEG_^#@dfMv diff --git a/venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py b/venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py index 1fd2801..e6e3a57 100644 --- a/venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py +++ b/venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py @@ -6,7 +6,8 @@ import hashlib import os from textwrap import dedent -from typing import IO, TYPE_CHECKING +from typing import IO, TYPE_CHECKING, Union +from pathlib import Path from pip._vendor.cachecontrol.cache import BaseCache, SeparateBodyBaseCache from pip._vendor.cachecontrol.controller import CacheController @@ -63,7 +64,7 @@ class _FileCacheMixin: def __init__( self, - directory: str, + directory: str | Path, forever: bool = False, filemode: int = 0o0600, dirmode: int = 0o0700, @@ -79,7 +80,7 @@ def __init__( """ NOTE: In order to use the FileCache you must have filelock installed. You can install it via pip: - pip install filelock + pip install cachecontrol[filecache] """ ) raise ImportError(notice) diff --git a/venv/Lib/site-packages/pip/_vendor/cachecontrol/controller.py b/venv/Lib/site-packages/pip/_vendor/cachecontrol/controller.py index 586b9f9..d7dd86e 100644 --- a/venv/Lib/site-packages/pip/_vendor/cachecontrol/controller.py +++ b/venv/Lib/site-packages/pip/_vendor/cachecontrol/controller.py @@ -142,6 +142,11 @@ def _load_from_cache(self, request: PreparedRequest) -> 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/venv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py b/venv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py index b9d72ca..f6e5634 100644 --- a/venv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py b/venv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py index f9e967c..a49487a 100644 --- a/venv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/certifi/__init__.py b/venv/Lib/site-packages/pip/_vendor/certifi/__init__.py index 8ce89ce..1c91f3e 100644 --- a/venv/Lib/site-packages/pip/_vendor/certifi/__init__.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-312.pyc index ac9a8f0a213005d8d50e14eb6bd41c8e532d0ea3..d3fa27bd1099bf4d9f26dc78ca09673b4c711759 100644 GIT binary patch delta 29 jcmdnUw2_JXG%qg~0}wp!oi~v?gUv+Gz(~(vV&x71bmjL&2Ai>-fw`X1#L682bO(E)xJmeFi%K diff --git a/venv/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-312.pyc index d146333d410ac9dff97acade90ce8a90bf1db17d..33746ac1405d58dffae58f0dedc24134412c5689 100644 GIT binary patch delta 1537 zcmZ`&O>7%Q6rR~1d)8ii{gXI0AwMb=WE&c2ibM}pQHVf2Kpmwy&=u0k^=wib|CHIS z(r~~*3Lp*$szGXnq6&^xFL36@WomGfuW` zIo7`%rVlwZ2M!~`IVTs%ypso+X%*Tovaauryeb4I}=#j}H@Q!5lp7q@iB+KXo75RuUV5xXoe(zbj^Czs~I_jMA)?={s}jTH`Q z=j8U@2_+lErsr%WOuLHV;P=)ZBWl?g5l+x zk_Vdgn^wN7m2ZsP2)pXSoS%2|dT&@L|gpNzq4@77{6rI2mt{Wz50frGW z;jJ}%*o&eNNxYA2g@L#9^-G@c1eRzNrvDbeCV8AAX1Sl9dR&qpt8*g{%)%Gd&#K$i zd*+LOTH}2-E|~m5U0=?FwLs#bUi0gX#w{8$uT$^xMrX}dBbowJ78=5$|0KZb zT_D^Ed@&7%b8<^N@eI~X#T4EdE=rV%2$tb+7xN1}XO;Vvx$n#$*Y8=?KC40nmJ-LI;XX`!`}PEw z*lMVCFMFMcK&WBDZC%*t{usg}!Yn|j@mf&xv1z7pM2#@ufn;j3mHgYpM{PY+y1qCf z>ukotZaE0BCBJ6#lt~Drj)92h5&kcX_wn!rguTk*SA-wgf^ZZeO6v*vy-}ny@+afD*M_-0 zVW-<&ex>D|5es0BKh8G*cT`I0BSoj$u1RS6caquFD4pG5aw;`pj_J>Sd2*M4*qN7S TQ?q7yumNJ{71>K&(=fiLY{V@B delta 1184 zcmZ`(OKTKC5bmD$>@&L?H*R9$BZ)W|F(x1$Vu%D$Q1O+6j>5QXcXX3|gr12pUJ^m@ zBqX#D@a8eUz=K|cf*19mG9r2qM7*r#=E30WbGxP(!rRH#ciozgI;buo4NG9jV>Sz1M{YOYq*U7Zr96b<;9 zOy}05!i?LRYj5}___2BAKYUiiw}6B;5XRj^HR&e*B8+V!j5i4*p(!^N*|eJmo2ax^ zGj4_wp5f`KzEFZ0!GC?SMJbpNI2RDmwph7qv$PoRoLXE}E6A z<~~}GugwRiwnE5JL#;l;YY}~@VKYD-PL1eCz(Ena0YZ%xgQAaLYX`2VN6i=U*-LWG z`jWtgJ9??e)z}XU-p2zAX&w~+}_vKow@7S+l5>ZF7%gwgptVC@P-RNych}ty(UZ@B2Gu#gi zFfbpYR}RK|ue9p=ZjDsyY_`Hj#Ry!1zY5}0z=ldG{i^6xTTc)gZx}=~U#qznYHn%n wrP}jJ8~TvVFP?al>sUP5(DM4WrQvk~rZFfV#rGyUng?JSL-JdES;Ja?0JyUCBLDyZ diff --git a/venv/Lib/site-packages/pip/_vendor/certifi/cacert.pem b/venv/Lib/site-packages/pip/_vendor/certifi/cacert.pem index 0212369..fac3c31 100644 --- a/venv/Lib/site-packages/pip/_vendor/certifi/cacert.pem +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/certifi/core.py b/venv/Lib/site-packages/pip/_vendor/certifi/core.py index c3e5466..70e0c3b 100644 --- a/venv/Lib/site-packages/pip/_vendor/certifi/core.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/__init__.py b/venv/Lib/site-packages/pip/_vendor/chardet/__init__.py deleted file mode 100644 index fe58162..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index c255dde7b973dce5ba90cf0cfc5c4a1c582bd396..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4555 zcmd59ZA=`;b@p!W`?v!RV{E?GKENDtFu^rn##F8WL->k~6B0zUEVsjPc<=T+yJw7b zNF<6>qDC_PQ=`_E(kfDIIaU4BQdOx^`y*2SaEA1*D_ceVkeYuuxN7TPeY1PZVjCw_ z`X?*x%$xV#ym{}VwMO|(n)1Ut#8At>t zgA9rx(era=ve<*f648roxCEEZ+77|Gq7R2eKlaW##i9=!lVu(RJf+X^1c1ljW3ZRb znstjo;6AWe90`2^V-&Gz>~LIBHOHIDxSafgp*Th>JvS$iajc#vays<}k!LUgY*7Kb zi|`I6Q)zWv6;upl??tSnCABvmRbf;D0B{M0(CpQxbfp9$By=3HE54EjNtjb* z4qp=z@g#0Grm2f5gU6c1O;6KF%JeiRlfpnCL|B}j-n-O(+X%~!>$}S>V9wZJ&e-5x zLlj+xuHH)<&=PEq6D}bW42_6Mk^>XsR|N?tRpq;TbbpB&RBu_93MxN+t?yb2PB9ia zd1f8}-JPcC3bm7(tXp}Ui^*yicZVUxusIR8=8Y@yq@oJoKh3ktra5#cX`V|UrjHPr zXe@Q65e)1s#-iqkO0t3@c0zYv7pJ+6=#Ys*&lh;$>4n~|sq=AlAU(rDWX@w%R;HA6 zN+v3vg1x>vH5{LrQsOFpH6=tZ3o)!rrQ)d*5P(ThCMTj0>LBw3&&QK-mFJsNi-aCU zy{Q2}5usT|Pb!eVe0A;<&!(^GVerse<0pNa!KR0$mHEBIFYVZE zp};n>6$PF+QCaoc+Z&;V75Bp+x8C;pW^ibEAkX^0Kl0wlYU3tbnfHZm^nBQ};j3I{ zD|cWWq!q_wN!T@Bog*0bMiQgDfdph4f_g|lfc9G#(zZPzZO_=hHl*!e719v$_IY}Q zp8HftNX9o`WfSp=*pn(=)r|%DCo_nOLhgWiPoi?)iv?HzCns>Ps47 z{U#G{^`r{$$E~pm&7UwKtIxPIF4NDTk&QIL+!l*&Li^7BO8uXa%kJxW*VlO0Ip1oo zZ}p<{mfiFK?CKv`q@FUV8P=qTF1iaOptf5y(ftAX)MHvZPS16RNwxYI14+y)^g=%N z(wn`I#Gnk&6IV)Bl=zHfWi+^Tzd=f)lD}zQ)93zg$?f?|3=-R5GAgCTz51(jg31Yy zp=PioFX%?=OYGZBPrp!6HIEFA4vxGz!e1J=*f%~fHr!iCSNjUkk?|y?Ra&Mgd-L}` z+CH2A3e~|&a^<%&Ws?vbEkbX|XyGc-j~cD^PQt&#K{JFHNFo{ZE>wz3OosUpbCZFi z?Pk#;`lWq=i7=ygXpL-ZZqb;OLg#WEsfO;Ur#ps|_*#neT(34#GA&q}yCpd)NJ>xh zE_njD6?%>T1O0m$J*esY_`Hej>ynr--jTcY@-Ac0wPDDfvOy;WPS6gM+%0x zyCoqpBMLp&tM;{{K)nJp6uQ7Nx_9-ylx-hcZyQ=hgjNV3*nSx=MykmH7!jIp$U)lB zj6$d`dQn3TQ;6mh%@?OH2Phfg=|J2R;~5w{Kfr(QolAXMkd`D0R{50v@=yq^<25I~ zrb5M{xe8d#DWp;q5r_fn9#56L5EYu=lt^C;ngfCj6U_^&6IEG=t8-e>oS^Uv@g#55 zWWK@iF@9ojlpi_!hGqx(ns>PG{MmEwPz0g5L9;_4sW}x|Wr^e!z(hPol}0n2UaAqA zA2nCOzwg*&q0j*W2F{kL;xCbDNHHo_D6+WK5=YqqxaL2bvqnN@$j{229Ctl5vtYsa$3hBiaP>;B;_ zf7y+(569MhRqJe(9xS5~raxlq?~jygPN?_c1x9E=OXzK&l@<;|j6S>zXGK5#MFm0u zN6TQ%fs^TkVuX*^IA$U|z6m`;T1nb`e;ZLP6XRjwD!jY(SGE4W)?7Tjx_I7*SsJ|> zOW!`mGeAFn^!m`XH!eSSH@vCR67C^GK%ke2as!%eJHs&lszXfe-%;x$)c6QhKSDuvwM0+mr{yJH0DSS;v7V9vJEh{}<{sNml>> diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-312.pyc deleted file mode 100644 index edc24d14dddfbdc4f216379a88d3767855d300fe..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 27186 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 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-312.pyc deleted file mode 100644 index 35e6275c1b1a753be493874ed3ab190406ce9e95..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1374 zcmah}Piq@T6o0e-v{t1!aj;{x7dIg-ONk9Fp(V6wYrD8DmRrzm5e%!{v9sx}q|S^& zWqk0#P#GF}Dh~Yy!TkpP0)<{$l0#W+DCE?esbUB@^}StfqMSOQnK$pv`}g}j?eFz^ z6>$Cb>(ARy9DpZuDVIGF#$Tdv1QA3mft2}-k!&PJYWij_n~9a$zMacf;-nS7!oYwH zi0lK19AO`uMJ(SPRy_9~hBuF8i>vX@&GlGm8FvOc?sY%y2FXyx3T<<1y(sSPv~-|F zGYId*U4hz#<{;7W>QIZdJArHo{k80MghWey^^1+0yw&8*uhu`?3@4@M$0Rq5H}U#C zb|S!M5%@-Ak6@cc#zD#4qedmSNn$lKA@E!Br7I;opr51`JGDiwM zklm2FD;MRa-*|-EPwWVEX@Ntw2lo-R?y zWsL@33AupJO2$I5*Bb~X3JkE(8W+whoLU$;VgmaI{OO%kx`y|Ijy7ZK`t7N#1 z+p_~WH!OSptOm}7GlSU+55j)|kFi-Q&YX$VcyNtOjokDU-!}3V@_^L9#e6!Z=CT;o zxngt`eK*qLyO9reHk)=PbQGf`37X77t->*V@ve_VR|9PrF*{SVS8NA&;z diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-312.pyc deleted file mode 100644 index 904ffd8775badce664b7112ac8d519354af9a019..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9625 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 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-312.pyc deleted file mode 100644 index e95cb8b296e3a723cab9b20add9cd2e70719bc0c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4109 zcmd55^uJN=tXyHZ3IUu4wz>4H`L~vDc|% zXYY(FVqDaR2plQU78RvMNSL=RMJwJY0tpH6P>BaRX^V$ZB|wOWeZp+F+SNXB&K=wN zS+`=}xJvFl_uez--h0mZ&N=>5DAY-yJ^1ZU(lcQ~{)v-j6C1>{Zve4QbfR-PvdAU4 zMLxkV`Vu~l=)CUB35#MvWVDd;FLoq47Nvy55uThSy0}7gzaif9d9o6L#FJP;pnxXZbrH{MCo3x@R;EzBEK<=w8?WIj_&W{l}<&N8Sg z<4!i8xnLzNBjp|7^{t!#0_NX`yBj3I=_J7$z6EJ3qerJXoilv+mb6eIFcVfn2~iI+ zT3nG6expO@4ao@f!Ut(y_pb=|8e$TiJN7!Z>;-knkd2VhmFDqFkP%J`dSFFJC_wK5 zNu5A9zPhnj_kwki{?B_Ts#*02!V5@&+PNysu7Dz0)=h6RdWsG=*H z#U;?cq-oiF*3vXLs3lWY_KKn9i;Hf@5;K_Tc5Cy7X=$0FVVat^h(t2Jc7D#xTE^j}Wa={b zf;qR8U7FBfPcP7k6u69TSZp*6D}!3}PCl}wEUC=WgacB)-5+cO-EL0 za^HsBSLJMZ@Go*-y#x5_5*Z$4MxuK`>^38zCo>~m17aOKegVdv&FqKum#X{)-*L+? zkl4;37sy>M4$4Cvx?LH=(o%(dI;$J`l;O(g(V%lJpIkKVa!kV}dRxp>=>U+Wfi^1L z`rVg+$((}j8u@!TQVWl4gh!al25foYu{`KR_SPcf8|t~9@F8JcO) zZ6Uf96@CZSdy&Hd(*FQR=ga&8I_QpOa%&3gv{1UaU2cW;tG==i_`Xo~S*=LYF6CVw z13ZqGF%7ijz5EN{Y)J&S@7g@QNu_v>Tp-&{#)!M4;mL5rB1Ar3YsF0#tuUnQXgXg4 z>_W5(G&kVvc6`3e`>lZy(`@tWeNP*1B27mngMeWTqERd=K12r9n&**;aKtaSre~Cf!V15v0 zrM+!njwgN%`F{=FHR3eGWH>MaVKUOYe)2~r9i_*K?pvR^Ia8G$Mb*lgzeaj+Egb!+ zTM^23ua{O!52fDE2AB?b42#Zxd_O7#lX>&)@1(4Cko$oc?#gVmFfdf?`vC z8hkd6>|6m!6Qd#Gt^qtu zD5b$Rz}uduF9DnRXXpTeN_4&RW@klog37JgT2!^8>PAonXfzf^?da%6a1Zgf3(GgwmwZDp`J@vB#BlhgL(^kd~L0yxrJi;UTku}6{d%4taG z*JoB|YI46V_dCkydwXi?30pmJKmGf{Zwe2rk9>TntL`UC@9krc!UIq_-3TzyKT$^O zyW!CK9)M({IEd_V!aY#;GH9wig^H2H)hL$yScpK$->GSf1-+OT@M13gI_{wM@}#Tpy%I&o*clib{7y%$p{d1%@Q0$z{*d82Vf>ohu|Q zFTIBvzZz0TE~jbm(*)7MvixgauneL|>`=D(L+CzPAhAA3{0u)f^oIe^;^qJ@FSLDykpAov=M3) zaE)RbBcdxB@cYVS3ifn^kGxAfd5GXor4yb}zDiHR6tk;22wmOBaoopWCY)-Mv44@V UzmbWL{O35X_jdntf+G|0Unk!<{Qv*} diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-312.pyc deleted file mode 100644 index 50ae213f33f0789d48ba584a806b324af242bc5c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5005 zcmb7IO>7&-6`ox#DN;YAEK0O~EPEq6mY7&_6UA-fx=vk5u~Z0DV9^aq%cWM_p|}#c zWM-Fgs8Fa-7zK?wh}|B{w1=uU1~YpnUTCU&qgN5%LclREkvY93-LhfT%c zoDg(>j)PE8wA?cpQ%mbg(sEwcq4PP40^K{U=!;opk-niNP0Fm+H(7c?(-&t=#iYjb zz;r_yUcE9Lx%tA4_2I8?zE~Un#GXLv>oHuXQk><^feed0Ae7)4Bcduq98_B3cB-)2 zZCp@AD&e`~lIpzejJVWea2hGnMBS=`dT4VGFvdl->9+K+EE;J!H0Q3HYgIk8je4ms zE}|spXa~*Bpz#=&Y6o2{b^IN`;RjkPaCFixwe66!7o@#){DC8Qe8A(Y<2il=59(>J zr!(WvFZS;`w4#;C5i}BlqLLO9kn@mIII>v2wy zn=rOx3r0N7?Y4*&9+?YRzZHJv%p}&S3!Ps3VpLw6#azDrSV!0P` zCWUxq4Y~HecEw~+6co7=*lE;k$ExiLDNd=n+R;ZWej?}I7>Go8ER{de!YyXEeE)+@Lm_ewbq1jzJ7Bw}Ix zSRIZCFQj!eme%8%O7$3BJ<)jl#@TVuP>zaSUx)1p$3iyVU;f3@1t8T2c9#vo(S){` zi1OG->&e{e>BiF>$#fM}p;<7(+TV}giEnkC-IO+CkG(G!9B|G;^Rt$A0Y5+F4s_}d zS-Jbx1hb0dOO@Lecq;`CT{g^`m>0*%%`rH>BQGo=DjzC&2b!t3Dj^V{z+K%-)}*|& zwpOVZZlm%*Dl&QX$)Qp5&p%`-IT~cM%02r9A*sq?8a>GzYID(sq zG7$XJ`tYCsaI-3xQrI$Oums#vIWqy*lT4Eam2Z^aJBQfA2@1M1SyP5sjZ-Ga6kT4x zlcckY2~#%HGGu_MXu7P(24$LkvRi4U8gS~QmV#SKt**Y1lkE){BXT&Q8FD5%~%z!R={_*>u)`{k@&VOy$Ne z@1v?tVN_-`lT>0<1<&Adz&J@N8*s-`SutXoRx|8KRn9&Jf5pg3CX+-9z%g+DMvQ40 z(~xf^v{*t`)3Tm6ax?uJ7Yk6Rnqd&_y>VB#p3T^%|SA&%gjhEo_TP_2_Mdr4>iufAJwf7wiqoqN(g zy4^ndXzX$Os|Dv?XU{%q_6!!rcUwE(pSd$r9N+M73>2q!TF;hRNl$MyZU7nQD(GJWpjs2} z`eDX}Glp=tCokn4%W!e9!MtcZ4*+xoT;&1K@=^o99mxluPUZc^sn(Zy8)>ZOJ{P3X!G*`6Z7+S&cc%(Z~>AHt`nd@Ce`O(IR~oB zDp)5gx+>#c#Nn})ab+ODG{rOmoV-P;E?>G_$5P9p`m8KNmYtmH(aBi>v4ymmsHA6g zYqd1xo3nEZP~yt$*wj?r^5*~~O&L%vmSqfHZg6aVc1U@Il&Ze@`Dp-d{U!U0Xnwx7 z?Kc?Se3lU7`G1+=?Z>;9I243KkjSIR(VU{GG|R1M^p+*XAbTwj)w3ze;46fE8#sb4 zp7HEePw!H%zqmR9V1;=M62R9wR(f5hZbMj88 zFn({S)b8=VqH_P8d(v*t$@{LoV?D+2<73b5`i~dS{PMfMTPe9nSO0^V z`!gG3@XiQtgmyYd_c~8-%J@!aaJQ%bzN>T!6n}AsvEdFq(b#Tvj zyo?F(oW+m9P_Tz}Kx;Keqp7r-P2%TSYc%?HR!NpW);eYy?n zHcJZ4geF)3x~vb!Zur>BP-f;B;s!jqOvX;)>;P60(wzL-=WevWah}JiK|U2vrWKO~ zvEPcXS1p#JaMh~pJn~$^Y7#5{9>s4N?lFeAz$*X__D;7`e!Mkud3)&f5&^;=r}nWa^Fpum1A#N2 zadtQE5C|W4?GtD?^A{rY_#MGb7;ItqZxkDb%5uS54PF7N%l0y)LgNsD){f&73P6qx-&hMQZDlYtX>4T+R Z>D2>=cuL$NegAG=7KHA7f;Hdee*l~`!0G@1 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-312.pyc deleted file mode 100644 index fb413b07f711548d60232020c54f410eeaf6e956..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3865 zcmb_fO>7&-6`ox#$u&udtzEK;S%(7|w#?e1q5h^yk;0YTq-~-Gk_!~HfW>NeC@r(x zrDun-rO1E}J~%*&pg>W%KS146Vz@wk?%nk3|3xJVwYPaM1e#165Et+=E?Y}HP=N?UEH z3euXJYHJNmAu4&9*y#tv&OB9P&PIAusbxRG#o{Llj5Q@HFZj0Ott|^vu-8m$-SOCU z#}aT-=r84w6-$W60gxuFcL*a5#U>5aRvIZ=WtyF`wWbEDwMN=5*cq5Jc9v!B6wAWC z4r^V~s(lLRQ$XjMs+|Km&kFrj{(<(iud^|+snsT;)5npTzXm8d3ePnfparxYn?Qw6 zHyC%Co7AMMn{W`Y+g;{aj5d7^dmWPt$LhK!r?4wsP^UlexfI4gNX#YH8MT>UmH;l! zEaq&m;0kpFz2mqpZ8Bz4v2Kd~ZJ#pG3OX$T7p1Jju*?n9am`hiU7^0mVlLn|sc_n? zPH%#`!wlBC>8-Hx zK>uN_(j>g-H{nmV@V#QwOJ*bi;HVn?jTr?f8JFCW8pB;oxY->AD%vRmQ*_HuHqj zbeLU_k-c^!fz`+5*^UKyg7Coa=%>S$4<&%!Ly2<~o)iFf1|4RBN(=pi@(@J#l!L(S~Jd+~V1k z7j1ICjZp|7SvY8bI+R-wIH(w}E?FZrXh#{&M3;MuR=)wuhL(a6e+PesVTWuh+r*Fu zIM}$t)+`^n8t{rtvft7ZYB&R5I$7B&tOmD5G1+f@A)$t|IGxZ>`+9*_zJzdpo3y^1 zoDb)uGb?11)KZHaA>OPNqKwgoB6Xul!|HNwU~(FeVaXax!*H3$5onZ_Z6nIZcV!ty znYeRCS=V1%gV$1YYK@6kfo43?4Z}0r%rK%1p2AKV`Vtd0HPQm+HaR*aKq!=ce(U=D z%FB*;rMpUB=YER`KUfL69iI!fvcbHKl~=1h4YDTL!B`rD-A(dDS*)dGBshF%5ROUmMB!za0#rdc2A-E-*qRz+ru6;y@ir#a zeKKOqhx!zM4mKmj8lU+;0tJxyqy?9bKDL6a+j6`Ic|6V%k$i!W)*#D=a^AQExSy9b zFt~Suu9VcJ%5kKA#%n!6hKAf*kkZ@g7Et$6C)`U*EwRRt8s8>&m2vfKXSOCF+Nv>X z!ytY`YnMqayBOsy*9-zf;J1Y=$7nLCwstDK0>$`1Y2m6XiU1R~YhS>)eV-YM^1fbqbUW1Phft`+Gke8qSgh{qRhiL;iVv$q7T;MQPDB0 zn~%Qrf5Wf4@YURfuFk&-8jd=h&%)-|)}65ZYzXe-;u#5UJ}h3`)h|lt)>M89ZY}m2|zA$*1X~ zg&u+F@xlR4y|YUC{Nv>V0#h#o!@KAEG|5c%R3$z0==^7JICGGKjZbkShJcEpM_|OF zvLypL`dWm~Y9Wn`(#-3&gSdrA$lm~#p&6g+-;I6s68|;MnGTu9O`n zSeP1^vLYDR`3I1gP?qQxgqYYW1sFPUXD3J?PV)2jeeb<{_uk#7VzB_k`uO2>Z%YB- zn)0-6A;PXX45iuHHKTP@4)Xrmm_ zrM1lOQnD0YY(G5QNA-jK`kmXYCfD0Ze0vlT-0)oHX33dV7i2yV;203lff#g@ z2Y{$V!?34RgidswU>>%l0 zIHcht!ot{&lPIK&*heHdvhR9bJN6j48aeJ`Q9rgLFRCHo!y&E7vtq((ZrXI(#xQFd z%ci3d&50_hk&h;pV|oT=rRsQhqK>b>L{szftX!Fzm4CEz=g013cRYBtJ~ek{YiFP5 zXB(v#MOs>JcS~Ho&O}#!%QCpZMv<60mA9U@PW5FV*W^*?rsQdMS)fyMFPqy)z{v*Ky7XDAru+N`k73aa diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-312.pyc deleted file mode 100644 index 64510b3ad3781eb9ae9f12aec54a1b0023f9a8ae..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1383 zcmah}OK%)S5U!rrj-B-bL+mwNEJs9)BH{=*B!EJ|j)I77q8Kitm0GhiZD*31*`>QT zVl5whu*6y-;)ERW4K*<5MVhM>8H;c8UD5q5S?1asUk+!;~s_XTAwe#D= z#5myd>n}fTuG9ej)-ToL4wbq)kJC*m7S-s0^R%+Gs^fw^z)EQH^ zY(sgR$u2KqJz(|d;`%q}qxg{=fUG>QPj=t|!d#UjAS=*8deybVVYVHhPGys4Dy@n| z@5_iCxI0z(|2wOj1bT@6df+QpbUTbIpVG8QC8b>F=Q@oViw*o#O zjiD}Qg2}*Aj$qlQ8lyDMA|WUh7Dg@XKL2Xv!{&`te%@^@AVznYY>OsVZF9+*_gQhj zxtg|`B9-jjP88pZwwP#k(#{e^U()7FF|wR6xfFMh+>YV;VyDOJn0)(<5#%pcBb-Bz zxP;=_E$qJq!jZ9bsMzWvcCSKGS(o(ns^FX{7+8D^t?R*vc-M=|)-UF>os%;m2)}J!Rt`mN#@KZ=p~VL(*fGWt0YlzorZ7{;nBd zxUa8jv8WwaQ9Rp&Q_FMD9#4Zed2A7P?qU2d;4!c(!?8Ei8V}EDSHrkY@NUD5U=r#9 zrp=CwY-hQ!Gvxvc{r$+x?}u4$HI=u9bd>wVH8jdYtH5Q~%U?EZpw{e|A)fmmm*8CG o=h3F86ALJgZ9>TDWgwT2;JqVw{|FXOyeZQ7ede80z|-{l0(zZCW&i*H diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-312.pyc deleted file mode 100644 index 7c19e0b72fb79f4a79209c9ae3037ee78423b175..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2983 zcmbVO-D}%c6uS7k?o{Ov#gy!Kb?DY?z#7#&-+U% zB@uXj{^`5TuVaM#hJ(=)9TErM0P%nrq)rUM2w6faR1dYn^{_xfq(qGHJz_*2h6d90 zNWhB%FUG84X2fp_V7r#kRQS2{K%Z8HyeXf4p0~l4lV=nfG|=Q zz;q!)sE3VEJz|9GQ6o~1b)&hMFDZ7r<5fM~V>?xe!c*HaUCKZ+<*dz_%WMyi#He9z zZZZx->Y}(yb=tAbZN^>QqHrYE@ElGXaEJ{?O?xWP#?dQ#xT8I!)Lh&bHOAneYkL-s+QSpgLvX^=b{fSIZ0oYY|W+Zyb3&U_E2XpZI-@RZ&>v1Di z7mav5VTg5!MOkboPDp)>jj=dVObo`!ZXzf7>9TG&I}kW?rsXldbNgj|27wgJqnp7* zmwv?pU+L|()uo<8^+415`s&E1#i2{r*PnAGhYb-f0_;T)0%`)O_W;yfiYMU9(P(@O zAqn6|)QT$m*}}Y{%2ipbDoe{{WloWc{-qJGwvsO@HKn5F%f7gfU(TbXA6u-f$a&R| zg95Fvu;_>L<+2|iPV&RR;<)<22U(;hM}UMo4}gvfgX1KUoahz%Z@u#<@_PU6cOOOG z=#O9O&G%E8-dsPO?Unjcx>x9@>7%PRAE$5PICFpgv2^*{?Z?u!-NIlIRC~(Nuaa&_ zh|LYtZVnQz^s>%7PPjHqXXhu`iDw|m&hl)=iny5#YKUM(7zI! zAtQb-@-UbLMM3I{xrCpsvb!B-H(1%c!z^>lag3cWFSeR>EQ!5Jr&#aw22>Eb=~$NY z6~tsvbx1R=qRQgYyyk$6n_oW1YwyI{BXl^U0jTEOmaWlWS$06 z+R5adYcE=5>P4{vOn0$}^~jSLnaBj;tLDbe%@|RYOZl4eh3t!~YFSy7%eVa4@GCA? zs!*`t-&n)aUAM)ciyMB}v_1YI=s%lLH;{+$3A`@)|D>TnFPR@@6x1TjtzV-PPoUjo zzW?YcfzLsh#4^}_1{)3(H9*JlGxEg2`@p(5vasEB<2ljK6h=`{82F&O^W()~baDqc zF+4qPEzr!FLB4k1P{V=?{7Hw-d_lRBK(2yJAj%?oa@^J z6hL_n8dA}h%J9)2V*eHKAkl;Mu11{42~J43oy zM9M>?f|ON|wrxVSQmC|Q6Qzpwp%0bXr#`LJ7YszUMydLzs@kWLWTUM1sprfvHh-H| z>6Ltc&N=tYx%Zs&-Qz!bJWc}btKa`3_Ny{N{(%d#*)}GxQZTtsWFm73lH|f%(h|0C zM7GG*gf+>Bd40|&Y)O0AuFq|WlB5t8l8&$==?pt{nmyr4y2I|IC+tavxU${xgzd6hpWE-a!zEOZt<*uCHLx*efh**nY^Vskw(*2b zJU8s}fV|@lA1;-hw2YS1JuwSv0Zv7XmtDZwJ4Zg@!ro!x_h{w)N_5LrXa3+6p^Z$$ z6>$qgoK~nJM#RQwTBf2BouEnDC`P8HSQ^|R#?nlbsY;_NT)0S6AO#cUkgn~=6O_@h z8IeYmcw$CmG@2ey#WRty1Qn?gjZ9Gywks3ym?|pt#x!ilZ!rp@i8z(TbV^jyx~jNL zQ))amBdQZrf!*eZI&`k)NL+V^CrkF3TFeufqkgitTT*TAEsp<(CHqY+rUmAR zzy`iAHTg0|Lcurss^A~B(Uh8e&zu!U*tgeQ!EO1?d2uxJnl6wg;FD2CjLupE8C8*7X zof}1k4|}ilqAbJs)9jZ*L;bx$hDX)PB9O#4Dd?7>>FJcJ?U9Vkrm_?TSXQX2RTN2> zaR|W-kxp~;^^f$Q9|;66YIaFMwAO44GF1h%<`tTV>Go<4Ns1;SiXur0CZj0c{%)x6 z^l=IG`4*r*a$Y5P z24)@xJON08N26nEhE;;@OwD$T>oBkJ2(XoZLHF%#@?7xDmt=+NrH__{>NVkLzNU7L zzgwDjmE~NuSy%1nsa*ZpZ2j34*V(+g{9bTAm~%H|-3@Dv$A0_KYGd!3`v=?UYuy)D z8wb|hfh|h9v-RC8uI~R$xGP)Vwc_gfeqo(4P?W)j)XcI{t*_tqhT>JchB=a@0;>W#=qn6uy+P(!f+K!`AyP3BJ46}C0X?8K zYl5a&Es_slR|lQn${KKvatu@03`f?46cM`2z8&$S2lP4MDI?IC!87ldsx3% z|B_f7^>cx|uW2r@=01>jSKbTFhn~6X)@{J}#!kehrDMN7^UE`a$_Mcc_A_!SSaT|CaGS{rA~%*r7M}J`6j|EFGsRU}7qURY;U(d^>J% ztH4!Iq96v{Ci$w`Tvhu@Rr{Q}ES&iA7<9VjnlLt_0@kW*_bSB+F94i@gDivWy#?>l zZhi;u-+^nLwN8Tk_NH)m%YjqKp(20QV&>Q_ewJ4Yc{N$6XNt1d+u%m7LY7-4^qk&i zp_1IK;*l+xDu`c8F>k?cd>^(o*?Jwq8SML!iqDeXCJXPaNr8%tNCk^PQ=y6}N<`r= z3;u@5mUHYM+4?kY~_$4Xzv@AICRbsBH zb)~8`?>&(BwdH(WSzp(ey{o?C3-0`0-xsHHP2Jh1?v=gW`PM@Vfi>@Yd2e;j+qU9u zd(@ltwm=}CAnTXpc!jn%3n&s#ckEgxiCK6t=??gFTOm|4uMRr~Xm4PT7rntQU% zJ*$;H&l@{(jVH2=Cl>mCdMV$2Jl7t|wue^RuP*ehdEd`>oXB;Y%XXZ@)xmtN@8QYC zlWX4Q7jYERl|=467W* z>jcCaMRVW~VJtGE*KF(*@;nj-rQkXaUyZ!R;k8&|YhAA(_R@6=XKQ&dv7{^}UlN$UvYNzo z`^K#GLEBQ-Vmq>13+&c)J7?=zvb_Ro&$_+Bw*SGkrS3=m<)*G|-LZ87gx?)_gM)s> zx|Koy9?h=KOhFv$mt)+3XXA-8N<@Z$r&VnHSH+k$V;yS>%|=txNkzYTJ*A8a*G82n zl-(|n&}(VEg4Qc%{kxBeVFT6=-wCG-x1M1^SR!mH=$>^e$8m3Z2-oya()MT4`4@6J bOHRMB*f`580^K*|r@8$Lw_Xz%bZ!3uZ9=>` diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-312.pyc deleted file mode 100644 index 456ef5afcfa04a7fdc0de411dc7aaf787afadafa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15297 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 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-312.pyc deleted file mode 100644 index 0625f6f6f22b918f49234e1c5f84325cc9647cef..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 27191 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 aPPA0%E=NoDEKY;i>0?}pmTo}Y5cxl<2G(r= diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-312.pyc deleted file mode 100644 index f70a78479d02335434f317e0a2833027d0cd4af0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1377 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 WqcN#(C+?9TOZ;Oo8T$D%&Hn+~Du})S diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-312.pyc deleted file mode 100644 index 25bea8174658cbfddeebc138bb303e303f01bb5e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1390 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 P=&1Iar@tWBDmwlHaa^Sn diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-312.pyc deleted file mode 100644 index 9b673b8d987689d8d68653b5ea246ef24dddc10d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 22142 zcmXxs1-Mq#w#M;IcXxMpcb6#AN=WxdcXvwK9W>ZMhe0VIN_RIbx;yUr?R&4!IsY@} z9AmuWopY`4)4d;#JCY#85wQxy?*6~&_|+rHQ$$7Ohai8r7w8M(!YcR_R)mP;3p0^M@k3-0je%2%L+lPG zM4lxI@gh`-w6(V?Nr=^uHC~7_q0h)m*>7WqSVm=Mst{2rL;3H?uOM(L%m(3BRIuFM zE+s8vg%}e$irmn<+g`7jVaYfp-OX47Uz^*@v_)ZYaGA<^B}wCiNC}yF&IFIuJ%Kz# z^O{>+M+qnlMfCovco`&Dmjcc+lnPeze97J(cTm}}Vubc1AF|sY_OQDb_Q8HQ00*Ia z(h!G4F|{2QwMZ7CB^Sa7h6t}Ek@uA zduQnFWp^LMGItB*;?bArFrVq@!P;}8`_&yY=s28!lW+=7!x=aW=ioeCfQxVmE<*rU z;3`~$>u>{Z!Y#NBci=AEgZuCR9>ODt!P;Zd6L<>G;5od2mk^aYL=1=tu^=|Yfw&M4 z;zI&R2#FvuB!Q%m43a|%NC~MRHKc*GkPgyA2FM7RATwlvtdI?|Lu`*ChbSlHg4~b? z@K`jR9;&Js0fvyGE{-8FqFU#I`)b_gl1HpLf7a|im02Cue@eoncF2nh(d~wzy^CA zl?+p|PxOhsjk5I#+<>tX$KZGGZcML5H8!e44X6pVpfjN>)dF$wCr>-cRg;Ek3Afm3Wl426A?5$$=oMjwO^`gC=l+T(Q*IqpxuRwix6$XS3 zf{ea+N`#_8_&7qn@T(vQli`vfd7!$z-oAX(Smv{=p(MQes31IU zR1h9KDku%%38I4VVMPVIVFrZ%jS9lMjtVM=h$JO7+wv33BB7&Tr6^S>8YvgvTF^{( zvc1jWkYKFnHQ6embP(Q6R8R-zK_y5FUqQJLk#b&@@=W%zmlx7O1_&QVly9Y|pizj( zYvDx)RYYUW=)zF=OrnCU_8NFbuR}v<1dX8yG=*l+9NvI8Lji zXTlbH$(a1evbkk@morK9TvSw|C46S@dwUH;JzYdsQA`3Alr)Cy_IleJAv*8=z7-{M zv9-e}xC-ytTOB^Qpn#}{lkc;vD_ae+K_S^#vT>n1z0UU1@UlrsO=xScAy-E%H$Zvl z2^B*`%7h(}^i+~Vxe!4VysxCGlG2v-EW5yXI2a=Gj%j^Gag_8B4fdeQDk%lIp#{_m z5qaS-Yef~q=N%ayE+gl|w=l?TuVC04c{6+-kwoF6jJ0 zKF%FQouD&xfv(UExqbX5eoDOCr)c{Gdn1$i8$3V?{~rjT0qMH`kZedV|K>i=*ujB$Pd^_^@SM zn4lz{C_W^UooH_oOok~i6{f-4Fdb&VOqd0;VGg_l@4|cVK70Tl!bk8id;*`sXYe_E z0bjyb@HNbZc`zRqz(QCAi(v^Yg>T?n_zu2@AK*v$34VrO;8$1%%V7nqgjKK_*1%d= z2kYTC_#OU$KVbuGgiWv+w!mNTH*AG%upRz^9q=#w2RmUG?1nwC7xuw^H~Rk#M%;Rf7v1fLkdU)=WPz-Z4YETH$O*Y1H{^l5kPq@h0VoKCpfD7HqEHNqLkTDerJyvF zfwE8z%0mUH2$i5RRDr5c4XQ&8s0p>8Hq?Q-P!C>#`tT~e1`XhKXb6pkae;5D*VGs<4 zAutq%!EhJ>BViPbhA}V}#=&@)025&nOok~i6{f-4Fdb&VOqd0;VGg_l@4|cVK70Tl z!bk8id;*`sXYe_E0bjyb@HNbZc`zRqz(QCAi(v^Yg>T?n_zu2@AK*v$34VrO;8$1% z%V7nqgjKK_*1%d=2kYTC_#OU$KVbuGgiWv+w!mNTH*AG%upRz^9q=#w2RmUG?1nwC z7xuw^H~Rk#M%;Rf7ZikOi_rHpmV+ASdL4+>i(ILO#e31)v}lg2GS)ib63c z4ke%@l!DSw2FgM?C=V5&B2cgw>8Z>~{p&>Ma z#?Sc8)ysdpgnYej?f7@Ll@`@-Jm=4fC%)2UeFu*Kwszw z{b2wMgh4PEhQLr52E$D!*rMdGhr6YhB@#K zybJHa`|tsL2p_@6@CkehpTXzw1$+r#!PhVs=D~be01IIeEQTep6uyCP;XC*qet;k0 zC-@nDfnQ-6EQb}a5>~-#SOaTe9ju4n;CJ`~{)7#%5jMeQ*aCmS->?<7!FKoucEG>z zAMAu(up9QkUf2iw;Q$*vtKu*X7xgihag?x}73P3?9 z1cjjp6oq0?97;e*CG%?HqaK@L3`)`9ibC+hAz+*xn0AU1egeuU@}aBsW1)RhUqW^ zX2L9(4Rhcfco*J-_u&Kh5I%yB;S=~2K7-HU3-}Vgg0EpN%!B!`02aa`SPV;GDSQLp z!gugJ`~W|~Pw+GR0>8pCSPm;-C9Hzgum;w`I#>_C!SC<~{0SRiBW!}rum%2tzhNtE zgYEDS?0|paKiCPoU^nc6y|54V!vQ!5hu|8E!38&yRoPo3O%+H*O{Q@V6 zpDHheze|hk^J}Ujevn-tN-FWGL`grdp3`<7Mk#3?UF>%<9sPv+Gqm$V>jfoe{GMjC zABX4rske$Krj9-mz36=%{UfsM6E+f%degKK5_A2WJl&u)lm}R5qH+tO!e0zV{*d@3 zOa!z16g{2%8Xa4dT0SRrhH@=YaeFgFecjM+ zZs-#Nmy|T8TnqZiCNc7*Y(jUHi?s~gk5@9*$e5zWdM|n&PjsAAl8O6!vWK+A6CD=K zC6!w=Qgqbw*e}YfV;j*=_`6|wiD(qh$JA}G_gKkhCGEWjX~N;b&(8Y>r$-F>-LVFl zaRlCG=ztmZm3*gUCV`ux%=Bhie&igNjVwjrxRJ@cow?Pu&|89+GV~hra+Ulv0x9+0 zqH@;N{jB)5WlM9{5Ljq$z24sB1A{hFd4<3e0&mlcCz`BxzqT}@73z{$PWH@O*gH&b ztf;?{$)lax``TU#%M_yOcQG3e%579sF^ zh+vH6VADRymVw=Pk0<#Ge4iTKT7t;-Ol2`(pNVR0+0|M!|sw+yx?kMN&;6=Ko z_z9^(vZeSN;9{TY=p*|8N_%)`op(Jvg_VlGG^nPiw`nao{X=mSy*ylfuVjjB9@&zf z#}EP^!+d+2VXcl=6{mpFFp%Yy9C8b0&jk=uQ0Z>x@Y&QV%NQ_C4d`; zRStN~n{yqGS&oOU1a8<%?RivFoCNN&G0C(=yrhvWBFdm+i9|uDqi%uY?-mu}Wi5fz zqP&WKh20GO&QLLRoAmA#6_prd`4;)xTotlRYvcy^l1}uwsHTq2q93A9srZb&Svppe z&uCf!4w8F)3QHWa93qjPR8mn|i3(Km(#s%`mcUMl$&?qvP{rp+wW4wuN;&Tfy$O9w zom2NUWTaAC^t0ptCi;o!N0wb+Df#ytdNis04n4v$KD~cM*+dJWva^-9x08*CWipAR zdJ`Gmh5Irdd`*MifxbEt%ii>8vzT$y-hVI}uF=aOv4>~@qScA^CDq3=rc*9cSDf*V zKBn7sJaeoqVImmmoy-?5gUzDv4gX6=3o~vR{+8aMW^A{&+3}YvIl$2BGUrIdWYM0)$Ja-dqw71Z`e8yTVb}w6&kT~Lz9Z(!w;-I}nmiZ_T^x7t2 zawWUxEib?ZCz`^>Y#p5qKcQoQx{u8rF0oq_i@$^tB}FGB7Ml@Mv|aB4y#*~N>-a;| z$@@~*jK_M1s=Mut=px$4!DkX@AcwuC+BQ1n9?K?r=NK8K73Fc%XR>EFxIn%y`5cPt z%Ko6PwPib^XVt|N?bp^tM{+o2@1lDd?lzX&TdJfj_+u84npC3Pb7xO$GaFYVepd1c zfyRapfJ{^p>3D^MR+dv4+G&~JvF^H|jiOyTx)T_q<25rD>e!(;Gx^d6-IHyhc#6G6 z_O6R+L3dI`sC41)q9gRuk%C_7Xn9ZJ1H}WlA8T32a)oL482U|H4^FGwn-1gDRX4YW zWo=RwDKF)3wvMhwUgF@AOB^6EOvxqLC3-*Ac3JkmK}VI$Wvz?s9@*BG&qW1|e4XA~ z_U^#9Tn&QOvQuQ&iTv5gNLAC`C6!N9#Idfrq08!$dGK*8w<#&$9BI{EW#a)u_jC*< zUss}>8`>1T$51YNJ7qsLZHm3UkWQi%(Fqa@ExTFvQryYN5|$qtw1wy#ZDlFV&Zh-iiDtO#d`-h+m+n@GI@Rp2I-q4e%3?j8094Sn0*H2fd( z&(*ahI#XRG%e$ieoNgleH~HDnTeg90X3Ar<%~N+kB8HNElxv3BV46YY9kq$X7KvPn zJ6JY{zbsdh8qP~sr(Zv3KY>6Gj>s6uEr_%1Xayv_ZuvSrlua1mWZt)1}FgS{Ya%E&-v|*c7!jfd}DY{ z%72OWs@rGzt>tueO9(V#{Gm@&SMu`>`Z0`xr>-uEy;^Jxc0&aykF!@cYztmfGL_y1 zZRN>7px0PkR!_Bu>?86wO!MdHB8hp~1f>+`X8el8aRLSPRtfilPUO34OC$T2Q8_y0!Msh0ikh&B$V0WenSb zWtK+>e51FDx&O$v)3%$JG91h|@|e0smTi=rl#Qk1scF~kRWLG_X@zwB;;4fhtFYeh zpqy+Rb0m>4zh|qlSoSRC%D6SA5mrUDSTYA zc`X(jbW!oY(A}Wt&O0Ma1ic+$8~N;tYb);L&_g`)&8B_FeQmupB|hV7yyaHz-_r5D zl2j7qm7Ikyc&W-&VupUykyc{8=dsMl^GsfV6DArwc);^D2c@D;W8MkV>Qt;vUNE4GRy}3!bEUS_LRg6cYna3I*d0Ze^hZI*#$)F zhmRNq{Si{sU3`>FuMqZ*f z*tA>hE|U$Y#I?LEd&9I>?R8`*tL0NsTcVdO|JHWE+*#p_;6uuBl&r9qPF(}&K_wgb zv(J$eqAiXvgoB=(&QX_4B9{xR

8Y7tu@Z2pzfq&x{=5UNA^BTH+TaDMYQPykmGA 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 XDbtQmdMj?z*coH)iAp=r$Mt^zz_8t? diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/johabfreq.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/johabfreq.cpython-312.pyc deleted file mode 100644 index 5c4ba86231cfd22701706f5106b9bc8b5b1dc070..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 82990 zcmX`z2VB(!`~LBInhpeP?_KV_H!3P_TsT_bK|O9l#94t+qLmUM&Jq+AM@fV@D=aIs zWu~?Zm2x%A9F^AZ`dt71r`PLT&-=c6jJtL9<%sMF3#)vIetUo0;t~H_b;%`%8UFuo zSN@07$A?{VN$w@VO9Gb!F3r9)@V~%i%F6>+D6b4$rMx;&Nm)5iMOifvrmPkSS4IRP zmDK~+D6b7%r@TIJgYw3}P0E`Cwf_uUxJT2yf%}yA2Odz? z2-H;83e;BC3Di~A3)ELO2sBhS3N%(W2{ctU3p7`@2((nT3baP@TluriIl<9$4%BKPu%BKU*{P&S&2QoF!3CvYK z8+cCnd|;k(ejrQvLLgiDVjxGkAdstE7+9oS99W`U8d#=$De$s#c_2@jA6TJW87NS$ z3anPH2^9YKk=6#*X{fmd*z?~<`Y`a3=8prPC_fGCRel!Or~EvyUwI&K zQ29mROXXLAua(~fzEyq~_+I%#pj>${F0{-uFS^t#mgpLCgZxpakf zrF4~bwN%NfELE|pN?}$tDg6IkB1PyG>3wzS8tYo=I_rAr2J1%YChKPD7VB2&HtTlj z4(m?oF6(aT9_wD|KI?wz0jq{o)2b!aw(3ZAt$I>@tAW%obZsL|jlFLoHMN>a&8-$v zORJUC+G-=Uwc1JTtqxL@)luqXb(W&7E>c&kn-pVpmwH$|rCwHVsgKoHinaPl{X^Fd z&@|BdK~kJGSQ=stm4;alN)K5NOOIHOO7T{LG~5bEiPi{dq%}$kTBD^g)>vtrHC~!v zO_Y+X$E0Lyl9Up}UYAO&O;V|~S=ti1cB`gs-fx$7SZ_#g zT5m~Z)=ued>m6yA^{(`u^}e**`as%aeJFioeJp)qeJbs>K9lxYpG*6#1JXh33+YSi zE9vXdwclv^*8A_I@2wxCa_f+E*g7IrSU*ZXSx2Q~)^X{CbyE7-`bGNH`b|1z{Vtuh z{*caCXQgx2dFfB{}=e5beVUTOIKJ|N>^D|OO>q3 zQWdMJ6lPVE!mS7?(yA_9V_hpHb?z8Tf9LPWux=Arscd3WfQ|e{)mikzIrC6(<)ZZE)4YUSHan@jI zh&5CiW<4l9WIZfBVm&IwTM5$e(6s?giQbQpMp~n!pfy?=V~v%@S>vS%)1x0owZ)tV7(%}YHgH?tkvgHb+9Z`)o24z*R%x5HUD{#2A-!q6C6!q_rMInj zq+Qm#(tFnX((cf;A86X+{fE*=*2mH()~C{5>oaMe^|`d)Iv^dizL37OzLLJSzLCDQ zzLUPUevrzoL(*aEh*V+yDE(v|m5y1*r4ylRPip$v`(LDAt>2_m*6-43>ksLSbyhlO zotOT!{*wN-E=U)xf24n<%hZjRxf?H2H(us$yex3JbcKKKmC{w#)lwy^vQ)*YDuw-b z?PY;#n!>%0kRq+>(lyq#(skDL(hb&)(oNRQ(k<4l(rwo5(jC^F(p}cw(mmF_(tXzb z(gRivsisv+s%_Pg>RR=r`k`wZXlm$vBdM{~L~3d^lbTyCq?T4IskPNcYHPKV+FKo@ zD66B?$?7acTV15CRyQfe>Mr%LdP=>l-clc{uM``)wx6c{-VcxlT7#rGYp^uL8Y&I5 z9+V!k9+n=l9+l#)1ZlVxkP@vC(nxER6tqT5W2~{#IBUE#!I~%~S&vD{p=&2;O7VWO zlxj_prdrda>DCNsruDe=g!QD9W~EEBtf!<5>uKp3YqpeW&5`C>&q~i(&r9>H`BIkk zf|PB&DCLB%U7#t~`-RdXYq7M%S}HBGUXot6mP>h7zO=$xDHT|&q}A3MsnA+0t+Uok z8?0BPSFMdwk@cEXY`rd(SevBM(6yU2ZSj7qw9VQs?XcdE-n8D5%B-Ez+txeMF6&+C zJ?njGxAlRv$NEtE$og3N#QId)Ykel|vp$#hTL+|r))&&3p=-a=^tJcjNZ(rDN#9#P zNafZc>9BP~s<3{PezJ~A$E@Sh3G1Zvv-OMgtM!|7%KBY8ZT%sgvCc~8tn<>J)?d=! zp=&Q_y6F8s(!bK>>c`97kC&?-FLys)u7318P|7Ryy2}5*tEEa-WvPl)RSL7JN#Rz6 z6lqnLuCcC_uCuO}Zm@2YZnAEcZn18aZu{@r%LBJ-y2JZBrMs-VrF*PKuJm5$+V?f> z_WlEDkM*JSk@d0kiS?yUKV zIwDnAKT1DYN2Oz-YmaL>;r&VJXX_W~SL-+Fl=ZuG+WJE}W1W@GS?8rct-qwdtqamc z>mTV~=?Zn@74F6>)QwlT8?R6|Ug2lQE7XlwxErqsTrE}dkEkqF`S02*0#!AId0$Nm zw<4rStGaZJb**%rb-i?hb)$5Xb+dGfb*prnb-Q$jb*FTfb+>enb+2@vb-(n0RYR(2 z)skvkb)>qXYwKyM?|lQQq18xgY&DUZTFs>9Rtu@6)kk9ThpdOC zN32Jscq>5~ZUv-7YlJk?8YKm-(b5=etTfIVFHNu}N=cz>AJdfV{Uj;Hnk=PSQ>3ZZ zG-5YMx1=&_r}VbXPmOimQmG)YnN&BqNrTx|c>0s#EFEoAW{a4c0);H3()_2nP)(=v-bx1mF z9g!-mAElqHqtY?!xOBogDgA8yBK>OpCY`c=mrh%MNN23G(mCtA^k?YWzcl^r{RQcw z^^f$gbfx<7O84WH>c=bHk5{T6uXI0Nsebg&U@EWHtCD|2WvPl)RSL7JN#Rz66lqnL zuCcC_uCuO}Zm@2YZnAEcZu#%pD+9M`y3PCBr8}%UrMs-VrF*PyUKVIwDnA zKT1D^u05*hnD@t}6V^%TXX_W~SL-+Fl=ZuG+WJE}W1W@GS?8rct-qwdtqamc>mTV~ z=_+;ORqn>C)QwlU8?RC~Ugd7QO5J#spB=AKH(o_I@)Z+OWxcBS$5)lYtZGuY6(L1h z)un5!Yo+U~>!lm48>O49o26TT@y{{+Lw;D(dtwvH~tBKUqY9=+eT1YLeR#I!Ljnvj^C$+aaNKsZtsgu=Ninh8) zU9E0XjMZK0VfB=Hg|6+bsgL)4rC6(<)ZZE)4YUSHan@jIh&5CiW<4l9WIZfBVm&Iw zTM5!|DzYcu-z1e1XQ~=~wGF>6G=mblUnuI%A!c&V{Z$ujx!lm48>O56yY}k9&6;lU{#NNW>vri5>rUw|>u%{D>t5+T>wf70tAPU61dQyF>fz;4yBsI30NKLI~Qgf??)Y57twGLg|MpIkw+ez)M4pNlWQR-xMmZGgL zQdg^+6k~OldRRTBURH0ZkJVR-wfaf@tpUun92wnT6rZn%%X&e|wqBHStOZi8 zwNP4QEtZy8OQmJjOVZ2Maw#u#ZN8=z-mjDjtX0x#YmHQBt(DeU>!l6WE7GghMybep zO)9otmrATnQmM6B+G1^$wprVy9o8Gto7P)WnYB}TJ9Ou=K-yz{ zD1BsoEPY~qD($sCllEDkOZ%+@(n0GB=}YS?>1*p7>09eN>3i!3soXjw9kz~06`^Z? z)bx}0N2O!dap{D0Qu^8YMf%nHO*&=$E}gdikj_|VrE}JK=}+q~>2K?TbkX`p`d6x? zZmi^PtfX$NFXUUxgRS9s!P}S<6J9UXI(GdVBIL)WZf*?V%;j;X5B8`VcjX+W!){^W8Ev=XWcJ7 zVAYUnhOVupskZlZq`Fo;slL@fYG^f*8e2`IrdBhlxz$2yX|MO-s{iOcZ0BN8#NQ$!tOGB)o(lF~m z=^^W3=@IKuDc(wuhFbwC(HbF*v_?rmYqT`R8Y_(pT{~XW1n(zGN!DXhvNcIcu_jBY z))Z-~HBFjs&5&kVk4sNjPfBT4x-`prO3JXFmY%U@OPSUjX|DCG^qlp)G%s}Rd`(&2 zzaV8>FG@Mq0x8#8C@r!UOG~V!(lYBM>1AuVlxO8jE3B1Lfwf9nZLN_Ct+moRYrV9= zdPREG+9(x;u6<2YvG=b_CDtaX)Y>dka8m>n*9w+9|zly(8_i-j&|7 z-j{Y;A4q$w52cT+kEKtnPo=%qXVSjVwV!L+@BIPkp!J3HrS+Bcwe^kkt@WMsz4e1s zZXJ>iTSue{>qqG)>!@_hIxd~CPD(#pzevAYze%U8-=)*mAJUo7wP!V*^ZvZ_r}dZg zw{=0fX#FGoD^*rMR(3yDRzFsDKUP*hR(3yDRzFtuvtwm-V`X<^Wp$%}1%rSBh|I)N%gG;QbVhe)YxhwHMN>a&8-$v%h0v0G`04=jnvj^C$+aa zNKsZtsgu=Ninh8)U9E0XjMZK0VfB=HS-qt`R$nRB>L>NL21o;~K~kJGSQ=stm4=0` zeNfXw-ajloVm&IwTM5!|Djf#>dQr-;7D&0)LTQn;SXyE&m6lmANiT=4U9Kt5`+RAIwNfguR!OU^HBzCqR$6DR zmo`|hNUvHOr6TJ!sn~j5DzP?6rPgL?i?vnSW^I>tSZ_#gT5m~Zp=)<)dfWSVq+Qm# z(tFnX(r)VmX^-`x^pW+k^ojMUwAcDf+Gl+(?Y9m{2dyupFRibnudQ#SZ>{g7@2wxC za_f+EICSk1O%>k%DE(v|m5y1*r4!ak>1XQ~=~wGF>6G=mblUnuI%A!c&ROTBKdrx{ zzpV?>Me85wU#W_^v5LE~in_6iyRnM8u?pSjC&nu3$13i}D(c57?#C+X$0~kytfGFb z;(n~6XU8h;$0~Yutm1yGqG!h{?#C*DYo+V_5wDkSux^xYvTl}cv2K-avu>B}u&TO+-f1Uv|356 ztu|6ytDV%|>L5i~9i>iIXDQn1B6YR8Nim^oyKCyxdnXpN9YTBD?(HCh@Ix^}Flao&%YCRh`t zBF%CqvN71m0rz*;4( zw$@06)>>(uwO-m_y&}CDx^|U(r_$cgwV!F)=l$o>e(QjA(E399()vpJ z+WJQN*7{ER-ugi*w+=~%ts_!}^`rEYbyPZL9hXj6C#9dQU!-5H-=tI4@6zeewSQHb?z8Tf9N>LPWux=Arscd3WfQ|e{)mikzIrC6(<)ZZE) z4YUSHan@jINa)(3nudA*p!AUSu=I%as1$D{NW-mwlxU5RMp~n!pfy?=V~v%@S>vS% z)vgHb+9Z`)o24z*R%x5HUD{#2A-x&8 z_AO0i-tUy&w%(C;S?@~kS?^1`tq-I<)`!wZ*2mH()~C{5>oaMe^|`d)Iv^dizL37O zzLLJSzLCDQzLUPUevryT*B;Vz*!v?=h4rKKlXX-&W*wJKSSO{QtzV>Ht>2_m*6-43 z>ksLSbyhlOotOT!{*wN-E=U)xf24n?yD?1N7)Cexi7`z580LNqQ$L2eAH&p- zVeZE;^<$X(F--j!=4Zz+^<$X(F-*^nVeZE;Jv)ZEAH($Q80KfkFm+>?yD?0kSBJS9 z!}N19VeZB-eLYW@yD>~(3m)cf4AZY840AVz1@4ya@!j`I_l2&#U(*BL*N|#jwWQis z9jUHWPpWSa#-t<_FyZ*`EOtd3GAtFshsb&){|12l`hS)o{}=Gr=@4C*;1x8N17YD_E}BOdH=jL&zdh~SuaT0){9b(wLr?X z7D|h(#nKXMskF>`NqX5@F6CMI(h6&(RA8-=R$FVNLTjzG&RQ>R2wnS%rdPe+C>2?+ zNyXOdQi-)mDz!FCTdb|pHfy`I!+Jw{(|SuPvvx{vTklA_taqjNtoNne)(6ra>qF@y z>tpGY(6ygx+Uxyi(mv~RX}@(qI%s_%eQA9qeQkXseQSLueQ*6Bm0O3T!`2b0!unDA z$vP?>vyMwAtdr8u)-Tep)^F0O(6zs7I_>=*(i!Wlbj~_2{b~Ir{cT;4E?WOc|4P-= zkJa3d)zpvG{Onjw-B``tSWVqn&D~f{-B``tSWVqn&D~f{-B``tSWVsN@8F`0&@0k^ zGrd3O-ZPk(LTJ@y*Rs*S_)ktb=HIbTzu5G5Nx%VxkmR2jN zwbe#yYqgWwTOFh*tE1G(>MTWDU8Js7Hz~&IF7>c_O1-S!QXi|Y6l?X9`db5}fz}`? zE_Cf+O+&mNDh;z9lpeAkmL9PlmEx@gX}A@T60H%^NNbc7v_?x~tg+HKYrHhUnkXe% zk4eeaBq_z3ETvjgq^Y56r)iq*{S0ZQ^|*;@ zO3zu(OY^MxQkM0Clx@8zzM<(&@86Qj ztew)^);rQJ>s{$R>wRgr^?|g<`cV4F`dIqJ`c&F$eJ1U*K9}}e2c(167t)v3SJKzk zH`2G(chdKvYk$yG?)@R@uysVLuzr+&vW`l}tmD!N>!kFv^^5eY^_z6c`dvD0{UM#P z&PwO3^U|NzU((;!1?i&okMyq;u5Jvc8~wx>u6_)6KZdIx!`+YJ>c?>RW4QV;-2E7? zehha%hN~aL-H+kw$8bM8hN~aL-H+jVb`1BkW4O98+}#+iZVY!fhN~OH-HqYu#&CCI zxVkai-59QJ40kt%s~f}Jjp6FXaJuooYwy)`pZ_fGmmaWcNHwimQf;e_RM)B})wdc* z4Xs8}W2=eO)M_R*w^~RotyWTNtBuswYA3a~I!IAgN2!z5S&9x_+eK4X@4HDcR(Gj~ z)l=$a^_KcreWh5dpVZ$PAPuwzNpaR-X^1sc8fHBxJ!CyBJz_m7#aju|a4R4sS|g;9 zp=(EJ3VJ_U8e@%>##!T~3D!g@$$CsmwkAm_)?_Kwnj%fLrb*MS8PZJaap?)`Nh!@r zmu6W{Ng3AD(lgddhowO!g_y&=76y(N`dJEga+ccfj`yV85s`_gXf18I--q4ZJc+K)AT;{B)6 zUh6YypY^%4-#Q>2w7!tOw7!zQw!V?RwZ4xfig{V4rp9hHt*$E6e2 zN$F?n7wOl~wZCaP<^Au{Y3mQ^jCEEzXPuY+wEmL*wk}8)t$(C{r3m$7gr6NF)Qu7D z#t3y|gu5|9-5B9+j8Hd5xEmwXjS=p~2z6tGyD>uD7~yV=P&fKJ0J^~<)Q=JF#|ZUf zg!?f<{TShXj8H#DxE~|bj}h+22=!xx`!PcO7~y`5P(MbvA0yO{5q@@z(6eKNyD=hg zzx06rTxv))ty)rTtBzFHswdUA8b}STMpEPd{@O+anrLe3eKV=K)k11%wUSy}ZKSqV zJE^_ZL5i|EN}a6EQnb}Y>S}e9Vyx~`538rt%jzxlvHD7}RzIn~H9#5|x^|GJIPV8b zL#(0FFzZ3-A?so35$jPY-b#>$TLCH28X=9eMoB?yv^2&VD~+?pOB1Y#Qj+zUlx$6s zQmn~RYUtW2nx=X`O`2}akY-wsOHWu&N@-TQG|PHQ%CMf6p0Q?2nbsU>uJx?+ob|jk z&zdh~SuaT0){9b(wLr?X7D|gk*Dlty#QUYvGV3MjWox;VXXQ&Ptd&xMwMtrTt&s|? zwbD9ky|lr4MS9iRC>2?+NyXOdQi-)mDz!FCTdb|pw$QcPHSO^J4e3qmEvd}fDZOpI zBki)@mEN=7mv&npNPDagrH`zSrBAF+rM=c?(mv~RX}@(qI%s_%eQA9qeQkXseH*&= zJ5Aqv|ASO+9g+@PN2ChtN9iZ)sC3LaE}gJWN_~NEq`NUv-5BX^j8r#9x*H?ajgjug zNOfbRyD?JT7)dv}ZzI)@k?zMx^<$*_F;e{)>3)n1)R1cWp|%u>tX2;>rpA*N|1(I0Vy$b?FdaH zy&ok7tOQGq`B6!(sS1H(mZRvlx4jjWm_*wIo1Lx*IFnovKC8AtfkU2 z>m})BYq^wXlNu$Yok1y!5B_m-M%FLAq%DBmFB?S2tF7H&$0SR(Cg6 zS2tF7H&$0SR(Cg6S2tF7H&$0SR(Cg6S2tF7H&$0SR;L@?VAa)+)!mQP)sOxz(#mV~ zy3QZ*dg%u1M(HN&X6Y8|R_QkDcIgi5PU$Y|Zs{KDUgST46qOC4cSF4*8 zV|AB$SUsg)R&S|~)mMtO`bqt{R{uLduYr0E(ko7{!AmbMxOAxg9!?!nV`%kDE(ylZ zzT}c)d;{=c0=g6>qW_^$=rR;Um!r|>3N!}s-NS=P=qi+qu11qkC6t2r{^P;Ps0vC& zRnZg_hNhxwXgUf+2?2;GM&(EaErdH@|mHP8uE z6P-e}&}mc~ok4ZbSyUIDL-o*kR3H6~8lVfPA-aefp{Pu$F^Wb_Pz-8{Vo@{HA2mk< zQ42H(wM22K6^ci#Q37g%hNHG95w%03PWT7EFI0efqcx}xDnxzJIuwgGpnhm0>W_-h091?yq7pO+ zm7+Mb84X5dXb9SghN4|a--TcQ*&Tl#8B33sD-%L+L0V z%|Zp}DO89u&?fXWDn-wrGNgaM^mhj7udDukAiebOKAMXv(6fl&bL=^E3O$cbqj~5I znvbINr%v>KJ7HE1&`MBC9?6tBNx$JU_)v>pvd z8&D#81qIQoXbjqjl28#!Mz5h1RE#F0*HJ1eLDSJDl!i)CI@*jf&=!=5wxTSw4P~S4 zCI*fLq3iK}GpQK~&p;PF6bQoFhbQ~Q*C(t=`5=H6X*keDVX!Hw;LBFC{^c(7rPN6vTJBmlAQ5yOKrK2+_ z1D!>g=p34l&Z8{!C(1^Dp&ax#%0(B@LUa-3p?^>z`WJ0Nms~29O2JD}8TudEi7rFC z(B)`1x&rM*SE7CBDs%u{jml9aRDmj^W2g!`g{q>{C=5l-Q&dCoC>$lA2$YB-(MVJs z1<^HV47wIgMAxAtbUjK&H=q=BBT7X#q3P&ml!tCX`RG;K zLZ#?#6tCtE-h&d*y=XYP4<(}e(J1r)3ZfclG^&Zlpjs#i)kevv4oX3F(PUH)rK0+1 z3Tl9+qK0TXYJ_H@#wZOnLFuR|%0SIfCTfndPz#ieTB01(3N1jbQ7&qO@=#lpkJ_OE z)E*V04yXu4p;FWlm7`AR5bBJMplDQqx*+}w8SIKqpl;|Sib1DPcXS%{Kxa@-bQbkO z=TL8S5%ob)`Y&#{+#31}!vM8i-J zJ&2OfLns+Nj3%Q;P%3&9O+)c04JDuqG#urj0Ln*+r~r*Xg=i#Nhen|y6hy^nG%7)3 zP$?RVwxe-q2O5vc&;+y#O+>p<5;}k$Ls5E)2_~axGzrC^6cmdlqy8ur4MbB=JerCU z&@_~YrlTO5fs)Zol!6{dsptumhMq*}C=F$xbTk{yLYe3(l!Y=-HhLQ6pl47nnvL>M zCfbDNpfWTUm7`}-1$qwgOc#6}okH`_X*3^2={YZ$g*u`aPz=gOvFJtAALXDpv;f7U zT$F$oqC~U^1<_(O8ZAL%&{C9ymZ4qOoW*nuxZbB(xPJqirY!ZAX*Q4wQ=CKvU40XexRO%|vA=4ednf=xvmN z-a(mY7s^8KqHOdY%0cg=1!y&_VPk`T|`*U!o{|wi5gbbwppIX!H$=LEoZS^d0JtzDEPm z4`>i7M{(#7ibsc0B07SCr~*w!KcZCh6G}rzQ3g7O^3ZXVk4~ThbP}yWKchnQ3tESM zMH|p>s0f`x#pribf=;7S^at94&Y*4REGk3i&@OZy?M8p1a`YEEi~dGY`n)fA0Y#&W zCLRVW)>jdD;Wl#42(JX8g3 zLRC>23PT4`HB^qmQ3Z-Xd?p)=M5j@8bOv36&Y^2jls?Z5UWcO5^(Y42fMU^&C=T6( z;?d100o{TU(XD6{x(x-C8MS&1vNvH zQFD}vTA-PzB}zlBP&#UjGEf_oiQ1wp)DC5%_9zE+KnqY5%0(SfIqHNCq0XoRMI+wF z2zEgyP*-#kbwj663_6Xvqcf-nI*WRubEp@(hq707}O8NqW-8q z8h{3(foKpKgyK*fibsRdWHbcjp`j=r4MPR!K~#tyLZ#?oRE8cwyV0Yl9L1w3y_XYA zK+$M8N<#sZjuKG@8i6v=NHiafLRlz?a?xm1hQ^?BG!|8$aftVjg5%LCGy$DP6VW-8 zgyQuMQ}8jAfRa%nnuJE76cj|0Q4&f;$!H2nK~qs0nuapabd-r^pe!^KWuwPY9(n>5 zpeIowN<&2`9TlTls02NQN>K)i*ZX6^r%?iW1|_1|D2Osq5}JdO(Oi^*o<)<v#<7f~k4L0M=4%0{^;2Q5Sk&?1zJ7Nb101m&Zpr~oZP zCFmtoie5(LXgNBB@=yiJN4$d=T!BuZmFP4oKxfb@bQY~f=g=B-5f!2+z55tki#nop zC>pItF=zvdMX#X#=v6cjZA5XX2*snVY6s4feXfoP@QqfkF zhPI&$v>j!m9ViFAf%4FsC?CCr3Q!p;L_1LtdK(p^cTfr1g-X%8s0_V_cA@vtL9`p4 zMIWFjy?YzngQC%gCM4zHKv=_yr&rl-Thl1#Hl#KSH6m$TkqJt<6 zeSy-^mnZ{$g)-6CC<}dqveCCF2YrWf(f241{eU*1a#V&6p>lK>9YRM?1*$;2mmT~O zokBmMGw3KfhmN5rz0(~$jyj?fC>otaG3aL$i+(}<(XVJA`VGaQQz#z&juOyml!*R7 zL39Qsp|dC%okJ<;JW54>qABPvG#&koW}piw4_!q0=pR&o{zZl8lFJlD=u%XS{)bA? zWvCQgj^dXqu0RRsN|cDMLL<@DXcVf1f~YbYjjEtAs47ZAVJI0@Ln$a6rJ@Kl1x2Fi zs5+X7u0d(&T9l5iLmB9Ll!-4dtQRQ9il@6{0&) zDY^@lqr1@|bPuXP_o8FyK6C=zk4~Wn&}mcyok2CxIaCXsN43#KR0l=nDe9t*s2++& z^-&CJfMQWY)E_lM15sl%2sJ@*s40p^%}@erjuKG|6htji3TlNWqt+-DwLw!+Ta<>{ zp*++c<)aR0C5l1?s3R&wozObe85N;uRE)Zy64VuyqHd@R#h_iNJ34@Rpo6FIS!OHcqULy0I4jX(uxBq~IsP%#Rk5;Pi>p)sf& zjYSn`96E-^qo@^%2`Cy(L@_7{#iGa1K$MK)(Ik|JQcw_0MoB0YrJyM&4^2h+Xc{U& z)6p6<0~Ml~XdQYS6`?0kF?te}pft1zrK3_b3vEG9p=~Gw#jjL6jS|o^XgHdU0w@zD zqB&?3nu~(ySu`3whsL1i(O5JOC87B!8D*gq^a4sn*=Ra?5v8FVl#Ujl43vv9(L$7k z7NKmk80DZPXaQP^a?vuh1iggv(90+vEk^|?4;7<)RE}1lLue(cKn3V1T7~$T;oxd? z0v)}k|L9Xf~Bqw{D3iqg+22VX%Q(W@vLZA9Hr5sE>tp;%Om`lHv;KvaST zp-m_bm7;jG86}`CC=qQ%L9`7eqwOdK?Ld>!8z>dMiKe5sP#P*j8E7ZULvN#e^bT5q zcA*0FE-FOtp(6A?Dn`3e3Hkt)qCKb#eTa6UkI(`1F)Bx&ptI;x6s4c35AH=B(Pta}{*2C{Ur^L)#jhwD z{f1)DDHMx-M+4Dm6o>vm@#qXnKxa`RI){SjJW4`;qGa?JN5j{eue8 zzi1u0;`J39!K+XLx*8>-N+^gbqcNxoNM!N<-CAI=TjBpleYkx(;Qb>rpnk0p*|@(E@Z6%0)M$Jah}n zN4KIPbQ>y1x1&So4pf2eL`TtGh_7D>-i=P7d(atlFFK3vL+8-_C`w=F5_|x~p&BS2 z)kF!X7D__3Q8KE7Qcztq8P!9ns6NU=4NyL6hzd|6REQd*BGd#Gqo$}7HA7MQ>YHG5 z6pvblP4MVBuK{OpbgwoK%C>=e5GSH(a6UCz}lz_6)aFl}r zXaPz@xo8B+LnBc>8ifi_5EY`)s0fWg#b_)lLE}&<8js4*1hflHM7vQE+KV1T2T?LA zN0ZPYl!6YU$><15MHOfYI*O*EV`v&Wfu^IAXa+ikW}?&RadZYffzF~Q(K(ccE}(Q2 zwLvipbwp30Xq16s(9^gIfpc_<0ZN69D) zrJxtkWR#6k(TgYz<)93-0A-?Fl#3RkJhTYqqs3?iT7nADQdEeRp>^mbRD@ne#b`My zL3yYY<)dwA1u8=;(N0u=cA-^hH(HGjqBW=-6`~5X79B(D&?&SYok1JWS@a5udPVUn zibfkz3@Spg=rzY7%qRl7?Z9&OsD@sAzP%7Gv($Ef+j^02S z=uI>my@fJS8OlOCQ8s!T<)C*^F4~0_p?A>|^d4G@-bZ<8H`;_gKxJqT+KE0yyU<5y zH~JXuMW3L9=u=dV_M$`RGgN{0p=0QCbPDZ9r_lj)1|3A_&=)A`RmGR6Bl-%(ps!IZ z`UVX|-=aA59g0WaqXhH=N<`%-hz_CA=rBq`M^G}VKq=@)l!|^rdFUw0N5@bBI*!($ z6Q~fKL>tl1s0jUniqWsA1pS6e(J8bY{f^={Do&#W^al!{Gbj3yh|#9`EkKu{Ty!}qMOUD5bR{~3u0j>) zYQ$IF1}mWxs4_Z*s-V-TDmsh8&^c5MMHMN+Q8bD`F(?vcpz0_OU4!z`wWt7Hht{C$ zQ6ahktwT4WB6JffMmM8UbPFm&x1ycsHna=fjt-zZP&v92oke${sMi#CqiA#wib40H zSacuikM2kD=mC_5YM^vf6J?-UC==C2S*Q-mMs-mxs)zDWeY6QRKxL>QDo2e_1!|1q ziWN;zJZg#(P&1T>nxi0UfySVgXd-Hbl2B`ujM|_y)D~r+b|@3IM_H%?%0p2oA9X|p zs1qtgoly~rM#ZQLDnVUQDe8veUsuGS1k@cRq8?}j>WN08UMPrqqtU1j8iV?xi6|B& zp?)YC^+zda0Gf;jqEs{pO-FHP1{#dg&=8c4hN28K3}vDRQ5Jd#Wuu2t4tfMFK#!ta z6p!*y0?J3jQ2`2|LX?QsqYYMREkEUZDT(qUTT$ zJ&(qqd1x$}kCIRpN=7fBNhlkopcm0(l!H>y0yG`vq8Vr*nu!*nG_)9Hpd~01Ek#*q z8Ola4p&axwT7Z_LJd}s>Q9dd_D^MX?iPoY5v<|I88_;UB5v@T*s1OySwWtKGL#1dv z+JZKqGV}`CiC#s!&_=Wy6`{T8HM9>Eqy6Z0bO4p0gJ=^fN2TZx+KejD7IX@2MQ6}9 zbPjDtQJWMyP)GCzibiju81xp3MP;Zz+KC3Dw^1B=2gRdZC;`2T6484oh~7s@Xg5km zAD|Sp2c@D9Q5yOPrK68g2KoeLqEFErv=_}qpP?+Y4`rjzQ4ZRVa?t^lhYq5A^aUzF zU!p?v6)Hksqhj<8+JwGErRY0UhQ3ET(GO@BDo4A~A+#4AM*GkabP!dba`YoQgnmL5 z=qNgdj-gZNI693^pfl(sI){EnQKgDsP)GDDiblVo7<3B7qTf+}bQ%prf1o&Y1`R=H zQ9L?_63}^+i2g)D^cR|d{zggY0!l^~Q40D8rJ{e)6m-dzimB*QG!6X^O-GlZ8R&8} z6J3GQ(3L0yU4=5y)hG*9LOG~1%0pF9KB|feP#7vi)zDfLj@F?Fv=K$3B2*m}qiawJ zx)yCh*P&8$J=%81!|3sp*H9QYKu;xcIY%}kItYD z=p2ed=TS!#wMEehbwr&}G>S$ss0)fkT~UA34GlywC=PW;@u&w%L_JXu^+HLgH%dl* z&}7sXrJ`7rhWepA)F0)e0jK~CM1^P&T8H9L5gLq&(GXOEhN4n53~fdaqAlnlv;#ei z%FrWdCwdg^M)7DLNok35dsBMa8P&As2Vo)ZEMRQO* znu`+9vnUZghl1#Nl!WG?WHcY8pe&S%UO;&$8|9-HQ31+9YtRBzh;q?7v=9}cMW`4p zMkQzoDn(1tX0!}#LocE2=w%eYU9lV`pgfd_^3h1N0tL}ZG!_-0B(w@8qtz${twEDf zAxcGS(f`$S-_d%V2bG8I6w-U|z4zXePx^ZAz4zXGN1o9Pq8s5Dn4!os8W3F=N3;MA z7%)Adm<}=+Fri4t*oM&N?z{KN@;dAH?DzX8>%B+Imae38s2@PxhWbI&dDIV~E}(uG zbvx=uP!~}@in;@J74=!vkD=~F-Hp10`f=1{)IF$csL!FUqpqPIMEwNnA=FQz@cVq* zKZUx9`f1c7sGmVSiuye2G1SkZ9!LEg>dfa)9zTytqV7eNQC~nUP``k>g!)C)U8ws| zmr=ijx`O&;)K%24pzcQ9kGco-tEg+JUqk&Q>eo^CqJ9JQ1=Me%?nnI=>i1ET{^;sB5SPQP)v_i8}LhCy&2El~E6&#;CtW%~5}YTB80I zbqVz_>MqpZp)RAojJksQd(>6bKcMbL{Uhoc>Yq?Qfx3bEJnAN@{PQOd164sif~uqb z8P!BRifW@CLyb|7qo$~TLCsPBidvw)f?A^f4Yfl3JL(+jKTx-!{u6Z`^MH8#sB5Tapsu5y ziFy$AEYw4&XQLiQJqL9Y^<2~=sOO;`MLi$&80rP6$5Agtow@hq@gme&)QeGe)Jsrq z)Jsue)XPv&)XPzE)GJU))GJYC)T>Z+)T>bo)N4@ZP_IRuN4*YpC+hX6OQ<)X?n1p0 zbs6<0)D_g5QCCrKLEVjdE9xH9+fdg~Z%5sWdI#!0)H_l4quzyj0QGLvnJ=6?-h;BE z-ivah-iHdK-j9l+K7fj&K8Q-9K7=ZxK8zZpK7u-j`Y7r))W=ZgQ6EQLKz#yrJL;3D zi>Obb?m&GSbtmdGs7ojd>T{?wsC!XoQTL&&sOu;j>LHXJ^)SkTx`}e49znTKkD}bD z$59^CnO``0cu{tg59LPrQDIa7l|%(mWmE`NL4{FuR0P#VMNwl^3^hf?QFBxRwL~RR zmryCxU8pqbGAe`mK2#QU1(id6KPr#9iYlP)Mio)_ph~D~s4}Yjizkl?s)DMb>Zls3 zjjE%@s0M0^YNF<-7HWxVqt2l^sM}Co)Ol17bph2!-HsZdE~190J5VFkXHjF+ou~=w z5^9RN3pGPsL(NgwQ47?As3qzl)C%>ts5R zN6k^+fLfrw5w%2p6Y3o5n^Bigx1;VteGBR`>LTh2>RVA)QFoy3Mtv4_59&_THPpAE z?nQk&>IU#R<0{~Ps1)OVsDKz$eLI_kSokE6Z^b>^2&9+yyV)Lp1D>i?k5 zq5d!GHq>R*dDQUPxkp)R7Xpzc6@Kk81@51=lgeh_sT^+TvDs2@gML;VQq zUeu4G9zb11T}S;G>Os`qsE1HLj(Qk%59%iBbErp9*HDk5eggG4>L*cWe);6_Qz$#? zr%`Uy&!EDn&!ftypG8$rKZmNLeje3E-HRHdzJQvdegU;a{UYiT>ORz6s9!=|M*TAC z3hGx-S5fz)?neD8>K@dup{}8R9aa97lgDqMDyZK?)lt8NYNLJ|)j@p`HAa02HAVdn zYL5C{)B^Q;s3q$6QRh$(pl(C`0qQ*J4^bCTe}uXn^~b1-s6Rp7f%;R_XHkEKx)b&1 zs7t87KwU#!M_orfhIfKcMWWe?+-a|AY#oZlI#5o2WR-KqXO+pvtI!M%7V|q86yfQ0GvO zqt2uL1$7Dauc*6FUqM|){Tu2E>fcdUQU8Iu8}*;4dr<#{x`w*tsV9%0LEVbF7xe_x zeW)j*uA`oWI`gY1k0+z-sINlBQBOf7QBOscQBOmiLp>dJ8|oRT^QdQ{E}));x*hdw z)J4>DPV>H5s28CgM7UWR%E z^>WnXs8^uQ{MyOml_)#vRVX*=)u=G)HK-)&wWu=cb*KvJ^{6`P4X76Cji@&2O{gyF z&8RWzEvPB#t*ANbZK!jox1-LZ-hsM+dME03)Voj@QSU}wLcIrd7wWyJ%c%FEuAttJ zx{CS$>Tc8rQTL!egt~_MFsl6PCy$SyDyWa5s;G~l>Zp&S+Ne*Ux~Na0#;8xBrl?P& z=BUr07AOm9i8_PYqRyhup{%IeP&U+glpS>epM_oq+P!FPlsE1G?6#lfVb{KUN6+u0MilQDx#ZZr-;;6?_3DlY2IC&&dXHhAX z9hFA8Q5jSil|@BSIaC~#M8&yV)Q5Dn_RYfgOHPjMSN1a18P!~{5 z)J0SabqA`Ax`gVW?m~4@mr*^`6;vN}6*WNJjT)lvL5)z?P-E1+s0r!;)D(5*H%}fj zlpQrkl~D^+9koQYQ7hCGwMNZR8`L?}7IhnHhdPhiqrL`pKwUr`QD2ApYSithbEu1` z+fa9){u}B})PF}^LY+rlL;Vlbb=3bvJ%sui6#gW&_65{U)YqaOMSUIW%x|4Mz8+;q zeFMsk`bJb3^-ZWa>YGtX)a|G;>RV8C)J0Sq^{uEe>JHQt^;y&$btmc)>f2Cvp}rk; z8TB2gE2#g4x{CVWsJl_$iMj{%U8rlQ??#n>`{eOGs0!*5s*bt~)kggv)ByE=QDf9) z)D-pqP;=DxqL!%dL!CoiLEVP>e$;u?51=lfeh_s#>W5GlQ9q2j1N9@Q&!T=5btmd7 z>JsY5P}fj*qpqWV9Q7dT9@Imq&!HYhT|<2t^%JO@sGmeVg8C`cqo|)oJ&yVr)R`}y zJU)*)i~3oV9rbf4H|pn6Vbr~-DC!HSIO-QrNz^Z*%BcHL71S@G>Zo5vwNbx<8l&z< zO;Nv!nxlRVwLtwkYKi&{)H&2|qRyj!3v~hY+o+4EFQP7?zJ$69^*gA`sNY3hLH!=; zhf%+ex{7)LbvNn{Q1_tz5OodpN2s4h{W0oZ)SsZffcjI^eW*V}-H-Zn)bFAG0`&mu zI_f&=LDYk&zeGKR`YY6Fo z^$(~r>K{>c)IXuxs2iv$>LzNAGEnDGkDzWt{WI!3>QU4M)MKb`L_LnW9rZ7$J5c|M zx)b#k)Fsrvp)RBT9d!luAE>LS|3qCw{TJ$9)Gbdtd3*tNE9ySf6Hxb~o``w?^(54F z)RR#UqP`0C5b7zYhfz;O-9$YN^$63Ds)c$fs*QRXs)KqtYK(dXYKnR#YL0pp zYKeL^YKwXe>Ky8|sPm}Tp)R0akGdW82Gm8=8&P+n-h{e@dNb-S)LT%OQEx?ELA?$2 zc0AsJ$2;+O*U95;PikMq`Q3QjgU7X#N8oL@{?W@lLD!kH#aOUtk6XQwVlZN}M~bmC zXMOf7w>)yo$^X6*v3)$}Y|mWt%4QaWy{C9`RvS*wK2Ch%6rUtMb&5|DpE-r)R_e^Hr#vfKNgHX{Nrz6I zq)T*@9??tsL_Zl2gJehylMyjW#>6<85R+s|Op_TgOXkEpSrCh4Ni35Uu}ap&I@utN zCfU+yo9u{PvM2V*fjA^b;+UL>Q*tKG$%VKiSK^x7h+A?e?#Y9ABrQ+S{XT*BD_TjL zXeS+_lXQ`WoAl_^OZr4V84!bHNDPw^F-pe7IGGTWWJ*kv88J)d#5`FLi)2YGlNGT_ z*2Fs55SwI6Y?B?*=#o91_Q`=bBuChr$I6#hRKK+C1YZoOo&M`C8o)Ym?d*! zo-Bw(vLu$tidZFUVx4S=O|m7n$&T11dt#p)kj9W4>2yp^#3?xw=j1|Mk}GjdZp1CQ z6ZhmnJd&0t;eM?*&O8b4@6EH|1?vqfX%p?FLv)fZ(M@_pFX4G$Vv_)JCmUjuY>92MBX-H2*e3_#kQ|9)azYwY za;DQcxe%A+N?em0aZB#RJ$Vq1q~*!H&@-q19(41pXeDi;opgv!(j~e{kLV?RqMrUe<6YFF{Y?3XpO?JdC*%SNZ zKpc`IaZFCcDLE78_)JCmUjuY>92MBX-H2*e3_#kQ|9)aw1O2nK&mG;*wm6YjPuQ$(^_-52SGLxv+m-LB#G9U)YkQgQ-Vw8-D zaWWw$$&{ETGh&v^iFvXh7Ri!WCM#l46YZo!bdoO7O?pHx z=@b2AfHZ<+NT*>kB1XxW7$*~Al1zzdG9zZmoR}vIVv#I~WwIhx$(mRv8)B1eiEXkY zcFCUDCkNt?9FfMDoal5)&cr#n5SQdiT$3AdOYX!yc@U4JVG z_gA!%HqlNxL?`JI-K0nKl0MN-2E-s462oLfjFK@iP9{hrNv3p~CNpA|%!zrjAQs7z zSSBlCm8^+%vLQCfme?jcVwdcReR3cU$&olFC*qWxiF0xxF3A;XtjUc|x8zRTlLzrg zTAri(J^f|4n`cEUX%p?FLv)fZ(M@_pFX_)JCmUjuY>92MBX-H2*e3_#kQ|9)aw1O2nK&mG;*wm6YjPuQ z$sK9z$%9Uhqy@jQiud=qe1AnNX%p?FLv)fZ(M@_pFXT+Nr)9DtR>_)JCmUjuY>92MBX-H2*e3_#kQ|9)aw1O2nK&mG z;*wm6YjPuQ$(^_-58{!uJn!^=jWegea(?qHdBaNDL_6saouo^2lOEAa`b0k&5QAh$ z43iNtO2))EnGlm?N=%a(F-zveJXsKnWJxTO71F4ZHJ#SUhS(%qVw>!UU9uZ| zN8*^Ah*NSV&dG(iBv;~^+=yFpC+^9EcqA?OUI@Iu&*%FqT1gve*hz;@ouo^2lOEAa z`b0k&5QAh$43iNtO2))EnGlm?N=%a{e?$H0|Aj1>6Z2$2ERrR$Ojg7ySrhAIgEX3C zOQ&tJBX-H2*e3_#kQ|9)aw1O2nK&mG;*wm6YjPuQ$(^_-58{!uyg>JR`pqsk&x%&k zCfZ4d=pqkZK9oYh)&Wax=D}dC4Hiw42VH8L>gf-qSGiD6XRq;Op+-v zO=iR_nG^G5K`fFbu}oIPDp?cjWJ7F{EwN2@#4gzr`{Y0zk|S|UPDo=)&U88_7vhp! ziEDBrZpodvClBJ0wBS1q@&3M;@2_YjZK9oYh)&Wax=D}dC4Hiw42VH8B!bWh*2^o#>s@3BvYi3CNnzCk~uL?7Q`Z163b*otdcdcPBz3Q*%I4iN9>Y4u}==f zAvqGqbWh*2^o#>s@3BvWFV%!pYsM;dvupwl8*63b*otdcdcPBz3Q*%I4i zN9>Y4u}==fAvqGq_)J zCmUjuY>92MBX-H2*e3_#kQ|9)aw1O2nK&mG;*wm6YjPuQ$(^_-58{!u;QRXV{=S^= zFKJjwn@;VdLv)fZ(M@_pFX92MBX-H2*e3_#kQ|9)aw1O2nK&mG;*wm6YjPuQ$(^_-58{!u zyh8VT`WrWHo)xX6O|+8^(r}V4ow`Yn=p}ukpA3jWG9-q{h!`bfVw_BfNirp-$&8pK zb7Gz>h()p_mdT1(C2L}xY=}*=MH+3gqth4G$Vv_)JCmUjuY>92MBX-H2*e3_#kQ|Z5 zn4IWzO3uVNxe%A+N?em0aZB#RJ$Vq1qy@iw4)5=)`TmMl(k9wThv+0-qMP)HUeYJ} z$$%InLt>bWkVce@=`>Cz#3Y##(_}`>k~uL?7Q`Z163b*otdcdcPBz3Q*%I4iN9>Y4 zu}==fAvqGqmAEE1;+EWrd-5P2Ny}?=zo)-F^5$95O4>v_=@6Zy zOLUVS(M$S7KN%2%WJnB?kyF}kM9G*KCljQRBvU#~lNm8f=EOW%5Q}64q zyq52;XeDi;opgv!(j~e{kLV?RqMrUe<6YFF{Y?3XpO?JdC*%SNZKpc`IaZFCcDLE785;U&PWSsd-mhpSZK9oYh)&Wax=D}dC4Hiw42VH8B!V?3 zxfA!~K|GR{*Pq_6apv{BU-E{Pw25}oAv#Hy=q5d)m-LB#G9U)YkQgQ-Vw8-DaWWw$ z$&{ETGh&v^iFvXh7Ri!WCM%>-C2KmZlMS&+w!}8s5xZnh?2`j=NRGrYIT5GiOq`Po zaY?SkHMtSD-nPC9hzBweDL^oU;4C;G{N7$ietn2d-~ zGA72!gqS2#Vw%i|Su!W)$%0rUOJbRbWh*2^o#>s@3BvWFV%!pYsC+5k5SR_kgnXHIavL@EahS(%qVw>!cMwjgAv`-Gi zAvqGqgPQd6Vwv_=@6ZyOLUVS(M$SB z!%qfu8YDwvn2d-~GA72!gqS2#Vw%i|Su!W)$%0rUOJbRs@3BvWFV%!pYsC+5k5SR_kgnXHIavL@EahS(%q zVw>!UU9uZ|N8*^Akj9jp>2yvm#3i{B*W^ark~?uv9>gPQd5iA%ExcdRO4>v_ z=@6ZyOLUVS(M$S7KN%2%WJnB?5iv@}NFz=rbebenVw%i|Su!W)$%0rUOJbRM%MyFXaC+5k5SR_kg znXHIavL@EahS(%qVw>!UU9uZ|N8*^Ah*NSV&dG(iBv;~^+>pkW-05^r9>gPQ zd7JL{ZMv_=@6ZyOLUVS(M$S7KN%2%WJnB?5iv@}#5kD{lVnOvlNm8f=13z? z7Ia!9OJbR|)`HL*@M#3tDi+hj-Vl0C6c4#Xij63663oRTwfPAbWh*2^o#>s@3 zBvWFV%!pYsC+5k5SR_kgnXHIavPK$pvZ2!^*%I4iN9>Y4u}==fAvqGqgPQd8h98oxESsO4>v_=^za!>C&m2^oU;4C;G{N7$ietn2d-~ zGA72!gqS2#Vw%i|Su!W)$%0rUOJbRCObOql0C6c4#Xij63663 zoRTwfPAbWh*2^o#>s@3BvWFV%!pYsC+5k5SR_kgnXHIavL@EahS(%qVw>!UU9v|SeR81F zAvqGqgPQdAIKO-MnAXO4>v_=@6ZyOLUVS(M$S7 zKN%p6AQ{qWn2d-~GA72!gqS2#Vw%i|Su!W)$%0rUOJbRsU(rh1L_6saouo^2 zlOEAa`b0k&5QAh$43iPkh>|g##>s@3BvWFV%!pYsC+5k5SR_kgnXHIavL@EahS(%q zVw>!UU9uZ|N8*^Ah*NS#8gp`?(gPQd9UvGy}V!1O4>v_ z=@6ZyOLUVS(M$S7KN%2%WJnB?5iv@}#5kECjU<`UX`0N4Su!W)$%0rUOJbR!UU9uZ|N8*^Ah*NSV&dG(iBv;~^+=yFpM;d$bpwlC1 zdB5)W{k&h%O4>v_=@6ZyOLUVS(M$S7KN%2%WJnB?5iv@}#5kD{lVnOvlNm8f=EOW% zAdMnf(rKBjh*h#C*2#w0BwJ#e?1){mC-%vKI3!2nn4E}Hawg8ng}5YF;+ouuTXHAv z$%A+#Egv|&U*pUNc)#QgD`^w$q(gL)F40YTL@((R{bWE4k|8lnM#Lx?6XRq;Op+-v zO=iR_nG^G5K`fFbu}oG-qe|9vS|=M~lWd7?vLklMp4cY`;*cDPV{#%+$(cAO7vhp! ziEDBrZpodvClBJ0w0uzS?+1CmqLs9fhMjci)JeKTH|Y_*q)+sd0WnC1#4s5Vqhw5s zlL;|Nro=Rv5wm1Y%##JNNS4GhSrMybO{|j*(rA(`owmu2*d=>npB#uoawLw)i8v)^ z;+$NFOL8Ty$&I)rcjBHrh)2@$A>HqXc)y~Rw25}oAv#GHX}C#`PQ9d0^pgQGNQT5P z84;soOpKEWF-fMxG?@{zWKPVJ1+hq$#4=eCt7J{AlMS&+w!}8sA&oBC(`la^h(mHD zj>(BQC1>KCT!>3@C9cVhxFvVuo;-+0((+;5?}vH6qLs9XcG4j_Ntfs*J))QNk%pfP z=rl-%#4s5Vqhw5slL;|Nro=Rv5wm1Y%##JNNS4GhSrMybO{|j*u}QYXHrWxoWKZmq z1JW3hBb|=Pi8v)^;+$NFOL8Ty$&I)rcjBHrh)2@$5#8@cc)y~Rw25}oAv#Hy=q5d) zm-LB#G9U)Y5NU+Th)$zqOpKEWF-fMxG?@{zWKPVJ1+hq$#4=eCt7J{AlMS&+w!}8s z5xZnh?2`j=NRGrYIU$WHIn(K!T!>3@C9cVhxFvVuo;-+0((+N=??-vRqLs9XcG4j_ zNtfs*J))QNiGDI52FZ{ZCL>~$jFCp1Oz1R8ro=Rv5wm1Y%##JNNS4GhSrMybO{|j* zu}QYXHrWxoWKZmq193=>#4$M$r{qkWlMB*Vk}I9A$&I)rcjBHrh)2@$G2QRSc)y~R zw25}oAv#Hy=q5d)m-LB#G9U)YkQgQ-Vw8-DaWWw$$rNd%$&603WKPVJ1+hq$#4=eC zt7J{AlMS&+w!}8s5xZnh?2`j=NRGrYIT5GiOq`PoaY?SkHMt>;ExFU_o;-+0((-ZL z@5gz+qLs9XcG4j_Ntfs*J))QNiGDI52FZ{ZCL>~$jEQkFAtuR`m?kq~mduexo-F9J zNS4GhSrMybO{|j*u}QYXHrWxoWKZmq193=>#4$M$r{qkWlM8W4uEaID5x3+{+>-~= zIFgo6=zc%J`xULEO|+8^(Mh^QH|Y_*q)+sd0WnC1#4s5Vqhw5slL;|Nro=Rv5wm1Y z%##JNNR~*WOjdMSC2L}xY=}*=CAP_q*d=>npB#uoawLw)i8v)^;+$NFOL8Ty$&I)r zcjBHrh)2@$N!{-!dB3D#C2cyjlMc~IxSRNwO|m7n$&T11dt#p)h(mHDj>(BQC1>KCT!>3@ zC9cVhxFvVuo;-+0(()(BQC1>KCT!>3@C9cVhxFvVuo;-+0(()PI?`L?wqLs9XcG4j_Ntfs*J))QNiGDIb z8bLCo(=Ztkqhw5slL;|Nro=Rv5wm1Y%##JNNS4GhSrMybO{|j*u}QYXHrWxoWKZmq z193=>NMlS+bUGzx;+$NFOL8Ty$&I)rcjBHrh)2?L`WM9FHvn61>3>A z;MCwU2e$@~Ie0br%)zfAU=BeIA#(_8h-fgP8e--r;u;d>kkpVehqQ)_Ib=2D%ptF# zU=BqMC37fisF*`lL(LrO8XD%%)X*}AwuX*5bT#zMp|4?J4nqwia~Nxwn8Q@VOoK7k zurNQd)UYy#wT6v3Y&Go6VXxs}4o3}^Gq>so0R9caH_w`bRfEkO>>3>A;MCwU2e$@~ zIe0br%)zfAU=BeIA#(_8h?qlEL(ClF8WI|eq=uCFiL{1{Ib=2D%ptF#U=BqMC37fi zsF*`lL(LrO8XD%%)X*}AwuX*5bT#zMp|4?J4nqwia~Nxwn8Q@V%pB$#7Ur)nGFRy9S3jI5oJ;!L7k#4qgpDbMR{j zm_txQ$Q;5NBIXd)5Hp9khJ-mJHKfcTts$eq$ZE)$pU7({m_t!R$sEcWD&|ntP&0?R zhK4ybHMGp3t)XKMT@5{R=xZ35!%)M>9L5?Z<}lSTGl#i`g*hxWtjuApVPg(k4Lc3S zUckTHj>hMYO%H54=$MGYnM6J-q*bEs;lnL}Me!yK9#TISH! z&@qRuhMqa}H4MyQs9|IdV+|8?m};1r!(79{9F`hZ=CIbVF^8>&ojL3^9L(XU!E*Xn z&|k0_XKecML&FWL2Aet9H8{+{sljCqZVeuD@M`dxgI`0y9D*7`<`C8pF^8yzm^s8X zB+MbHA!QC}4H%$zZ8f@lZ*WfS*rv{e> z!>z$%e!{E4XAXW10dojy2$@4zL&O}S8e--U*N`xWq=u9^q%~yBA*&&04tWg)b0}&k znL}Aa#T=>{YUWVa&@hLlhL$T@5|+6MYQ>a~NtEnZsDa#2ls?X67*0urPYG|25TSLbjx*B@s(AO}~U<@^k%ukFpOw3`bVP+0<4GVKvYFL@WTEoU1wiFdKBtQu_QVAtR<2d4&?Ik+`=%)zU{XAXW10dojy2x&0F8Y1Q= zq8ei65Z90}hopv-IixjY%pt2GXAXG{1#>8BD49c9L&Y4b8fxZH*U&JBriPX|v^8|h zp{t>14t)&+a~NtEnZsDaM1wKaFf%_f*RU{$rG}L`tTk-RVXI+h4tos;b2w_SxXrH* zx4u5i!K%S#4t5O=b8u>KnS)z{#~i#GeCFWS5HN?JhLAagHAKuIsv)M~W?Vz!WO&x| Y{_vU4n*qZe~(7cV*mgE diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/johabprober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/johabprober.cpython-312.pyc deleted file mode 100644 index 7db84d004a84c6e84c4487f865fea84db7ebe88f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1381 zcmah}OKTiQ5U!rrj^tg*QEX|IT!f5+2V)76i*bVRL%~Lo4@ zD|FC7kQKz_6lC%bjPeii2Liby*atI65XdPvk+s11lq+b^3h9Dsk+p<4D(8LXgk1QA3eft2`!DBVbm)bvfQn~9a$zO8jDanhP!BVfRN zi0lK19A+PzWiH?C)jaoKf+vp@vnvlD+_}3P3(4blSH^jECkv9Ehy^;Q?&VROZEeUv zvb7-Gjx&bV>9uYmDq1 z!oVjH_(o*+VUtA0LESf*6%l4{8j*Qm9S@^@=Z)1GvDW(VJ@MTQ@SNg;u3NTIIGo8Y z&qDRUYN_JtH|V4InH+(vJa9<%;4#8nl_MZ4&_N;{wYXBblY=?(GHWjXkpcyOV)bCvPZ4exZM)5 zWH&lN_-(MoM5_~b7Ag9ooG*sRa>V4~PQD$qJDTf-PLJ0y`R=6=mTwQv0^>*KS?#{n(>pzVjjz6vsFaqA8O&K(8 z3X>z~5zkmJ>=o6=Q+P`FMKlY=%p9LWS=3dlhy~4plUvdhMi=x9K8DtHZ%k3I`lYlOr!>u@ zZld%$rQdafr1WU83m3u1S&_ZM#J?+Vs!l#eQ8b2>hb&1b^$7n!6;%D**1&LAT~%UU zIhIhoI)HP-vM-<2!I?NSh&}Tp{10#&n3dto8EVZZSCp%%T`%!&Q$Il`R1dhQCuC$c z%W<75$5*JYM_PV8^l%rGX?sXVIZa$aQ#fc9IO=Nj%Z4@7iXHuk*X|c3I7|E!w5ivL jITU9mA>{lfkejFQ=_!163iB_W25J5|b?qE**S-D^)aFUR diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-312.pyc deleted file mode 100644 index 4d711aa593e67cb7e030fec93222da4397343cb5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 39536 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 KQ%Qev_x=y}@lPoL diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-312.pyc deleted file mode 100644 index 4d7035f0034db0ed9024cf3f14d7d1ea8b2926c5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 83109 zcmeI531D4Swf>W~Y16q$N?S_lJkJwQ=A`pH&r_Oar)}D_Nt1M*P!NIVQxp|ML_|P9 zL_|ac#92`sZXHXVc+clhpTlhxRGi-Tt+m(x?9<#dErb5sd#rrjzrFXF)?Hm|uXFD` z_qq1%+vMPX&pvhghT7Y5bACp!|8@6`KfJU)C+F52m*aA)a<=BK%+1ZI%yG^5pKE?g zu500Ppn0M#MO%sHi?$YRBidH9ooIW}4x$}JJBb#E7K#>8ah%RV=ZSU^?JC+$^nB6o zq8Etv5WP^er)V$H-lBa(n~V09E9ghPmq+R^JV11y=pfO-qC;exq0$~EI$U&w=t$8~ zqN7E}h>jH?x7_eFQKyEm6M73XKr0yK|j4_u`YRlSaG1}Ako31W?jx1COyMNM~IFT z9VI$ibd2a&(Q%??UA1UKHS6XD*5!5O$yK)$ZRLibCtupFrQJrft@N~$c6(`e5bY@1 zN%{+V20- z8X&!K-(|m9m+fIPXSf@P_6TW@l(t!ybH+&jSkZB!<9Ss0?hx;{=D8>PZp*;Bd@b{2 z>z1PCyF7ohF58)`%WciNoD;V$&QYw(5%XQ1_vu-e`|c@L>?P;bTiSg@n~N>_ibpl{ zT^?_s%!vCgk3CejG2dlR+;?ej^IeWwWZ>D1=Xt=oW=(o8UPb)DD~CVkyR90rF3-!X z%l);MYcbztkHuXcIUX58>#`mBE-CK2?1}p>_iet*c0BHKzFC(?HtVwg)Yj#U!Sd=1 z5qq0;**{$RE$(u^qol{;E_*Whu3A?uYJMDAH~*B@<<-UGE{|hbjpt>NfivU2%br4c zO(N^E&wQ6#Tij*)e3{#LR^yyrGN-qAon)~B>C&pcDyWq&)l()MzuP5Cb7OJv}7W?ivCp%&A>AoCH@_c44m1Rb#uhJ zv@mUL)@{?kx;*DhS&jW|#2OZN*<-%Tc1N*vrmSYx<*ayQ;FXwl*|x04wpo{3S={9n z_V&KZeq0UId>32AR%G0Ztr-@@N(rILEBZwnYZEZN1C+Cr1X3$Je`@^-9;fyyjD9HO^=%tMQ!TS&ds+ z+~xVjS7hjkMFzF3dT!*q?HX8@do|zXUM(`PZNAHMvB<#w#v=pw7Fm~bEi$kjj||+a z`7TE@RTJ!w`!4^LpW1gDT9+iVU=?Wi`&RH3QqW-eo(!-sKVSZxL$Ng{5QbU5?p$ zm&X_^(bU$v933XxpGjokQLUQLJf^C4ja#=vU|k-+@k*HI68Bxsk5|H+(@DDKeV09r`z|eIz8hJW+gRLf=(`QA%h$`S%XZwl>@n+d&vqBbGMU9(RDrQI zLs0|ka%+nWymnhNux(k5bIiJI$F0km1rlRVj=P+jY0bd?c--anoL)7-Z5z8s#xYwn zu-#NO!8vw+muE0qt|DGd@Rc#^>S}=&wTK(@U3yetU+z5~8`xv^W!vn_W1D?x&Bj-} z+$xH^oEx_<$Ggc@n0>kL)AL@=Jauf~@tV3z#xt;ckldr$mv+pQ*ErwqlF`0aqcJup zM|thM)37ej(e6RA-Bje|ImXvy*ov>DSkYDuJj#`@jk3){%CF36L-3eZ!s5nV7kXN&2A+Xgms<{(t7|;3(Z-h7cH3U_?-s!SS`#W z#A{*pz+a$N3uABIy6iRIfYZdzz}&xSyyN=6RcS*^b9u?ysrHz&X8rEzCB&1=?^; z#xYxyaYj>dmviF2%O1;WY{z{U*VQ2IT271NZubV(r9JFDceX9=vYpAg?6)-ouPIYx zz?=rY%enUM1l#dyjXjy-F8dp|E{>BSGMtWec@^fnJcju$+wr)|p3IS

Ab8j=G)o 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 delta 20 acmX>oa!`c(G%qg~0}!0pJ!>Pk85aOPEd{;+ diff --git a/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-312.pyc index 0d045d3eab5768c3f391949433669ee6a065bc5c..19964a6d9abbbe1dbd1736bbf6fb15bca2dcce39 100644 GIT binary patch delta 24 ecmX@jc$$&>G%qg~0}wp!oi~wNm(hHpG%qg~0}!0pJ!>MjE~Cjr%SixL(FY0u diff --git a/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-312.pyc index e97376bb76810a01594d0d8b63840f56261dcf7f..2cd69f08b1450dd3daf3678b8deb1ee8471349b6 100644 GIT binary patch delta 13056 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 delta 12872 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 diff --git a/venv/Lib/site-packages/pip/_vendor/idna/codec.py b/venv/Lib/site-packages/pip/_vendor/idna/codec.py index 1ca9ba6..c855a4d 100644 --- a/venv/Lib/site-packages/pip/_vendor/idna/codec.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/idna/core.py b/venv/Lib/site-packages/pip/_vendor/idna/core.py index 4f30037..0dae61a 100644 --- a/venv/Lib/site-packages/pip/_vendor/idna/core.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/idna/idnadata.py b/venv/Lib/site-packages/pip/_vendor/idna/idnadata.py index 67db462..c61dcf9 100644 --- a/venv/Lib/site-packages/pip/_vendor/idna/idnadata.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/idna/package_data.py b/venv/Lib/site-packages/pip/_vendor/idna/package_data.py index 8501893..ed81113 100644 --- a/venv/Lib/site-packages/pip/_vendor/idna/package_data.py +++ b/venv/Lib/site-packages/pip/_vendor/idna/package_data.py @@ -1,2 +1,2 @@ -__version__ = '3.4' +__version__ = '3.7' diff --git a/venv/Lib/site-packages/pip/_vendor/idna/uts46data.py b/venv/Lib/site-packages/pip/_vendor/idna/uts46data.py index 186796c..6a1eddb 100644 --- a/venv/Lib/site-packages/pip/_vendor/idna/uts46data.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/msgpack/__init__.py b/venv/Lib/site-packages/pip/_vendor/msgpack/__init__.py index 1300b86..919b86f 100644 --- a/venv/Lib/site-packages/pip/_vendor/msgpack/__init__.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-312.pyc index c14458c30f5322064f2780abaca4854d78812e1d..1d157a050b0188cde6d991c06c66dd65b4820017 100644 GIT binary patch delta 560 zcmbQmcYv4oG%qg~0}wp!otI`hkyn!G4#PwZ^?KGQ))clVwp5lZK9DRb$Pz^5gLo(4$<=P{AC@P|m2yGuedESe^su zlqyz3Jp(<9TSC6U?g5U@-thsUL9PLjAs+sIle-x|GjdL@XX@hO2dXRr5h9a?neUnM z0$G|&MVv5EAX@;$76KB*Oh7_Gp-2Qs-C`|BOwLX!5(l#7CabZiF^W$1W%*zT3QJAq zB2WN<_1t1fNi0b$W(M*VU|QKq^FW%5q=AC!lk-?L*hE3P#3s*SRhWE`RYjB|Eior2 z38Vz<4v?8e+><%jWVpeu1=(37Jz1YkE*Rw8B9LydqkeJN5-LBE@f{@x3X7$Ni+5AO8 W?%&JhD9Lb8lHXCA`JfgfkOTk$y==$; delta 626 zcmX@WJByF^G%qg~0}!0pJu59|BCjM92jfHyb#>+xmK@e7))dw#wiLD~_EeTE0gx(G zkR?1ZPo}ec?POb44K^_lOJZ_1s{%7~apmMrRy8l4vecsD%>2Cg%)GSxTO4VLIXOunO<>o7 zY$@Ua61O?<@ek%f51NOl$4x8Nk zl+v73yCPkn7$XoDPXH1hm>C%vpD;+?XHb63z)O^AwXJtJUevZb hpm<5!d2$S!zZl4m2ZgyD^%)N8^E)vzA7Wqxk^m4PgpL3J diff --git a/venv/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-312.pyc index c1a79f4a8638294311f5b1413faa1344c03036d4..e065f0de6e77ad3f51bf8a2a7339469ebba510cd 100644 GIT binary patch delta 20 acmcb^e}|v@G%qg~0}wp!owt$uB0B&=YX)-w delta 20 acmcb^e}|v@G%qg~0}!0pJ!>QPMRou}t_Fet diff --git a/venv/Lib/site-packages/pip/_vendor/msgpack/__pycache__/ext.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/msgpack/__pycache__/ext.cpython-312.pyc index dd72e4a3a0b039fafed4f32224ac01e73e1163e7..2b64975aa27d0796ac80fd82d05a41c2953a05c6 100644 GIT binary patch delta 2005 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 delta 10067 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 G0r>yH&-u#$ diff --git a/venv/Lib/site-packages/pip/_vendor/msgpack/ext.py b/venv/Lib/site-packages/pip/_vendor/msgpack/ext.py index 23e0d6b..02c2c43 100644 --- a/venv/Lib/site-packages/pip/_vendor/msgpack/ext.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/msgpack/fallback.py b/venv/Lib/site-packages/pip/_vendor/msgpack/fallback.py index e8cebc1..a174162 100644 --- a/venv/Lib/site-packages/pip/_vendor/msgpack/fallback.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/packaging/__about__.py b/venv/Lib/site-packages/pip/_vendor/packaging/__about__.py deleted file mode 100644 index 3551bc2..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/packaging/__init__.py b/venv/Lib/site-packages/pip/_vendor/packaging/__init__.py index 3c50c5d..9ba41d8 100644 --- a/venv/Lib/site-packages/pip/_vendor/packaging/__init__.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-312.pyc deleted file mode 100644 index 57e4af60ffe5f3c7c2d486888183ab5f2a2f3ae5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 617 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 literal 12063 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 diff --git a/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/_musllinux.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/_musllinux.cpython-312.pyc index 10b0ffab04a5c1e310f5a32859c15d4c25b91d82..878edbd56f9daf529a477c530cd5119d2e7948b0 100644 GIT binary patch delta 2371 zcmZ7%ZEO@pbY?&9`=i(UXlbD=R45CGP()GmND)v8Rw5PU#9Wq}IeO>b?K!(gX)Rtw zL`+a2Yox>|G$El0nvm!Z{^Ae+=#OHJ)TPEBY9jv%#h{oN-|Y3YIGcU%&6{~|-n_55 zx#646$k*X;0KxeA-B0qz0;eLW8lL?gBXk-OltBa&LB}N_BVbO8x|k7NEM+7Y%Ng0l zo{R^uqCWMiIog(KC;4}ejqMqVfdjfYo-$G)f`P2A4dt$Id zDt6bU=0lPo+=>nJd3Bnkh}_UYTI`)d`{H(f8f_=7^R=IdNN7+T6xD_HG2wJg#ZFKw zmkmp^3P#!NRYk}5v_+X_8O#avY9&hgsui6&zTNcIDlO;e4Srb=^KRR@eS1Ntx%sxt z`5(_N1@37?Q3gZ2h36s4R3yS zp=_{TRkFuJ%j|DM&GIZi%T}Zp(u`-93z~s2Ljc}FQ^ClaI{+Nr!QzeO++1v6j*t(2 zFcE+LV0a(K*gh5M=}>Vm+(tGnR;Z|gBdl5L;IhdhrYJ07&qN-=t#((m>yaCr$2hnl z0dS-e*gce(vs_uRkE~Mnt#J|a!Uk1f+$3R4ul^ zz7lO&oZxHmY(--x&2rV*gLR*<<*?FX--(XZ?zxNy*!(iHE8V*CBkSL*4uh8)$*=(( z#@1Y15E{mfWG(Vb{BIlN7VL6tNxSr^+$grgqQ$-K zj$yHwfUIuYwHtM!b;!g6P~m$KhVR7AL*iaEfIE@JEq8~-15&5lZo$dCcpqXSml_lX zP+dm#d>&~o;u>278~Pwh9@8R}F-NlKAxjN9l2M^$#6&Lo_}k0={c@fiXuyJ)6*b zsh$VK^FE-iJRtXM^j>+;%jr#tEzRPWF%0mY?Bc%cf$v|&vD9+=iZ#q8MtICwdmTBr>4Bo32)1kFEZ7XyoCgL^Kof9**3cIZ2C-kynCEY zCc7cj{>{g?O(i-;51oDe%HaMOT>!i|8x1bSX}*N4K5hsEWowS|s1nIT$x zJ&VAKEiYJKb0aH47l0R_q8BU&Ta3Rb^#_FaGR literal 6897 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

*qTl2U-ZB*}0~ zk_ii;?vOZFVS z!d-F+=;i4$|H<7h;TD-21`DKla-7Vgqmv;-s)yjHgh0qLtg(W3lI=j}Ksw7CkMlWR zqod1EjqZVNmU8@18D&^)Fr&kg#VWs-qAa~d@ukz6zZcd|;Wtjtlc4MPOPh-qW(WKh zar@r^hlT*|bhWuzD*-ucYky9!Qc5n>fWsz#%b%wzo@$V)Td?2^F7&2BQzbOZF2M`e z-T@`0jAYb(W3QL27+P|GtSkr!?L}vq(DsGO<9-OdG&E}eO}?EV_v;Q!pUqcYuf0}# zea(E`f$x~}`M7>9Rnb3~4hBc7jgXC1m+rLK+$V1d_Jvr%+zEJ z4&G4F3_hWx3{F*05%lPwd2tWHIKwuern8x#pmrnaQPyPA&?FNCO|@yG11qdf{SiL*V3W#>ibTvhW-(=5H!TyXA~IQYop#V$|n=TR_u zn{RBMY5eOqK1=^&@13fDsr~2LyH&re{|D)Tr+ZH5{_blZ@g1QWqUB#W4mAjWB|v7l zmmtYY_XO0(1o_9A5-y8~&{@BdtUJ;MD(8ZzYQ>leIkE&H0JW~Fb$Q3RWf#7Dwa0mx z!#`^@B_E+;ao+>f`2niq?PO`F3>2*vP&fWd!HS>(_Adc-VF)zg)nv)oO8|DFabgKz zrw1Y7s}hcK7C_ucT8T!_gDN6$1l^HL@EWv5&cLRYuwyx*-eyJA3{Ap^9#1M(#9V@l zELewlT~4PIgqYDmB|2h`v8`Qf0_$e?=5RJofRAW^(6-V0>Nk}Q>Jk#Z%$8bl}fWt<>9`qZo?vc3O zt7FLS130IsQmNAr09d9B$Gg1@M>6mQb|l-MQPWXH13LoeWe6vZp6F(Zuf7j=BxqB6 zp)hP3ax{S@myitsi8O?}xUP~7sX|a`LcEfFRMF8RAMJCx8FK$qZW+aI>6S`I9 zY&MS1PE7Mxk{{OvI*ppksYB40 zf}i#QWDI*eUq$?lUj%NhyRoiN`Q}8=f}?WIQM=%*cv4j}HFEXCD<4j)GusPQA&d$- zCv6M<`uy(e`>ySqtAAsrai)7_*KFf#*KGS-MMuHe@eHDf&hIn?j~^ebIvAh`vy<>l zDoJB@bJxaPfTht!XGg|tC|$>x4HpgtirDdjia~1d@Y**f{3NvPG~0?7bekD3$AI&g zqjdhkjfO*#1)e$v;(N_^AnbA0gq9$@e&||m~YF3Iyz&EjjV!NyEXFYHvU{Pc7 z0mF;t&N>A!iLhcYs5)GA?L0hwK$Hz`MK=v74~7=3D55rl>S`BGSB^DaIQN=i%06`* zI?xnoV~|7OMd>q6pu(b;&{dC#|1qh2OkC{W_n1^YChq?rdw)arf<2>qr~31&uf&T4 zs?$+c%qX)zxD%M|xs_hT)}k{+{dsk|>Dp+KKy~KFv(a0p7qR-hpK`Qvs^d9%L({*41)V||e) zTrKM?hJ3U$54@n5cFqKD_!hBR6p7%S9J|l2c`Q`_r>Ajp&qGh+yr;3?**MX);HhNM z{O$*yO>;u)^l(9Fo%3w^o#2|>Jhk(IQ1=LH^MOs%y*Gb)CH1cW`%!p|DF5Jj=Qw*=ApaW=ifYBXgE^v_29j4oTQK7Ss^kN{;gBQ OJKk6f5TTx(&Hn+tL}us! diff --git a/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-312.pyc index 16fd2093ae2c1d9ed4999f349a685c8568173d7a..02c6969012d86cad62e70e8927e3d77a03bc2210 100644 GIT binary patch delta 20 acmbOuIY*NFG%qg~0}wp!owt#DA`bvL*agf0 delta 20 acmbOuIY*NFG%qg~0}!0tJ!>QPL>>S-A_d$4 diff --git a/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-312.pyc index 6e61e4d0eb65cba6e6dd4c6d95283f4af884e4af..4a9e6f3233ff1a7a022edfd38d8f8a59d76ffb42 100644 GIT binary patch literal 11000 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 literal 14045 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 UUtcFs{GzUs>0>@82c!D^@vdQyyInK8 zhd-$(7%ZlPnNTv62`9tsyDD9si6kQo_NQwy(PR`O4!w!g zz%`@>wb*^$-8UI$*brdD_qhVDcDy8c}SM ze2HD6*oZCzVMqjVhKjY-SC$UCM&|mSmkbvuPD*hBYGD zrgZAqDe2W$_II#F`V&6KFUwRcS$2Z5oH5mGn!;gOzL-_gg_$Z@R?Q(}Rysw@lxCaOpp_jliLDJ@(u_-kZ|i3VE#21kj3`4FlyjOjIHHeq$}p#z zq|-&}#<|Wi(XEb=aT0;mSyuyqRR!HOw8n9QpVWCXoAg((I$l2v)0_3D22}1E_?{Y6 zc^CyXr21eKVH9AjQp2hUqhGC7t6&U_`x6l-RIcbhGarzYas_t;nc}>eb2=QUd|t9_ z0tW-zfUb4hlEArat6j3PL+2&14OJ+7c}~*KR{Qbkx7#JfP$lL}R)=(2(JjrAo;SW^ z8X(VEMNNIDxfjrKMVF598FroGdft-N}Pr_$bXQ3vB_ z95o}mXrC5Dc3kG|lIDtfnBu)Py>W`a%Bkow|8ss6kD@XDr)U)4!~KaGCoY4#ZO&zc z8k2>T!-H!$KI(xEpCxJd)@(;~eU3nGM^2#Vn2wlXxsFiXIuQScHY&@6>H#u_J7+=m z@L5`V*ol`pq3k-KBQjA`2WuAf9GbI8y~{4^hHlI9L|s|5b;t$mE}*gg2;CL5%JG4& zmHM{a?gRPy?(4@_{b+}@xN~9Wb>Gdva%1b_#KOd*#=Uoc1mFG@srkYKnAq+yrTRs@L8~gp4e7yZZ zQ!c#kf2%y8H!SK}S3^fR^pFc2ZRH<^>W@nNLrDO5Q!r9PH`8GJ83f)5gdrfO@Ne)O z#t=X$nB3Y(yNXi~zFS+#Wh(P|PUDT2ITb?uJ-Co>^TqvWYS_|9gIx?OSh)g)w_$UcT3NmTW3;Pwst&IW#W zf;%j2U}=KumJ(H@5w>%DDN{Eb(W2LvN+duL8s+3$v}=Mc!IKsWzX+WZrFmDefz-YG zEsI*E=-nY1u02BI(6%NTHaU1{VlQx5v(WtueSHNjN8;1Lr=gl#-P7I6jk^}d7REjj z@7kYC-kZ$t?#?$J%!OZEuB*>&dpTF%cIRR)o_G{aQ2L(fo|Sn0j5=q`8u@tZqi`$5 z?w{VjT(@n;o*SDTn@P=dJ_FBH9R*a7%`BvBxPnz1={>SmPbv{G~esxtc`IpLkv-n!TA!HvyO{zp_!PczM87 zp;glKIXFkEc%68Za5|1nX7M{uHi+EpYvSaaG8Dz*PZT;Ob&r#S+9j z8!i7T6=wym?Tm}QPqsARs(__jo_7SCpl<1gWh=&zM(EY(MEXs;FEf&6?<~l+B_E-w z*iF8ryvwoJcLdWu4{sT2Nw0_yWm&rj{u3{YNhl#G?uS5T-Gq*M&-VG&4|YDT*|Sm$ zw{+7p5mmo5uP*8fdOp1Sar>c9wa-(ZrSk24OX0pXR7JLz&Tcnj9 zlU^^5NHjZ349C}R8XC;d+r_*$yDGIZC_SDYaD z*I%d>-oooIMTOS&7A$nFi&*&fx+n_4XVIYGh8<(QT204Hk=4%dK98tgWXl=2A}Z z41JNahr9czq~5pXgd6^Y?t8a~oP=3=!&o$xLn(*xzx@a|{}W07KnK4-iNB$)FHj5o Zo{2p6&+mAKVE9k?IL5&>M0=KN{tx&SrA7b% literal 6933 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 diff --git a/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-312.pyc index 78cf195f29abcdda800fe9ec0529717bd437bd88..e152d01e691e27e3bd91a5425e5e67bc5667a82d 100644 GIT binary patch literal 38751 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 K&P|$G(DZ-SUSjhA delta 7910 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 z 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 delta 2212 zcmZ`)TWnNC7@j%zbGp0TOLv#Hw6tt#ckRU%f|ZM0L=?P~VwLEEf!Z^*yY8i#bBdvE z)1oBupr$yQHWIaoK9r!b30^Qp0}sR)eQ2#3a$*9BnrM7*O?gnC{O9a00>(+sH}hX+ z=D*E<-rRJhbMh;%*FZ47{PgwV5kEpda-uTy@?zx?jL-}+k%==X$!8&hvqDnHib*jm zC8eyKl(R}w!N?R%DWhh!q?Xl_x=YI$BU_cM%6gI>jEGDmQ>lf6iA20)z&9*#qJ+t6 z0TIzuiSMjXx;p6>(0$0%P9Re!fwN+n8+5q_aI0?MhF~{J$JtAP)sx9^i70Kj5l!z| z@P?0M#PkuLSxx-IlIcGoC8K5l?DLSaQ6TYwBnXmKX2{i)h#%zDL?D`Lwp2p126Sp~ z&}sFQ{gTWui0Y2vMC4a~XJ0~g^m}Q3oa6?G&Hlh+7_p4h#J&`tU_T45;cE7**y-}# zW?LlvfiP^Mt2jhB)B%hu2RjdUJ<&d{#}Aq9iFns-2}jBeW{IOvVvo_>P}xDyMM#2= z$89Ceo>yZ&6Bke=x@nnhQtA`fR=FY{wpN-ED&UIN07?jbf8)-C%-&NvwhFW!bR7BU zU}lV1JWowcG|E|lp}|}}ml_((q{hi%ZV-)eF?`l-08@x=^(diMDu1(?yb4`2 ze_{jLRxi#81vG)5LK8v(vqi0jEoeFxSd&pxVzdYamojWG>~sh7>ose60h)3;P+|T% zo5~6BDjj5(^>v|gB~?lRgM_`TN8KC3qLdD>&w;}1d%dR?r+Mga8OIyl`=cUA*~>;V zXz?uFGRj(EQHS$iG-7b#f>F7}0Nzz27KPhx*#;z>URU)=Y+Q{W>grCkw>ao;-1VQt zZU9a8nWtAggZo&Ur+>>?^@i!CcO=N1xjcWC_7R*pUOEZB^fek5l0-Q z#F0kxmhFfpIqJxnJd{R4q%B-o86Bh+F&!CZ+p>5*81}6R?0`ipeAY%N;wf~^U_HJE zIyEF4FFbhs!B>MbkyDXbWA5&G@qO)#23}o=e9?HZ@!RhH<#_*cVE?z$!|Ws9J9sBM zSiQQt8C`0w+I_otsS5)-+HfjEcwycY0ABNM>7@nM6KOejvAPwrU;S&s-lyXbh>?O| zs{EZ#D0UF6>{03t6qHKkOsEBQDrlGM2_e&0P);MWx_|)vZ^#wB=djJ6vODbS^S6DM?uZ+7C)ZHSL2HCqbUP<>9=*dnXKovCbIFXFHi^Gqc1KOC@i;8@!)F~~!!;KI zKlsAaWOnDNk!9bSsrxRgUbZd#%4)Zn-IN3wwzx@XI@cYMG3$*s3JHbHLQ^bQ}>f=(a(}pxlm>4XvbXHpmld$!eXa`mkk_EPce?W|2|HQ|>&sIAHPq$KF~M zGmgMw3_j~!_VudMlic{svM&aPd;HUFC$}$3b*|}&`cm{1``BnI_Y~!pQ~tUr_k$`N z_@VSM4*Wk#d4Sw-(JH?3aNu#G9US^O_y8Q^0B@|jDa}*XP;az2>QFvA3eM0qTxTDL z7>6Akc(mye_H=zig9%IC_^saoiXz5%#X#7&f;N4JHnI8o4U@B*uOSg@*E|5_b%6+RUY;AR}Z>(7g4a*I`4m*l%vWDphi e;1I5#+fYO>&2L<2ybxXN*|XHX_ZnxoasCGaIN7!U diff --git a/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-312.pyc index 55f5521d3aa1c999348d65c1f063a53525b7e570..5124e406689d1ad8f9f12d0d3a48382469107962 100644 GIT binary patch literal 19489 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 literal 19926 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 UGUm>l6=7AB&hpp>Z)BeTA6H9&lmGw# diff --git a/venv/Lib/site-packages/pip/_vendor/packaging/_manylinux.py b/venv/Lib/site-packages/pip/_vendor/packaging/_manylinux.py index 4c379aa..08f651f 100644 --- a/venv/Lib/site-packages/pip/_vendor/packaging/_manylinux.py +++ b/venv/Lib/site-packages/pip/_vendor/packaging/_manylinux.py @@ -1,122 +1,72 @@ +from __future__ import annotations + import collections +import contextlib import functools import os import re -import struct import sys import warnings -from typing import IO, Dict, Iterator, NamedTuple, Optional, Tuple - - -# Python does not provide platform information at sufficient granularity to -# identify the architecture of the running executable in some cases, so we -# determine it dynamically by reading the information from the running -# process. This only applies on Linux, which uses the ELF format. -class _ELFFileHeader: - # https://en.wikipedia.org/wiki/Executable_and_Linkable_Format#File_header - class _InvalidELFFileHeader(ValueError): - """ - An invalid ELF file header was found. - """ - - ELF_MAGIC_NUMBER = 0x7F454C46 - ELFCLASS32 = 1 - ELFCLASS64 = 2 - ELFDATA2LSB = 1 - ELFDATA2MSB = 2 - EM_386 = 3 - EM_S390 = 22 - EM_ARM = 40 - EM_X86_64 = 62 - EF_ARM_ABIMASK = 0xFF000000 - EF_ARM_ABI_VER5 = 0x05000000 - EF_ARM_ABI_FLOAT_HARD = 0x00000400 - - def __init__(self, file: IO[bytes]) -> 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/venv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py b/venv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py index 8ac3059..d2bf30b 100644 --- a/venv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/packaging/markers.py b/venv/Lib/site-packages/pip/_vendor/packaging/markers.py index 540e7a4..7ac7bb6 100644 --- a/venv/Lib/site-packages/pip/_vendor/packaging/markers.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/packaging/requirements.py b/venv/Lib/site-packages/pip/_vendor/packaging/requirements.py index 1eab7dd..4e068c9 100644 --- a/venv/Lib/site-packages/pip/_vendor/packaging/requirements.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/packaging/specifiers.py b/venv/Lib/site-packages/pip/_vendor/packaging/specifiers.py index 0e218a6..f3ac480 100644 --- a/venv/Lib/site-packages/pip/_vendor/packaging/specifiers.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/packaging/tags.py b/venv/Lib/site-packages/pip/_vendor/packaging/tags.py index 9a3d25a..6667d29 100644 --- a/venv/Lib/site-packages/pip/_vendor/packaging/tags.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/packaging/utils.py b/venv/Lib/site-packages/pip/_vendor/packaging/utils.py index bab11b8..d33da5b 100644 --- a/venv/Lib/site-packages/pip/_vendor/packaging/utils.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/packaging/version.py b/venv/Lib/site-packages/pip/_vendor/packaging/version.py index de9a09a..8b0a040 100644 --- a/venv/Lib/site-packages/pip/_vendor/packaging/version.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py b/venv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py
index ad27940..417a537 100644
--- a/venv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-312.pyc
index daef5a5647b51026539d084f0920b89c07a480d1..477cc16f751a8a4abfc210001da3ae5550295351 100644
GIT binary patch
delta 32816
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
L?`?dqmjL{KQnMJB

diff --git a/venv/Lib/site-packages/pip/_vendor/platformdirs/__init__.py b/venv/Lib/site-packages/pip/_vendor/platformdirs/__init__.py
index 5ebf595..d58dd2b 100644
--- a/venv/Lib/site-packages/pip/_vendor/platformdirs/__init__.py
+++ b/venv/Lib/site-packages/pip/_vendor/platformdirs/__init__.py
@@ -1,7 +1,10 @@
 """
-Utilities for determining application-specific dirs. See  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/venv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py b/venv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py
index 6a0d6dd..fa8a677 100644
--- a/venv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/__init__.cpython-312.pyc
index 4644b10f6e36c5399d5bd25e210421b1f89025e1..ec9cd7b6a5160ce0be3b94f109ee3eeed7750149 100644
GIT binary patch
literal 19816
zcmeHOYitzP6`p;+{aWt>FlKn#>&M#Rkpzp7I2Z^m7z!kmjib%5Gd4qZcUE_1A*QCq
zQ6v&oRnlK+|MaCwElU4Xs+9iize?%DhE#R8Axe})RsK13+Di0Cd(NH5J~F!=$ePr(
z4SVjLnRCxQ=gxP}eVjXQheCb^{yzN94<|FHF@l=}p^PsZ
z%C)3gs60QEZ%wsAevl8m>`b-U8KLb>O`lY|(4Ok>G5S9~spqOweuxjg>`H~pck6Nv
z^C95uw7@yUw*Y6v0_QN_3Y^gj&WFnR${fF&Zv)O)`5s@NvmH3&6`b{L?*PsX6`b{D
zhJkYX1
z;M{J3b05DMICog!+{9e-0HnJh9fY(8(j=t4kPbnbfOOcBDV8e~vSNl)L@7Tg7le#BDP~w+
zBy!U4KO+e2fs2Y#kVl4wrbOjp@j@~q<%SAbP60VNWUIP3sEg;stjuzGo-NAUlmMbW
zK`)Z9l>%HoFDbM-c^s}oXV0HHoIdo_;X_|NHh%OIo66OCN~>WEY8ZX;5Ee|QFAGEl
zHPdOhY%gCb#X?q~H=U}daj)Eo;T5a_~X4)
z()nfheFndu@{caVAJF;b$TFNkos-ySm@^F65X$;F~4Uw!Is7MaZb$h(iOSn<~agS;FjwImpOR`GR~*-;)|u===j*_
zlgGx=W20wBueyeKPT|ToPoF$__Nr${o|Y9MS8|hSU7CHJY*hmRclI*4dZ1JZ~j
z^65z_%L@c+998cmLL~ERmdF&FHJp~;uf4M>3ngJvNMMxA#!clUc7UW`9Dc_S3!Ys?)eP(QA;;5)R
zRlLBSBGM&6k>m-vSdfS!On_yVCyt93CS>RXg9R@00(3xm0yG`ctgh;@L+Ld50VSPI
z7N$$Fv@9rTy;0K8D(Os?lV!3MDvrTVo(6KAdDr8=F*7^!`juOr?)SV$-t`4v>w2~8
zd+}Sot?zlC{Mh@%M;_me>DlSmyKj5gA055r>Hn4eE#EJFzfRsBKK9%5w}zj2HxPPl
z|Ev37Kle^x^G`c|w&BMce*Wk?TlX%6H@tGdP)QsX@Me6mIwS5z)aq%2RpwkA>Kt&ypD
zLQSG}WkH_CStE@|91I3inl$aof;5e@Mw*b9i$q8ZFN(4vYci|uS&&@CZ^$QtQY3kh
ziQWOnC?TUrWSWI>jb{~!RW1rJ-Ux)Y{!LfOqrH%l4>D>ymONS$lsuaDrBGF6341A6
z`CdyQl$gdEu|JR<05ll^g?M2J3pvuSlZPO))C1%?^I10&j4!ms7CJT|h5ym*p9S1O
z_rHRSr*k&97;?Kh$u{6!0YJaA#sQrJw<#82E^yC~HcA?xQ(Zz8Mji;L<%=8vSYMc?
zkd`$}lbwjQT}TjTC7+=%Nx*f&PWte62%Uc!v`M&E3)*40N01!Dho+zf=srNu-d^LN
zU3FeKBjqQ>spb4I^_V&?Td6Zu3)Xd~yAhd4IQUs{r_osn-Dz~C+-YfzBh&CPtI3^y
z4xMF(s?QTtr%KQ}8UUq^vjU)Iu5%v(6ba6Tt+>vW2I#Fd4p6B8YZxhi&+ydBJ@~Oc
z!)0Kuy6gP(iYW~HpJy)h)X0lF*AZ>g_cBX9dN5|b}7Rq@v<(mYI3PM
zLRzlw-12dR7?R(tG~nje$K=&DCTFGP*D{s!{3Mkg-sD>pjzt@t{do3^XTk@B{glqu$fydpQ4dFbA|L*4e$OQ4N6
zRp+ekc^v{h2$E0Xw}d<0*O`w3v2P#zb6{XTFfivFSTQ56`aXaarUA$%+l?N?&C+v*0*dfCR!~H5Mf11Bp3jqL~)-l`Y5>Wi`NA
zXY*Kp3F>GrgqX6ips)}I&T7Zj;r0Y+_V7gqVrZ1@`5
zfCNs4)Vzbf`9R;Cvrn}F7ZduQ2Qptg;`B>!usp3y7
zN%3d4G(8J|B1qua5wiqA_vL~ov3YkCN6FYqfpe{IME@Uvv%J@bK2Y1|tHLH-oGypW
zbBIkOJ%CN}G+xokLGvBr@1TO3pz(SL+QNRwmm7k{5TkkY*<@i#L
G=_X0!G+{;
zgxX5(gsk<`4zN
z`5_oU_TbeD%~O956|CiXYW3Pkn|)fCIB4a*gf2rP%?+G%<*GmP^KSef)z$TCQwTI9e?y=R;8hdjKot=bUJt3U9BZn+-ao?X_Px%os$LVl5>Zbi{{gM5
z<3NM+fx$WFU^A^qR74>pJql;Z20Z{ro4>|}EZTs?32`=Z39p*i^1Wr9^?+LAW>*8B
zIw(sChOW$)>V(9HPlv(!)mOiNWc#Q36ePK`xQgq=5G+=__sds){l6u
zqKKI(!swf_bO*1+TUNN$i9#aSMep_==l;m_*$81kVtZ+R7hri}^_@
zou=nN=`IF6TTeG+$T0HLz3OwAqt)!k99@OtM_sI*K_u
z<rVo$Jv99CWqf}QT%5*_^w(>JU_(uJ?
zgll|!{K%0+kRIE<>z5V6&amTBUZ5Xr-Q85a0r#~})So@VWo6+x`ZX81hMM61Q^|Qj
zlCt!eH~ALcoWYw85THp{S?PCR-^AxVNNDjP%+WFlBZsBQbs$v5v$~4)g*<8$H4|c|
z>Zk%$W9v&oYfRPgp*qWzu4{~?(siw%r8O&Pes9T>PQ%PRoi6#)>B%CV)B;30Q28z-
zF(4&3ymt6bmN@ak0bc;CaHehVK`t+nZ{Sl8_LQu6fuMNeN3s%VS86Bca%(K*xgx!&4oKf`?OSv~y69$F;)@>4d6|}uMIYw;OlO>O
zF9sR6Zz+WLc9*3^H(8R_)@ezap<7hbEvo4jHFS#_xNcw@Vj7GgxV_ID?t*)3+SInp@X4Dlk>WZ1RYICH0fmZcnPpNw2Mo(${
zj#M<(;OFzwjGl5ImQra|?PloKSemL^&0F}qGy~g>`&DHHb
zd?~fG6MIS$dj%!5&-5GJWx%wj#I>Fh*Lq6a=qYidr^Jn(633oG>x!H9l>3(U_u*Xu
K`>cn~L;nl*iivsv

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

diff --git a/venv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/android.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/android.cpython-312.pyc
index 60473854f81261ae1fd73de5ac4f376d8156090e..9a15d66a38931d7e0405d9507cafe3893f13e16d 100644
GIT binary patch
delta 1494
zcmZ{jQD|Fb6vw}FZ*r5|G&i@m$r{%sy-gEG#@3D&w$i#`O8L8V~CXb;2vyUeep%V@21eZj(&u5
z&-tBm{^!eg@3)frGp*e6`DDV@>U$p)A@YTC6BZ5vA=imPrlCNlg#t{AhNI9{5EdPu
z@=CU*ofZ*oM6!s(MqCzg+KAgCl8tyQ;<6FhSm49lHsrO6JT}r|5!pt37V+AMVv!ab
z@ms`aBdSFd8)-EhNjBbZLz-2j+DMy4T5Tk7K}!T0uHkZlR!W6@6jy|)U9zmRmCm0w
zOnu%o^h!~$&Kj5$5Bc=m>jpJTl`=2E=f!S$Gd`Nzk6(#Nr`3udNtOB;M;|~te&}3<
zJ@rK?5732wxc-6!-gaLG17|$FupgIO`tg=$%+tf(4h=Aa>+%@pc&?
z_W(!gRbLmtF}$Yy=SlP0eqMW}bpUVsKZ6V|s{gqPgVd%g;e=K`HCS4(FM
zE}2UJ9pz<@4L3_wBWtVN8ooVqj`f?ozd1ax;*b68k1e}nG|1rb8$v^Bo&!}_oCxAG
zfwz?A)Mpu>!)$}!1cDmRnrU_bi)3ApobELhhk{{r1poF4&I1ocA}MPE^YDBy?2TLT
zI*a3VaaTlOuOu3pVfO9N5S*`n8~OpH7rFX4UfF#_n&55*f7#umO>y@nW)cpX;r=VA
zbsUDv_2)V+g16bj@vFGJC+=-F@_6QI_=)z%n|aE>gW-MN_qqETH?x@UT*BT+-y?E!
zk=US3jukevkyK_hIq^c~WcEZVIWd_T9j7~uSc)XzCT>LLfXn}@+IGsMYMuOR!UbJ9
zv~7m6HDe^1O7E!uoxT^o#s_*+e+i?}-bc27D%y2;o3wvRIz2g_O75urW%Nn-5${Il
zo}OiUO$ao_w=A1gs=uipuapgXjPn5HSFIsuv&DIKag1!1vO7iSK5kBO^D@5EJq5$~
zTX$%v#sI%A=1
z>BPhlvrZ(ASag!c5vwxDikUfN(}OG=N!N*$BX*tGI3nvLog)sN*g4|ViOdm~V)WDU
z4i34GI79B4wDRtRn(Rol1o4O1I1i+mMTVJpsl>*`8A(-odev@Krsq%wlFVak#usl@H;c3U6+1Pld^#3G
z!n|lQndfBfNu~qrW|L>ZAV~7ONS&6Ml`BFFi+!zBFZjx!Q+wu{1S!hW)Zpdptx_$s
zF?^f7-d)dZ1C@|bjWHj`{G3uauI^-Ja%(nx@$9n(~Tz_5ai?z6B%xBIj9VTbU%NvcY~XobA>71YdCTfd
zU~w?Kt%V##hrjWF&}
zcVK_MPimwGwFyV_o5DMpWy7V9&v)~dL&-#Mm$FUmql`|Ekea44X8?d#f;@|)Ak(oI
Sz;inJSz!D8fQXd^V}Ae+Z4V6q

diff --git a/venv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/api.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/api.cpython-312.pyc
index 1d46cb8581b8d95bb45d28214679c4487ca0448c..26f71affbe65ba66bd5da2e896aaa883a2521719 100644
GIT binary patch
literal 12918
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

delta 1122
zcmZ|OPe>F|90&0Co7tJ!|D&_3&i->}HMK?jcZf**Q@Qj9)HRe2dq_uTbQe~4nOzIL
znB>8$zC$3C9lC_KJXO#!5TPuIav>?i`-&cdF3o#d%^?T&%i}Y@-+RA(Ft2-lHhZ@{
z9w#!Ntv73v_q;1!84@c^wM{mS%W~6viU-7?n@HoAkS6H-21{xYN(q`U1u6SVF}dId
zgdQUur9eX|MuQZq+q6oJS+Z@M7NZnLg|!Gz#byzK3TF{J72YBaDuP9v`T{x3ZXp*f
za#+Mo#c2@_6_-W4RNNL3sdy|>LB(s4O5GMQj~6W@%~iyu5;veuB!|^K%rIR+
z%{?e6#k8(W&1N)pWT4)y;?7`ZME(YRt7=%jdJ13ALEX%_zgO`FzeOz5v6C+rxhR%TXV#
zG50D|oAD5pc~s&5BDQ}N+jlyWyW-G}eF)FEy6`9GBM9TWuBT8%`yB2jSIlfN0wg5-
zo(tf?ppIX;pF^WLVLe{-gwLCD1i$l+_~ymG6ZWYSX}w_h>DHZ<4bkRvM!LQ$_U+jF
z=tw>(0X4K^U*@qPMP2Rx87SymgG*$f&96Q;Kqo%*e})Fy_Mxi9(MwvI%)l{u98Xmz
z&)#iUH$!4o4&ut1muJ-K;_-e>3~sN=TW7Q{H^3mNstpA2KIhmR47LCa)BnF75~aa7
zQ{oN1IBU$5*h0~W`|y)+cXt&zR3;H35g`#JL2tC4tQtwgNsy~BT1d2!=)kc^KysMN
zLbLg0EukZZ=j`PQ+#d;v40i{PS;TwG3|ZpkNCdA$E}EYB=ZRB4h|Gu5r+Q>or@@fO
z{(>2ChjAG{tE~%`ST&z9xIbPJMn~0bc68LZf`8P?S9{DC<_xINYDSp_fIZ~?hUyNG
e_Yf&3`~W~2mXjxlF3RH!;@oAHaWRVmJ?uBF#{Y}}

diff --git a/venv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/unix.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/unix.cpython-312.pyc
index d9b7b0b8c43c4927a30c64ada442ae5db3f7d847..35c40b1fae3d1ebbc7339986c51cbfd47aa77552 100644
GIT binary patch
delta 5157
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

delta 172
zcmX@XvWltxG%qg~0}!0tJu7VikbVr}zyK4J@mU1On9h*GP{A0*5XG3n2&9>!m@Any
znX6ch^(^!ZHJM*B1J%6b01=Ep!cUXs7I%DnS!z*nW`16L{4I7U^Ohh&w4`+6ZIQ`^
ijG5v*KrJ9`#WFzR12ZEd;|DedNrlOVOu{T6_W=OQDJL}m

diff --git a/venv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/windows.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/platformdirs/__pycache__/windows.cpython-312.pyc
index 2d010658168f801e9061d3b2742c637ecce0633b..dcfa70b957f209d1b975939d21785d45a4e0d46e 100644
GIT binary patch
delta 2583
zcmai#Z)_Y#6~Je9_xASI_y36HF7kja{g(MRym^IzH$A
zxU+k8lAf_!{2`TE+GG#~5hzml(z*qO6RLnBQ3(kFRpmCIx)(tX_NC`Lb
z6DN!wcy__)h0zV8j|7MZM!x{_b(x5-cvmr>*?~CluW}h$9fHFEQP1K;@bcypc!+0xFd
zofd*c?huznV7WWQZ4p@b4)It7Qm{k37V$O^pGABP#BUKlkimL>ATbsSG#CXf5^Nx$
z3u3gnV*f@aPYMf0x{BEkg}zzs=&WhZ8%N^tte&R%{#<677L3A-**{&##r1q&(TFe9
zr||LKfw(cNXS4Bh`NBeerjR8%&5)r~vR_p-Xs6QWbVDl|x>lIc%voJarRV4K>70H=
z>fE&@4y9riP8ZGD0_D>{$zBzm?6=}!mzJW1bS{%WTUYe4gVN!EmeTV^k?KkPe8w=1
z?KwY^eC1cArv=tl4=7f06lJ8~DrR4_&{)c%=N2=Mt93AYsNK
z*6xh4if1=l_PvZJ*@v#y@`(Q&##80%fjq`%SUSABJQ(W4_-r{H9>h3nk=L6;7(Z5i
zr=<_$$FH=uvbR(RyB41E-G7AYW|8KPXhb*8nT2`wR;Z16+T=r8DiwKXV&wD#r^kupchn$pF*?d^LX
z0tIb_?v84hR4Zv?g}hEDIpwNon4M~W%1$5TV1m8b-r-6@8CXHL1;wURgXNFg_uwJH
z_BC7+k?gJtT&yY}ek91Yo-GJc)oU@q7O~iEFpSU^?p0+6`-0`6j*wuRgXibU4{J41
zK6OGjwKN;=`sH4o$ARe#3C~D8E$!jy%as}dlJOg;BQ=o4ie_Sa^U4YUWK7<;@ZF9
z^)K+cD`e3k<`s?Dc;zJuaS)X>5$9D0d#ocOx=M(B+R<@z&JI)WYQ(+DR{?ENG97gZ
zp%NyZRiXa0Xe-&~RQ5(kfYIKdLnsMEAh;y4=Xyh5@~)tgG>o>Z(zY*pq=f&^+hp+S
zwY>hPHz-PTL3Xey5RxIDt&ai~O7fyqLd3@gV_%4X#ddU`jl{nlj%&Hy|rze>8~?TKUf*SkAujrJ~@5q
zz_$z45VCozVWb4s?5*rYEgbxt>U~%3ep~JSiFrefEg#!(1)pcr@d3Qfz85bpeFt9j
z0&?*4f#7@~b1SW|xrhkcX``|US*W*(ZEI-}o7T6U^9j_6OnJ)$bs;KZG=-iCFQD_{
z6k5P{X&o4uPOxTk_cWj6TVUlQYOklvKASeurb#K!N2O^rH(#LU2&Dx|FK}Ca;3>a%
zQNfyEQG>hD*dOlMy>tzvf5YGSI&^R$;8yqDR6?5yat5A1{Qb}WrKxKp5LE1%I4NvboN-w9eJ4PG0eoE>@Kad8{HAh_h
z8IFs;@O(uQ-w>BD3{hOM=hEkm%tbvaS-04#O$}A*e<+U@R>bSr#o)1YHk&?^)gO5T
zj?Fh?8tidG?!wLp?k_^>Slni)WJZyih+k
zvnP|_AErOb_71c>%r7Rt-$oWXSRlslA@>Jp-}}gM6REe*o?A%!0BL_0y|<*EO}T_|
pFc`ZC%0Qg@Z7rb`G~&ZqNg6;zPK?mDP|lA2f;+j$XO+!U~o57XA00J`=6)m$wkf^6{B6RWZ*C!jm?-J5c0uz)F
z2u_H)1k(vq(()(>L?qHQCPCtuk`uCRm#gfGO_VC)w28BdxNPF8BC1U$)hbkDBZzcm
z=~|mW%qzrg6Nr9=cx(cBSRr1UKt@)GW)rQ7_-x{fRUyBP{8c1yPK<_1%8_)A7-!8?
zNMP55?nyNa&$dy^%5UlEF$?*;L9JLeJxmSL7_nl*Mz)9OBdJ2hilxl_*i+_knruIF
za;u)}E|^>UP*GidoN@1*#|Yv9xKKEH4d6JWO`aTUY#1$_co+7*p;FI8szqQNT|yPwiv8ow?j|
zuBV~AXbc3KtZOW~JfC1ZRJ`K7fbjtq^*zEb7F+%AVEj_?n?MfB1RTv47W35?2SROF
zPOtV0bzv;$R{O;@A&kx9t@>{48UsvsgDCE7yovDy!_9l2j0z>0>Q;f~N}_4es7y8P
zc7Tfp5RX-$;qmZ3Bd62-%cf|Mk#%pe^14R%CaC@?v>>PsXSu#u-_nBJvLmu6BH6Pb
zfL6?fdj*FMBi}22*}5o7dxmt2O}GEB{sgcnrYUGle$~RX4kUefSxgt{#vuXUVArG9
z810zB$Jn~g!}4)%PqMMj#0I|0sAA7h@|mN0CX*a7GDN3Ie!7(BiCXMo=Putks8``N
zr$L-YWsU9Y`j%aexbP$Pb>uj9unB)tFR7j38-Zs+v|JSpAxm1;h*$Zh^3prpS&7NpSEGUYngY2Ld
z2syxG>DxtxamR!>j)=x4VuM@3V|n7$miU%8b_kaGKaWEw>SqhFwM^@Yu!W8_>~K$@
zejhysbEFXjSd!1e70qNQ50Jgla~0obvEH6~URzNQtt1`vl00mk%j+g9^jh6=CG|DK
zW}0M@!$uBjg(tlvo-B;ecey5k)@RC~vZnaPou7en8(y;v0?xsM8k%Oqt+OrbXB!%4
zo7T;)ZREek<^`WCAV2gYMSXMlLdV-iIe;8mImq6RHwFJvwcpkDU)1(1)~{;U`DfhAfr++}AP5
zH*M!2s+5$`l$o+DN}JeTEPt!F7UDCOl1rOd5WrCbUo^XcI;$y2(O
zgzPTWCcO+^JbZHy#CbHQcs_Xbqp{zV@SHbNcgGni3l2xuU1#Wl6KP#{oSlyzDD3bx|3vP)$aNQ~^QdJWh3}*AJyDyNA`fH>ptKlU$nXjofpZ@>+UTh`;y;%@B3UFABqc~kqpv+V9d

diff --git a/venv/Lib/site-packages/pip/_vendor/platformdirs/android.py b/venv/Lib/site-packages/pip/_vendor/platformdirs/android.py
index 76527dd..fefafd3 100644
--- a/venv/Lib/site-packages/pip/_vendor/platformdirs/android.py
+++ b/venv/Lib/site-packages/pip/_vendor/platformdirs/android.py
@@ -1,4 +1,5 @@
 """Android."""
+
 from __future__ import annotations
 
 import os
@@ -12,10 +13,11 @@
 
 class Android(PlatformDirsABC):
     """
-    Follows the guidance `from here `_. 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/venv/Lib/site-packages/pip/_vendor/platformdirs/api.py b/venv/Lib/site-packages/pip/_vendor/platformdirs/api.py
index d64ebb9..c50caa6 100644
--- a/venv/Lib/site-packages/pip/_vendor/platformdirs/api.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/platformdirs/macos.py b/venv/Lib/site-packages/pip/_vendor/platformdirs/macos.py
index a753e2a..eb1ba5d 100644
--- a/venv/Lib/site-packages/pip/_vendor/platformdirs/macos.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/platformdirs/unix.py b/venv/Lib/site-packages/pip/_vendor/platformdirs/unix.py
index 468b0ab..9500ade 100644
--- a/venv/Lib/site-packages/pip/_vendor/platformdirs/unix.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/platformdirs/version.py b/venv/Lib/site-packages/pip/_vendor/platformdirs/version.py
index dc8c44c..c418cd0 100644
--- a/venv/Lib/site-packages/pip/_vendor/platformdirs/version.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/platformdirs/windows.py b/venv/Lib/site-packages/pip/_vendor/platformdirs/windows.py
index b52c9c6..d7bc960 100644
--- a/venv/Lib/site-packages/pip/_vendor/platformdirs/windows.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/__init__.py b/venv/Lib/site-packages/pip/_vendor/pygments/__init__.py
index 39c84aa..5b8a3f9 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/__init__.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/__init__.cpython-312.pyc
index 6a16d1432b170025da83515b0275d83f07152987..f498a8bd670ca6cfb97d4d8e59887c06107b1f30 100644
GIT binary patch
delta 29
jcmbOtJw=-PG%qg~0}wp!owt#D1`D&fp3&xIEblk~c=ZUZ

delta 29
kcmbOtJw=-PG%qg~0}!0tJ!>QP3>IcnJ;Tk*Sl)2}0C~9xxc~qF

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/__main__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/__main__.cpython-312.pyc
index 9b757160a394eef4e81394b72457abf93f3bc46b..de33cd2cce2e2d54bcd6aba751188d9a793a2cc0 100644
GIT binary patch
delta 20
acmcb_dWn_$G%qg~0}wp!owt$uI1>OrZU#I6

delta 20
acmcb_dWn_$G%qg~0}!0tJ!>QPaV7vixCTrB

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/cmdline.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/cmdline.cpython-312.pyc
index f9b63b3fc0c04fb9570ff41d3a34c514e6ee5fa7..3f2029d85691666584284cc74954975284af8130 100644
GIT binary patch
delta 1025
zcmXw%ZD?Cn7{||ZPfnWK-Xx8=No;eoF758}*2KOnowapYrdanu=oq4NYQ1?`nl#zi
zO%;(y{op5IFgU0bWAyFd
z6@TF!>IggGJ-Qow3O=BZhP>7f`53+`^6WL54F%vMdMPvvpU@vdewe2VVTJw|
z8imgob<@+~3AXco*z3K%mtwhtnecUCuhKg!2MaftGjKoYiaZ39^kT$ApO47!hH)`+
z3g9Rm9q2RG`fUI)`cL#-c#S)Zk7I%WSLpnJ%EHOP!%82T{bK)=Lr8Z6I)f@bx`Umu
zcdy8x3+9dFphDnT?`Yr^A%cK-kyrmM(QTt3U-WpeCe0bYO7;md$
zQO4UbrFhhiTXw>VmPafe!mU2w8gLcIaVsH~4&WUNl>BJN2b>RJ&VE;E#5n%MNq{PS
zYvLJLq4kNM;w$V&>oZ)&xD0Tq?h9d0w`^h6o9J($jhuizQ`M+FIni$3;kI2PcKTB@
z>>78@)V{g7x0_+v@7C)^XKC^vlH)K5(-}UO+V$mD}YK4DKh(d%~d=@RK-coC?-gf
z50n>sE3af2K$TZF^}yQ$fNBH9kH{a&0r-q01ETObZAe$mHS-100)y}snG3|=Yw~?y
z0M3!y5sBbn9L^i$C5MA!M&*;B2p7nFun#WLI)C~khibm6qt;*CI?xx|1Fw;}u!kHE
zx!@g2`svUxz&?_Q$olG#4Pc1;v-?AMOP>q(G4L@t7x8c27U;XYH4j2hp=vLnBmZx`
zC+gnx?b1upzfEvdPwzhqG2aR8L^yRSH<_KPhBH&;sj6C0!`h@aqp4+WI@j!aTx?pl
ztNM;-E8uc&hpGR}1**@=I$0hUgyVuw;)eYzyAEEcy@>Bn&ej9
z%#Em^2GNf@9chGa#gmYZqT3^UMn?5+KC7U*$B`9rU9lMa6Bcq_^z$H}kD*^gXTiq&
z>PUhHsNv$Z7;5T=&o!l`%#Nc?k^|Mg4?DJvJ1O_YH-%BCh)=t
z7`lkKbQmvkVmg2q11#kzm+8lg!%{}XOCoFVl5EfJ#7ldntP{7Ltif%O&HB6A{dBOl
z!sR@;9hGuDxYNTL-0^bx2=2)I#3=4W_*{bNi~!|?Yr@6ecQCU?aNh|uaQP^Y^2UJ&
zRw*CC4?-;En5)o@m#sk6#uY}{Wsg*dv&(VT;1%Gs2wt&DS_rR%SjsVbQNgQ>RFv_m
z%u){7OZ|9tSSpElO=JyTleuyaUK^6i&j@&3V2xni&6S_T>jOa5?=BDH^#oUu@Iy0H
zeCVMFlqF2r=dL`hKk?EyK$GOh4#Pcib?k?I_l#GrmZ&^OB|@dSEi7Yv0gDm6i~eM~
z*cV{S)YPxMJZ3dNqP7ja`;9Nnu%TZ*k_Yo&H1$aL9s35lHz+?&wBEEcy)7frv?Z(g
zla<`$%t5s}ovT)x#FRP+4RR=T6uu)DQy#cVuBFDoqW2u1H<|CyCM~_5wKHb=DGmSf
LgaSU|$e;fgLxMgp

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/console.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/console.cpython-312.pyc
index fdb0b05d49b3cbccb4be6d7b3b5d40ee8c5e0aa8..0eca057e01591c0b00feaa1e5047246c1a6fa4d3 100644
GIT binary patch
delta 20
acmdlcvQ32hG%qg~0}wp!owt!&n+pIuG6jwR

delta 20
acmdlcvQ32hG%qg~0}!0tJ!>PkHWvUqdO(Cl3HP;swM2

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/formatter.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/formatter.cpython-312.pyc
index 03e47b6b7ec1d1bd5e9dc007fc4afbbcadb5e5c2..3e3917769b7e73509179a9088bac764fb2aa0e5d 100644
GIT binary patch
delta 20
acmX@Bd{&wJG%qg~0}wp!owt$ukRSj;?FM)N

delta 20
acmX@Bd{&wJG%qg~0}!0tJ!>QPAwd8`HwK6R

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/lexer.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/lexer.cpython-312.pyc
index 973d6739b6e4d264ba751b07f7b8d023691e0ab8..fb0c76d35618c2011ad523571bc3d2ba7f191dc1 100644
GIT binary patch
delta 7107
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

delta 6967
zcmaJ_33wF8mG0`9o*9j9bc{}rgboIQ03mK{Bo2c>k~s_*Ofnj)8yFokqIzV6BCTYH
z0OGR@a@p~b^=G_cV+hGE_9WS4ozKU9n{{Hx1TRS}cj7F&vA=lZO~8UAj&pqb{%VaR
z^ojH*{Zn1_-m6#dy?XV!-oK!J{eqhEW^%Guq2~uLJ-vVB@fT7~I@zb(Cb2gnm&R&Sl%h
zsJm*R^Qf{nQP&8QbQfW=?j}spy}IWp+ncH<&|BIO)t|^`kgQ-=Y_F$7jjc-jyoZ&D
zS2D6nms2-i0ayvZjC>V=@M@wy&-gm}F&Q|CFCn{-Jtr!%>xu7B_6KX%
zP`~90c6J(J-S3dJd_DE?T7rrB(6g4HC#}KgHh5J~*8{dv=fsn~<*Xw1w(lb~1he{?
z<%}BL(fE{Ltpw|gG1hRf{fKDJwmBsKSc0NEbZ5J>L+f)gMR)bN
zqA784>y^(eRTOacx%)hWtTkO6s?Vr!$7P!A;haGh&4|l#?m>umMey_0c}=`P)qr^My=B@8l1aU`_nin?gV@LLH5-ON-;Pw!;8
zy{?liyjRj@GJEmY)_SN@s!WXY6XPOz)ntYB@qQ>wLT1G|D#u57%HQH3`h2LCo}?$o
z7b@qKz5bM2dX?6K$;-9dJe_3B63=bPDM+Y-@4smbxB&@@VG2~D0^)JCDn
z^GOc&>6AwjJ+~!8Twm*kNtD)d(OH=3Bx*l2?;jUvYUF_Ao@4~d3FQRauj;8sJ$+tP
z>GfV1liHWqtD3$j0#`o0i6n4d{B7cQP`NM`wZxIQLz%5av6tK(Bs-muk@(N-cK3*C5uC)$7fkAV6mvh9PmgQfd(vx8RfRvG`uEuhB~VP4^V!HaK25X%v#=WxkxdiCCclF
zfNuvNmsuKdhB~=SZZeyBjqc81SdRwpH)W!;JS4_E9Eu*~(3T_n_>(3yv%FnlJFOTx
zzZVo(w#5v~ts5;7-Ow$^{gKKJsh;I9!Y%wh5V&Y!BiJD`cXKl>ZS0}-T`DV1d5vhy
z4=6$WaX`6QATo-o`?d6Y*n63auO}(_vrfBzURFJ-IMQbhH=bViWX^~$|B3$L{xjxJ
ze3c_5rKIsm_q#cT*WJW*-K%8gpI$SPSNv?%
zQ&s0O&l%^U=kl-QEjhhzWM;{;ZBMnGoBhuf=PNGGy)yTX|D3z&Ro_VZ+{HH>Y}S&~
z8?X9i4m+><^2NTQABg1gIgU?m?iBNjD+_W+>DQQRW3}>nb;713$Lp(-Hn|<&cWcxZ
zmuj+OTg#6z-#Vh=(y53O91ZB$Eq+r`yqM97O&pH2>KRIE$z@Nm%(H%Wmp@&e4tz1F
zYXD0C3q;+Vwe@@h+M5Au0oVk*1F#!Ffjs%_#0e*lxkc14_YmOhT%>uf9~3{Ev#?~;
zS)i4TuGX~mY&6A1&9qc4=|;(&TK0`vH9;%k6|oimM3oN44V4Q#nA)%Lb)vVjGOHF6
z$AUG!v<>3Bm4(bFtje`?>J-i!W=lRtWVUL(Xf*}1#(yv-tw5zk-;PdS_M@zeDIfMLwX{yu{cP&PH(pn-N_lLrUP6~&O!-2qN
z@pN?os}OJdGR2$KDgBTrW6-bKt{kS0TjU^ydeSG!357$^K%jAA;a5FLV+(gpyKrb?
z`*h0chZJ%*AEMz6qIq$i?av`phT^Hk-($N(pvJcndlI=Y$fNewM6RRYviGLcE-SFr
zG`jRiV=&rskXCAIxLaJT$)%;fQM2L>X*kB8AlCEtLM;a@HrZfL(qPYwTSUoO?-R94
zvPjOZCHibB$06m&O~JoNO#EqraZ%#EC3)<#;*%vMay>1ocrKhNYL@PqF%9jrOJ}m6
zczNk;lHai`SNv&dan6{ol6rC!ikf9bx%**ulv)&TX_-%WhrK8IE_(_nayyolW`k9F
zli$Ml{Ic@?5E$JyV`};dignP+xxCYQ4VLAw34aD~2JjDnvw$g{d<=bn?U<&F8e{uv
z)T3$zH#|%A3Js)Ap*b0a&>i*vWBes`6h5mJMKp7
z3_x1+Jhl8@{#A6KP~u-Bu+;W$i56MKfErAt91qJE3v=Sy~+CJTyFkt
z5Y_^2J4fP_Irw)#{;z;Z)6lEs3Phrm-}p-y`!0c*NI;uSJ_9ImFamRmU)JTaZ;Igh
z$9Kvg(%`*LyXJAWhp2=&1=4&1%7-tb4T1Kw5FjU!sS`Cutt~kZ1Ax4h@<-ykf0Zn)@^Hic>Vbm$ImtYDO|zO$)tnJgj-iI#s4@E-)GlK?iHl(bR~
zN4Rc|YxxtATwlcS`Po-H&gXaXbjY|>+AW(K!*v8b3AQ}?;5
zK0C|xLc-LLmy-f6iG7>%?af<=u
zkGo#{wXvH0S}bZ>Mm0>R=|Pn}FFx8@==v#?8xbknYSN^#`=E{^6pr#Cv3*;)2LVcD
z$Z0XK?QT{oE^k|@UT3kS?K>FBY2K0JWDklXyVnJtC%XStL7c^{C%;pGmwEb{NoZ~ielg9LQTfi?2~0$c@v-E!GW=0C!V
zGfFYee}SfhlWiTeW%(6)y=A+OhZ}Sf=}md!;=LNnh<)qczo@G|qCWmA0Hd@+<)jO!
zZ6(O5Xa;j){>gQt`0ag5*&0!{Zy$y0OOf2zm-fBwD2Bi$4pUJAbO!<*JQ4_4o%>sAulm*(f?O~f>(GAx*(7O0lJxytHse^Iol5F=B-yV
z4r1x?ZAaM3OO{3>8l-({Gk1&o^+Wq64$s7C56{b(TKZH*fQ*U>oiM@F-S!4J0KX6m
z40|*1H{@>nf^o?ieh0&_ZWFh|nwpqDB!pY-Ldy=Q}|8Edqa-DI))~Mv02#V627`EoTkJ5k#A~e?1<%s^2q<}xbi^n#
z3ThdHe?aSh#G!%g#7R|?cywT6YAJ>uio=@NhXa3duVmGO=NTw<}0_~Gk=f8oJsivXIY=BDOp<`Rv
zN%8Kn&-Ejq{0a6BF9e4yBgX3rj;$sSBD$YCVp{HwV7D3SF>o4U$7uD9<8ywlLr+h1q&}~yFd|LrolIojEM&q=fqwp6iW9;3{|XKt=Kufz

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/modeline.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/modeline.cpython-312.pyc
index c797a0193b34f30dce3e315796b51b0d9ad6633a..7304e0b859366cfbd032dcf0d3cd75aa7440323a 100644
GIT binary patch
delta 20
acmbQjGlhryG%qg~0}wp!owt#jlMMhhz6BHj

delta 20
acmbQjGlhryG%qg~0}!0tJ!>O3CmR4Z2n8en

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/plugin.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/plugin.cpython-312.pyc
index 6aa31b47c6c21cf56c26793edb166136d19fa02c..ec00702c7cd8ef932ace6ace1ff339011d14cf2e 100644
GIT binary patch
delta 20
acmdlXwL^;gG%qg~0}wp!owt!&mlps%T?L~6

delta 20
acmdlXwL^;gG%qg~0}!0tJ!>PkE-wH*rvQPEq(w-Wd_Co

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/scanner.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/scanner.cpython-312.pyc
index 5d12f621b73f4fa9152b4c54ffd2c9dedb43d228..4962ae66001bd30ff2120e3a46815236045e8958 100644
GIT binary patch
delta 20
acmeBB?NH@D&CAQh00fVF=WXP!6#@V_ZUwFY

delta 20
acmeBB?NH@D&CAQh00bv@&)UdcD+B;IxCOod

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/sphinxext.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/sphinxext.cpython-312.pyc
index bbe2cfc2c1e7992571c4f111badeefcee13ccaf5..9fff03e7f0d5b4dda5dc40ae9649f9913f716e04 100644
GIT binary patch
delta 2181
zcmZuxT})F~96z_;y|m?{w*~s;Z2_Tt4$z^X(`B#>MW=2v(~We6dx74Sw%%S4>b=1&
z%VsuAV8?7IqWH#!SyrF$^Qc7(g4--d@8e=&Es9SCDq28LIyoLhqBiVo|KJm7^-jlR`_S1qRWiIm98^GE6NS
z3NocgMnV~$t#RTbG@~yP-1t$A&m)1Ry5u6+qPb9PvJKxbGHlu*`85J(k}Vk%Ld#S^
zLZJewTCq!8G?HwWSnaG?6H8?~E-^9qxRD0(zbv@&BU+TG!3OhE=iY4O#bXIRjctA}-r=t=cZ(s-qv}MI;5vo{|Neto1tY3e
zDwQ`6CKD1^rq%L9646mUZvcaN(`b_8l7k}od6Ga!h+|UXw42-tsk1D;Z
zbl$D)uQIQ!F+EwPXN~F0GJS;dNKd(Zxj-ZAO}UmX*muoP4?Nz>4d)w{
zPR=!~dOBvz_sRpmda81s<|TP4alJ3+t)6RG*He|XPxLx(-8#}ux$4#}h^d&PzU;^a
zYZjwd%9l#7cxLwH82{a1cb4g%>4jre*Y$nZcioWg1|a|%Dz%_Z;bd^EL522=@~Rn+o%(
z`cT7bg{RGU(k6t@)xJbM#5ZfdtyI-6gDqPma$+nRhXEyiC-IrO+s2(n-{Wz7JiK6B
zCX_$%vvA0y26G8l*AI9;1;d{KTmV=EumCLM#d<%rf`6*-DLmSY=b

delta 1349
zcmZvbTWlLe6ozNkd-1L>ZECwoZ0F**j@j4^q@bz|AV6)A+NOn6P!*ME8yLs6>oMk$CANFGVH1Gsk91i#n1&pEGmLKj)m?
zy*{yWHhLoxv4~ik->*#FOnw`k-rL($3Hg*T%9I+Jraq;lOnjw6{DAnWa4UOgbeT?^
zA>>7c5MT3kt~1&#G^caI2bv
zx)qD)GS|0w07i20C^yPP23GrEJRMh<0SmcAx6Xptq|A7gHWW&j***>E%z~@Aj22?y
zH3hEaQi%wQN}+pWM|8I9eoEY$(xkfR#o+2I;*Mpylz|az@1P&LtF6#|+X}VY%Kz6^
zh=;h!jmJdcLg;ywc$yrCXn1aS9R5^;V{G?ZD7;VP8jZ^
zxcLgKlIt)h2Om
z;kt(r6-2u;w4Ov%;n%@~hu%i>9O4DU3?hc;N6aGT5OqWY;UVVXk^HdTO3tG1ATA(Y
zL%fb?A{G#D!eah$`rZ0w{s)Ct;GH3xF2XlMT^G1G-L@P@jAFi4a-8;s|Gx_*aJ<{*
z)5pi2J9g&iGe_KaaTCXF>+PW~;zp~M5wx0!1$dxvklp~N@I`kk;RCU|9d?}h{A6ur
zavE=}!$9#jEvuz(pMag>s=jVRosS~gMml1!Q}y;K!f|_
c1>${-Et~ZvPB8K-GOA6;{Kf#JiY$OS0R~PZZ2$lO

delta 84
zcmdmJ(q_VUnwOW00SHd+o|RT8v61huD5K6~9x+{(N)AoV$*y9KEN*_9+>r5V*GWPW1+QbiU(V*m%77nuM6

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/token.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/token.cpython-312.pyc
index 17f09560005464fb7d96c2aae9b1aca6fa71285a..14261301e6a639295f2fcb3441338a702e24f402 100644
GIT binary patch
delta 1364
zcmYk+OHUI~7zW^(GNZPoAho3}B2Dmu^@2*NsHkXxq!(xrD3@08M!6|sxTt7iofRur
zb#1!Qz2P6Q)y=pmaqAzLV&dBGeDBnmCZv6zdFPzdbEfPK{2l1}?(w)Jdj0wSJ=x$%pfPj62~a=UTop2yv=SlsyKSlrA+Ms{6+
zIfv6Vy!vu!Vsm}1TnzQOe$u@%{cVKHUqe4i1=;J^SDcj|qd|N$4oRvAhdCUP)aFXm
zaB^@-s=E?1+#DJu)kVR>p-F_O(agassf`qlaqv;7Dn4EDReB9SQ!7(IR{}%M(G2FHq0}OX$Aqg!(>$xj4#hLIW20=rzsy<3ffmh||v^j)`b)`907ik((Mh#3>QY#x!V#
zsN~+sYFV0a7MAB4_O}4KFX;cX^#C}>J?zy(&?6>%@5i7gHhK!0XTqKq0X20*lOFLw@g_3
zJ37Cyj^HvM`FmTpgl^m+sUF(?K?gU6L^Pl5VNinTC^eFZDG{qmtFE-taioD6LOy0k
zp{#fK=6S4ffmOx)6;Gf!DbPI29B2wXesE&OG;oG{_ztt6ymf1>Kocdy#V{`;wy)5^
QW1iX;m$jz#Ci;X_G4x7Wg{7`yKaDv1AyJq$vo!Bvh9d%o&0&J049A?g
zk29PQkTY{sagw3WsYoy+ojFnrrvy|(QGJQyX=nTl!&w2?#W{xa0??8R3>Te>G{YrX
zNXE?2HZIFd{Y=>VfNWGhL__HLwbnpg4Owc4p16)DGR{E6QX@1lh=Hs#fOc)9t9PNJXA3*VnwkhL~fQ$qGXDxU>0b>X^_E$uFimN3fjC;w}7);hgRJN
z-C@Glz6-k7q6)2WANGI^J)Hy1GhrVKpodJjIg6l2ZL|b>%!DPMfS$I|Gf+vEDxwt|
zW#nZp!QP*PUbM~q67;IAY6bL~30r>ydfTGbeYW3W;CuSl9sM>3%BJ-H%c
z^NwEyWr(&@#UNr<#JU==)BrUw2h0=l(IbwCxOqIIz#G8k&wETM@Pb95tLXDM3MWv=
mmn&sY0;jkR-*XydIFB}F6r)<|ne$=xMwu&2Z^=u4asL7IS$whp

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/unistring.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/unistring.cpython-312.pyc
index df3e406737af3c0eec9a03d7ba144fbfe4acb045..9a4b16faa7757c75e7d5bd7429a5fb7123fd0fcc 100644
GIT binary patch
delta 22
ccmcc6$aJBRiTgA!FBbz4Jno&hk^5)^098u|umAu6

delta 22
ccmcc6$aJBRiTgA!FBbz4oZLNYBlpn;09BO-zyJUM

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/util.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/__pycache__/util.cpython-312.pyc
index f2d033c8657ad77228feafdf67db7bb73b00f524..3a863feb73ceb901b031b63ab76d81ed0bc39575 100644
GIT binary patch
delta 20
acmbQ3J2990G%qg~0}wp!owt#@%?toU8U}p;

delta 20
acmbQ3J2990G%qg~0}!0tJ!>O(n;8H^WCo1@

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/cmdline.py b/venv/Lib/site-packages/pip/_vendor/pygments/cmdline.py
index eec1775..29b5608 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/cmdline.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/filters/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/filters/__pycache__/__init__.cpython-312.pyc
index 9890915d250c62843da123a350ce05a5492af41a..5dc0f20efe7cd577826f33aa844d02affe2d6aa4 100644
GIT binary patch
delta 22
ccmZ3of@#SLChpU`yj%=G@VIy0MsCR|08;D+4gdfE

delta 22
ccmZ3of@#SLChpU`yj%=GaB}yojogw`08=&x9smFU

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py
index 39db842..6abb45a 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/__init__.cpython-312.pyc
index 401c34c4b311fc5d5e3e18e23b90a7ba590ab4fe..db1227fa18554c4688129b5fe4473c98db06fedb 100644
GIT binary patch
delta 208
zcmZoNn_|X$nwOW00SF%V&Py}j$h%00F=Fxtp?kb~3=A<$3=FmGwH!4Zlcx$>GIC6g
z7ZztU*!*0$i;z{yu{qpB1ND9#hgGw0S1ahfxIFP7*P&VaB%Vg(P9B{
z-OFNnpBR`~)jGL4SUZY0+lyr|NqK@)0_|id5(g1r-OeDE^W=jPGK|iX?@359`cD2K
eahD$?e2YCdKczG$wYbP@@)JpW#+b<}QuhGF9W-qK

delta 190
zcmbPY)?~(enwOW00SHd+o|R^>k#~_0W6tNm-D3-xw?g3O#
zqz59zL4+uXaDoxNKt?gh@)m}hELxvg*jbe!%A6*DkdS2bnam}5mmj417JF`fN@-4N
SagpcbZ<6+m(UZ-j?g0R+M=x^#

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/_mapping.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/_mapping.cpython-312.pyc
index 7575e1efbfc77a36567c3d941dc5226720f4976b..6b8974848b3be58e63035a82704a7616581b4b27 100644
GIT binary patch
delta 20
acmaE@@LGZUG%qg~0}wp!owt!YK>z?oFa}Ei

delta 20
acmaE@@LGZUG%qg~0}!0tJ!>O(f&c(UdInnn

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/bbcode.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/bbcode.cpython-312.pyc
index b3109f497167edd7bf950d7721e8831674f2ad31..4c75890c8bdc6b1b39ec201ff9275f1e24a30121 100644
GIT binary patch
delta 20
acmcbna7}^xG%qg~0}wp!owt$OTL1t;=mrb`

delta 20
acmcbna7}^xG%qg~0}!0tJ!>Pkw*UY`G6oy~

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/groff.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/groff.cpython-312.pyc
index 7ab635c2c85745882dbcd60817d0c19ab44f056b..d0d000ae0f74a270d7bd9aea4d96378fe5ec891b 100644
GIT binary patch
delta 20
acmca&am9lBG%qg~0}wp!owt$OQw9J=1O`F?

delta 20
acmca&am9lBG%qg~0}!0tJ!>Pkrwjl_P6ko{

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/html.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/html.cpython-312.pyc
index 5492aa049e2c547ab42e3008f4bed8f9218ab885..3d3a47b8d6e892c7639a513ace32f68110ac7858 100644
GIT binary patch
delta 412
zcmV;N0b~B~yaLm`0u9Rz4GI7N0085So@QLJ4O0sNp0i;K{UA3WARr(hARr)AXk{RD
zVP|t7W@&6?AZc?TVRLhJZDnL2bZ;PHWgum4V{c?-WFTp7AXQXGEjW__FdegbEF2X9
zo3oZd^aBCRvx`Nb0RhyrEJw%z0o=3oNKyj<V}vvgQM0s%#nwOYpkJ(GP~!~svULR?1y0aLSzT{{5*TC>JpL;(R|vkPE_1_5ZZ
zk!Di}0g1G8{<%>e-nvp#w30s$7YD|{dW0VK0be|rG|HM7Wo
zNC5#lvk`*W2LV5`>WNDO0kV<>Ba^*Q2$NF<7?XL8KMNRq0%QUi0001L3zMN?6O+DB
z2a~~#ECB|S?u{Y^a;g9T0Fw}oLk5il0047JlUa^57S|Ie(Gw@r6Dg=QupH4VKF||B
z&No0tsym0U?k{^#E;?
GK%OuL42{_U

delta 342
zcmWO0%`3xk90%~dzdyg9J^e1$4v1!plgHRWN!BJClD6_pXrr`ppd>3zcJc5F-y%~>
zxeyL~YAM|2IoaZ{QZBC26s5FgufO2+e92N5On#7Mtt#v8JUmu#B71c3(TFZ>;)_Lv
z{INny7v*_Igz3rlE#QG-&AY%e`C4v)SE_Wm1-w(RJtE+bOr6UN8ai^X2vPx4siv;@
ziQ7n?u3m;3I__y=aPZH*8#M4}e+(ToH_!sOd1lB+$-y$9moh^RV3-`kAqnGjKju+m
zjfy9?M7&UR`irp)ql1}8Ku0sP9}GtF2227h6q=s{>Igw6P*1H3$y_v&WvNZT=7wnD
zZ>wq^UhS5&0p?}-+@MrJNPD-7;Te`1Ln5}VxHLkZ(TDfN66kD%l
lIG|sCD&mX|w@pkM%@NfpCna|7n8q)oWX<)X^7Fk&^*`>eeR2Q*

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/img.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/img.cpython-312.pyc
index 45328ade65b173907988c2e8c132ca61d2e34c8d..583aed3da0105c4b6e165a075738431dcc84f5f5 100644
GIT binary patch
delta 4238
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
MLaU32lj*1a3rwsdlmGw#

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/irc.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/irc.cpython-312.pyc
index abff56f0ecc5bd20cb639df91564ed6e34ba1412..357baace1aec0e45eec1da1dd01bc392158b276d 100644
GIT binary patch
delta 20
acmZ3gzf_<5G%qg~0}wp!owt#DmN)=DV+I}o

delta 20
acmZ3gzf_<5G%qg~0}!0tJ!>QPEO7untp+Xt

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/latex.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/latex.cpython-312.pyc
index 1ee11798baebfea088fad0f4ad41310476cacead..bbb43442bcfc22733ae3cb537fcfedd86f2e6c2a 100644
GIT binary patch
delta 22
ccmaDhoAKFfM()$Ryj%=G@VIy0M(*3b09=~~@c;k-

delta 22
ccmaDhoAKFfM()$Ryj%=GaB}yojoi0=0bJz>0RR91

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/other.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/other.cpython-312.pyc
index f1e415d67fd5ef1451d43a008b17a40d8dae4bf5..9b1aa1f27fe59499b20cd3d43b5014eea6dec6db 100644
GIT binary patch
delta 20
acmca%dc&0aG%qg~0}wp!owt$utP}u8HU`E3

delta 20
acmca%dc&0aG%qg~0}!0tJ!>QPSt$TVfCkn8

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/pangomarkup.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/pangomarkup.cpython-312.pyc
index 8d15563733a706edc6261a1965d8c38031ac6edb..fe462f8ea5043754dae9db8720c204865cf95a07 100644
GIT binary patch
delta 20
acmaDR_DqcXG%qg~0}wp!owt!Yni~K^`vxNb

delta 20
acmaDR_DqcXG%qg~0}!0tJ!>O(G&cZ5MFukf

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/rtf.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/rtf.cpython-312.pyc
index e673591903947ba6fd35c24b7c6c1f0c73b174fc..4aba2873be6d1108caca91cc11053304e0e5ca84 100644
GIT binary patch
delta 20
acmaE)|45(vG%qg~0}wp!owt$ux;Oww>ju>T

delta 20
acmaE)|45(vG%qg~0}!0tJ!>QPb#VYlH3sDX

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/svg.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/svg.cpython-312.pyc
index 277e1b4d8108993523a7b596bdd2970e9589cd21..be9b762f268882a1b4fb8f16f44991550b0f294d 100644
GIT binary patch
delta 20
acmccTcF&FbG%qg~0}wp!owt!YSQ!9GlLmtT

delta 20
acmccTcF&FbG%qg~0}!0tJ!>O(urdHi-3F5Y

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/terminal.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/terminal.cpython-312.pyc
index b3c4ce1cb284209e8dc81f6aed4801f81697c346..f9fc91ac8a9d5bdbd532f6694d97d343a12016af 100644
GIT binary patch
delta 20
acmdm~yHl6@G%qg~0}wp!owt#DofrT?ItEn$

delta 20
acmdm~yHl6@G%qg~0}!0tJ!>QPIxzr2ga%~*

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/terminal256.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/__pycache__/terminal256.cpython-312.pyc
index 96207b6937754a33f162d56dd908cdbd3c1b4c55..ae4ab932993e38d108693550b36210976942107a 100644
GIT binary patch
delta 20
acmZ2kwz7=-G%qg~0}wp!owt!&&KdwnBL-Xm

delta 20
acmZ2kwz7=-G%qg~0}!0tJ!>PkoHYPQZ3b)r

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/html.py b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/html.py
index 931d7c3..0cadcb2 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/html.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/formatters/img.py b/venv/Lib/site-packages/pip/_vendor/pygments/formatters/img.py
index a338c15..9e66b66 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/formatters/img.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/lexer.py b/venv/Lib/site-packages/pip/_vendor/pygments/lexer.py
index eb2c1b4..26c5fb3 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/lexer.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py b/venv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py
index d97c3e3..0c176df 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/lexers/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/lexers/__pycache__/__init__.cpython-312.pyc
index ff579b5f63d3afebd7c1b9b76aa102b58316c0cc..2f0b787569776a2f9268d684f7cdd295d2ae6d6d 100644
GIT binary patch
delta 1769
zcmaJ>O>7%Q6!xsW>)5g5{KrmWXR+&8i<2}-$xkT+hYC@kA*D$~NFmN9vnfXY39}p8
zAfSm9s49U_7zr+@{G19BsL}!wM}!dK=THu)Fc%I;&5_9efy)K`!m&YGGRcvVWoRq>n~+&JUT`s|Su+r!8jq`J_Lqi4d|}(?6xCJrHZgb=4z;r1|gKbUXzN
z5h<2yCM}lnlFjnK%JY@r-9&fa4mK;KmwymC+$l91PFhaUESGn6M?m+0n+ktJ=CeSu
z0KxzQT45SOFMy%RjpcwAYPo7wEVdtMQe-#6Zlk6y7ehy^X%{B>T;vSVc}z>VKSsDR
zjn=_L?Ucos^ttB=EgG88Ai|PqOJ|;26tHoG|2X59Vkvb3L^J$q>;gDi97wqDHclzW
zZU*KXK6VH;Bgk%rO$2LePN`P?AJail^YYNWL}I{T2vvT(<$Wk=r1eujDe%i3N5~}C
z<6|+IZwsm+oOM^@?*-BrC%X$ksLQqLx-9}LHEP)^aM1iFOYw>1?c_tgm9!w}@001Y
zEIT%MuPj0{*Ve2m^%^nA^C{z=`_X8yVmd1iTQ=+RPBki9g01rEG>8=Xmlb34K-u*G
z`VzXA3qp7$l~GrK`zHT5^#|nkQBPL6tpE%|VaR7#4kN&pkVeOB5&F>
zBot#7IWv+L#1X+YR;rk6!&ZPLoB2-u5XthN@(1%esy={l0-*q4M42Bp;kPY^p&usO
z)5B-`jLdO7KZsBSFzRKop%RXD+VLvU#b51f>%Iw9Cd6wx&n|!m_5Y%hxH{n-dIsDE)2$~V~-<4
zc3~4Ke0f4ybwqgCvK{a5U^1R3L1Nbd;3VMkrlA>cAq=^14WCl_9|aQ3${E;3nSAru
zB@u+0n2y7Qc6fT~*yJqR$L|~IPRPd3p{nfp-mvj!MhtR-UmSTPq=WcgLuE5OGnyNF
z9+e9SI)Z$a=a52}ClF^Ch;853f!?cukecz-&hf3$u8tQ_uN?qdv|$U?*;s?O73c2g
zg)`40J5Vm!4ojn&oUJybs8e@lKaYT5kM%T;M
zEO?Vq!n2kPTaKF0YGqpCVl0^{;1wMK)4Eo7i>EiiUWX&3=Chl4=lF2stES}7!9ZBq
P)P9NZx$(;Z9b|t2lGA>S

delta 1784
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

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/lexers/__pycache__/python.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/lexers/__pycache__/python.cpython-312.pyc
index fef1cb8de525559e30b448c5bfe7d0729186fad0..f2f1e61598cf011275f2f1f0f2cba399a590aa66 100644
GIT binary patch
delta 4908
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

delta 4912
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

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py b/venv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py
index de6a015..1ff2b28 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py b/venv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py
index e9bf2d3..e2ce58f 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py b/venv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py
index 2c7facd..fc0b027 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/style.py b/venv/Lib/site-packages/pip/_vendor/pygments/style.py
index edc1962..f2f72d3 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/style.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py b/venv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py
index 7401cf5..23b5546 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py
+++ b/venv/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/venv/Lib/site-packages/pip/_vendor/pygments/styles/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pygments/styles/__pycache__/__init__.cpython-312.pyc
index ffb594bcaf57ead93aa4c9ba6cc582bbbbfe1d20..021a8b622325bf82ad8d2ea2f79f684738b1637c 100644
GIT binary patch
delta 1455
zcmZ`&T}&HC5T3d79savBa3q1mrsglkNs1t$Ds`h09H?lCNfEB9prRA?83Z-p+&TQo
z7AR^Z5UC(KwKy-8^G1a#kvF0|Q2N>zTp|ToM5@v}B<({DPSrrAw!0Xx5~(B2%+BoY
z?9A*p56icTTt5kd83_IQ)wjKSc|=p=kcVxfqtMHcAcaRk%!=s?=&~qgBCX?=0D}kNM@j0rwcDz<<8MJX
zrua_(wJR;1&uNZ(So8c}LKBR~6F5kkxB+;=Ea8lwco#_W5$fHi5m0S8D+;v4{q|st
zQ8301y``@T$MmGJynuQw
zPpK0sAaeM1Pzh=YLd25YBQ55mI6-obvSX-{s+Bz2>}=x?KjS8j!WerEJflcLiHBE7
zDBCNcOi_l0di~lcy3P6%(-UWk9S>?Ln8**0_YDSzB3g|W84m@uniSVb7y2{vB~GP9
z>Srx=c4MkU-tV~F-sEeM{a0n*)#i_{w8*}ukMv>7@8u`S$zsCVA4E(+Iv9cM&g(Ip&-6(6+<8(Sz3el9<7mUa~p^%*Y
zF7*xKY#^*P67dXPPQg<_n(LnFo|Sh1IcXX1(oVor;a8OHeS~%1nNtv<$
zA&5{Z_*Dvt{ruca3O`pJ#MI~<)Yk5ovS++FIIP?V1>aMviI=uky9<*5Bu~U`#)yVL
zivZt!3>O~5+i5d2w&6fLNAByi<
AbN~PV

literal 4436
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
H09)h#l$&nq

diff --git a/venv/Lib/site-packages/pip/_vendor/pygments/token.py b/venv/Lib/site-packages/pip/_vendor/pygments/token.py
index 7395cb6..bdf2e8e 100644
--- a/venv/Lib/site-packages/pip/_vendor/pygments/token.py
+++ b/venv/Lib/site-packages/pip/_vendor/pygments/token.py
@@ -209,5 +209,6 @@ def string_to_tokentype(s):
     Generic.Prompt:                'gp',
     Generic.Strong:                'gs',
     Generic.Subheading:            'gu',
+    Generic.EmphStrong:            'ges',
     Generic.Traceback:             'gt',
 }
diff --git a/venv/Lib/site-packages/pip/_vendor/pyparsing/__init__.py b/venv/Lib/site-packages/pip/_vendor/pyparsing/__init__.py
deleted file mode 100644
index 88bc10a..0000000
--- a/venv/Lib/site-packages/pip/_vendor/pyparsing/__init__.py
+++ /dev/null
@@ -1,322 +0,0 @@
-# module pyparsing.py
-#
-# 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.
-#
-
-__doc__ = """
-pyparsing module - Classes and methods to define and execute parsing grammars
-=============================================================================
-
-The pyparsing module is an alternative approach to creating and
-executing simple grammars, vs. the traditional lex/yacc approach, or the
-use of regular expressions.  With pyparsing, you don't need to learn
-a new syntax for defining grammars or matching expressions - the parsing
-module provides a library of classes that you use to construct the
-grammar directly in Python.
-
-Here is a program to parse "Hello, World!" (or any greeting of the form
-``", !"``), 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/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/__init__.cpython-312.pyc
deleted file mode 100644
index faaf8610ba33502595fec88b939cc1bff4e48572..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/common.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/common.cpython-312.pyc
deleted file mode 100644
index 53dadae0d1972c761765cf79cfd916e38dd35e1b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 13402
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
sdi`c~&4;}YFMMqK<d$R&rz1e~6
z-kd;AuP@;1%?;%C<^}S&40j~Iw;)i^TNo(hcTc3Kw>VI&mtPVn;qprZrTkkKDC6IG
zfqDE}9w^6eMx>&*GEk}KnID+XaaDmT{ANa~duswU9OsQJ=#>L9KW9a1d+P#q{G1)B
z?_C&Ji02%|7is8S6j;>T7-;Nm3N-cl1ODE{fyKQ`0!w6qaIN3KI(5Ceq1zeQsQT1R
zN;wl2Y=Bq?Eqo6e$C3
z99D*~d1}*3E!WO!fLn{$FUoAG%Zd0n%ZA!J`>~4zC(FK
zk@36pz9ywsb@kj~w9)!i*He#_I>e4yp~jOQTdnTy&QR)6(jKRz?m@r5Vx+KsRcFt*
z^=3TvJYzgrzskaw9OBIw3oR4n?tDp4g4t+S52y##PpOC0!)k|mM7>+RN4@t%PT;6o
z)$>EEB;zS?ALi$N)h*^H@PL}Du2QqqRn#{bT1Y>2_0DfuLT>ZXFUtDb|}P#dO~|s0ti2LwDOkyF@6b
zUZw6no?)g}%=96Id(3cEE$R8CF*4RKLVs<&8Bara2%J#Y^jtGStlysN*0b>x=$Rw!
zZ;TYyZ{Vb|C=gL2N+Z|OtDaCJ{1jE1dj1zHo$-VgzGXaHzuTlIq%P-i{5?=CNh8v*
zgmnLG#T!qj95KiFqG9QR^L(irsYfIO$^x3=48_#>J^#f>YyDy^`)MsJzfl%H;s^|6
zNy?0}MD0|XKXOI1sJoSFHQ4P{S|9NQP9fKzB@gtn<8X4=ni=oW--wS|6`L$@JxyZTu(?O6`pfzX|{(9fx#RUZmI
zY>XB`~=s|>j$`<-4haN)c
zVf9h7gi#LdK}w5_(U
za_AX^4ys=@YkP)6hYWGJVHa#EUr=8N?BbXw5%XnR%oPrO3ZYNiLSN+2uORfIE%e(QI*!mw>bK1n
zqiWC`Uq$FMw$PV3^jU;{%@+C{4*g?hB}<*vF*)hMD>YNPXdBQh(D-{X?XF@?%ne%S`>JNPSLu
z!FWeMd#(N%Ps)`?to`Ljoa4oh$?vX9RkCH%FKI`Ct&gp@YS
zk@IhioZRk|TIa~~s*%S&zH_8~%}5*giP^FrtMib0)S5x#>E)joFr)k}^?Hsne`=J;
zZT{IODDCGTQQGT9X+u7So^#4Cj1Vz-4-`H=10UE83+dT!+UYwOQWWCwSIyZg3=x=yHx{NR!3vA%(*qADUF
zFBt6Vi*|>P2fHJoNVo!qMZwcwbNpMUShoL`6`Ib%pxXpr#&I&xp`q
z*NKo8OJoL*#Ui2DiG-KRLA#=f%zcNB>{omH61irT{92%?{gF_YssxV>2K&|iHE6G6
zG5YU2h?2l(#|9$tSYlq#{(4V1e&RrPcT9~Vbz%QtKax`82BP7vK1FR!c+uKme6U~j
zJAX$4jNf_1yybUMzm;IW*4M9U@xd+xo0kr)(ydAaU6fQQ;7}w;s~q5QT#8$9fe&*J
zI{hBaj|5#ta>`H7RL`v<+%8JPj$tW?Cvgo*FFM+3K7!o?(Jpk&9aAIS2{*mPD5orc
zaA4cI`*()py9SQQ2erN)HQpDyKQ_?cr^VI#PpQ#U_wNfIyFZ3`Zs`wooeW|8@9z)y
zFAXA2>C={)L$I`~Pg7g_0g}OBI2w)zgG1#heQq^kj-cvT7H(&y*^27XZC~7TiyGYC
zrHg#%g?q(4i{b@6lX`R!3CHTUVTZBA&NxO~!;T*N*cfS~9(xx3xyOBbAR&Zd*I`L(
z#)IFbwcv;PqlCNAA9{*nO$CE~x7Ny0;b<%#qGjdjJB`(saA|5hMg_~bv}KegGZ@4I
z!D!68eKa`YUZjdG#SMe8e)Hd~`?Gbgo|s;LVA6MBbn95tOi}$*QT^p@FYI}K&&?MHDN6RA1Qmom;S2hMhlI7Xy^SMl^f(vf-@bp)~pGZiEu2Xws@c1p$(|bTqN*qOtq@)3Pn+wtVRjvay|W87_HMQiE&etyP~M4)JR`{
zuNsYWiJ_<>$JH3MqcxjDTI9}7La-_T8#_p_Evf*)o>Zf;&Q7^SCLAoIQKC}0JA8&~
z*&T}wsB-=4m0}zaj2@|)))!U#24eDYt#6Uu-r
zXdHjYPLr23BF*x#fw(yp=vZgxj!-0~qO;LHInsx1MWe=I_e49Y+IrjwKPY`&Sh3l>Z3GqUZHcn<
zp9eO+jGA{%H&i^ph~kdG#iM>ye$^#hi%_-Ses5eT&JY+aUc27`?9mn~zwq-~-W
z(Cq>I#dhKLi1fBI+vB}iE)~_D-Sbv;?WDW%pB6Mcb7rP+%XrZh?Rz6Hj$A$b#?rPY
z>!u60oZWNN=`8X6ufD=_+aKTgwny?5zJJRl6>W9I=#b{=vNlh~%WmAbk}d?9mx)4l
z0i&luAB=!t6v)cbVJFB+fucaH1@eE7ay&+R(v(x67AjsP^AWev%Ro^wa?=r=MIgFH
z_}QN&cB;^Ef+Zy!Iv(xAitpN?-Gz}zxKD?)Xu>BJG=S{b!14Aj`-V!p7H_u%3cTIo
zH}%>kvBVifMh~S;xvb6DA(6y+P~V=MiM$|HPlS?y(+trLA~w4K&TbAB1c}%+i}i*Q
zXzN*HLshgBQ~z4i#6E(?#OiT7E4@`RZ>D6?RLP=uBu5s=i&8H>N+t9sjo
zAl}+ubS5&eT@Pr{c7Jios?@fipoE`l4)y|rg+WB?_z}bncS6Ck1KAtp?LtpF5M>mo
zuRH^zQVxAR6PaDZrBaWB*c*a<(V*JfA0G_v=+h9RBx*Sx!9-iC!2zZ(lao{%Nq|Pf
z$D@Sji99w+XfUG9rt2hhNIM>*goLlV6HR6^LZ(0&z@|Y$DZxnWM7SGG1EtCgMXeod
zsKwNJNOn!s9n-d9z_jgj+d;Qa(fIiUoau9(!&qOi6B3E8!TbYHgnm>LN9rAvd0Qcp*otdx@1M|4gtbxw^zb3rZM~$jldvcf{~yQ(yoAX
zWCLZ!nm0CngBs9xLxLe0TRs}Vn>L89P`dryzU>ngU_l*|2{M40lJsKhHnTHj5gRyW
zrHyf|MD}o(KFLb`59$)=N+L@z5VtkmY=xZMRzY52qwmwl3iO9+44)vTlDjh}Hu)rd
zFlZ_reRSF;MX#Qa0w%{!%?XO?LNFg%P0t6XS0cOPs;=_VIHo*c-O^Z_hz-A_mhs-Sl!1tkDr?oH%
zC*)&;vZ#>2gHb&ov~go2DkR<#XP!hxBWS}04g{d{3liKm$mTLlhwVSU2L>2mJq7!^
z2@3R44oAV-Yv2?jV3L3`boyL2>XT8QjICvW_91JXee9l*)TGcryst%M!Ki^c!Mc_S
zKVfCWSa>C-3M4i{!HD&li=E{&+V+S_^|#WVO3R^BATbO1#n48Rjaq8pI+_70k;dN`
z0i)$WrkwyD#f;E1F%{C;%EQx!CYpFIg;kroXjEvDHF`lBkw4lz+`z-cc?6b>wpY>0<8$_v8Rw9e(G!+6v
z?H;^$85+e&^5uo{8c_)?Q@{XGs;P^H!|3+s_=^?brqB6|Tb^>uZ@BBYi;2>%UL^?BqVi$~Jx!ve
zSi;972xP0lQz0!$noFyk$H9m3#W?724ymLm=NxekOJKud5T&_>U5aA}S<*3Miqlvn
z3X~lyrTc+KM%*Kwk&Kbd5$~|OhtNvOWsGc(!J*sYEdgCDZ`c!a4`;-j!0cLEcvtAhurIMec)K9b)#7cM>vsX
z3g|lgPVE$hN;~}Sg!@=uUqstU@198CX$YvcjGgEkh=4I-RAgd!
z?JR2hDgI(#!wsO4A>|c~HBaX*IJ;xE#Q%F?K2yWOl>#w{KZrGi?6J_p1<_X
z!pciMFYdZp{_1_#)*gJTwBp>3+1%16K7H=f)4A0%xlL2KO;?KF$ZeTun%s2Y+KL0S
zrIqJ)+$=`@H%la6(b@e1ZYvKSJ=k{W@b31V+uPf=?AzY9Z{Iy_huZOeIFXyQ-6pb^
zEnl(nj#aDgT(dUe!@<$E?K?upxNQoJIC*%vyW@cV|^6ctn%
zapyz|(I7+k9Ay}`D5PFu?7>W^Abm*04N{U`AUnj#Ll+IYanUnL*l*DW_O#<7&Xvx&
zhD{WrABiv?!~%1~5{^j15!dM0!Z`0Z%ZuOx?}kXI_m~peG*oSy`_>IYa=8f)BDx5(
z9m_%f_s&X};+NZ=Iek{AOK3uOXeV&j6x?3K`Bfy`8;<|(zu{sEsSCm8MPo-~)2$o0
zJ?*(DW#J#1?;V!TWhqjn^d%fR0AezS9fzfQ8%!+(8W?e&%hVhXV~*3E9ASRVnMnst
zz`w4S-NroATq+)dm=VvgM_}FK4iO^W&gBrM9Le~MYdAy8KbLhb`y@K6Wuu*rAtLbq2IL~)ItUsN`@$VVeQR%e9pV7{}@8Dt4&Z8pjOSoY|vN~|$xE+FcEs-0<
zu;WR|uGyNp
zv7Fg?m1EiO-6*blM=Hv#{HNlY*^-L4D(25r_@^rTV_R-iFPf=dK2^PZqV8(j_3BMy
zJ7yOyzOv%^J!AXds#tVcyW*IvSUg$28r$8FZYFpyE)Rx({
z$n{!-gYJtw2oXniSvaSn!w{S)W+qC4BtrGmix|wTCfI>Cr0{#iL_9;Ov-a(7-yYnyd&drqww**4;Rj}ow6EfwXG?n)Pcg#4
zV8&$muDk9M^O0kl28~8Mmxlh2@$g^IN;kcd*LOX?ek!y6AM+PYdKbOr%RRe&wrJkj
zy*GVQVbR&$*x+hbUaJoLFg&w*|J3UJlO0E{ufBWoo}*K%1C#EG8)yR9HUl9`AX%abn@soax2eW)|B>?PB|KcH`9F*u_2Fp?D~ggzVht2k$r}
zS;UUxeiT?^*zq~%up^2c<}uH(Q_G+@aYa4Wj_{bixJfZtp`&i>7M^Y#
zi$3BtC@Z4bfWKX#tyuU>xb85pHqbcaD3A@r<&Yc;_d?`MCs8a_bmm
z0d#DLxnsG2ex$|4;w-EW<**D{7PL*Pyj2_}4(R8Vto~q1=j=&I1f+rM4x@f9&dvoV
z5df_rMIp@%B~0W~C-$Cbv@cEvmRw6yYydkDq(tKEPf>`^4pB!%1}>ah8kG%cvmBw*
zOFAeu`0+3fX3qpsEX&%7OXF+@n4AWucTycZ-KRm$W5^)ZSprNQ3@}73x-^EWAHYdp
zudK(>25PjIk7prj3x#Qn)H7WwSHks?l!$?e3k!FPBU^DA%o)rE^9b!AxZ7@&&`GtR
z)_$H68ijB#WawecZDi0m!tBHDter;Ha~5iqC%QOP-5m;(Lm|C0gf?ozOz3x)L^z0ayR|JLkCuqVCWA82>CQ3JMjK*^NTNR
z8GCTNcKlOc-g`Y?ezT}@eEE3ja`ALg!=$eP2)dw_u>f|(;xzM+$m2kB92vW5MD?H-
z)L89XbbEnr#L;WtrW-9^?ts9O0!dcP*?8@HNWX(xy#)^+0AU#hunUw$RQVQA2?(tiav0B8Z+*JYD5(JZNy|m
z`*66}7fHD31*%gMRO%~q`##-%fE&*8Nfb<@M_Ohvw1_~|P~Dl2^D90aK_rgb_0uc?
zpW5Fb?J=6-hwyM#dOJg^YPhiVO5NH0H{4lo3J#_ux;mMABCXa@u4<4I5&~;P7zEgOkuym|ze9d&>!pVXL1T89@Ei8G~
zHNN$7`E>c>E1#MwZ=EV!I$5x6!U2vjcjdo&GH|@Uf;s}VGqjMv0!OO~g9i?4VqGTN
zfJC&-GfWWk3z+bjFp*({i44pMHYwae&ZZMA7+cvh($~y`Y@RufZRUo&Jaa%yLvFcc
zlMMd+	f6SmqIEC;BtRe7uT4?KQgbr2LqkXlAs(#w|t|i|50bk!ov32D-Yyrzg+J
zPm#Wl=7bctFee4}IT?Lm^uYKUo|2L)%J(8KMqY|ewrrft-t>lhvlvAe&{h`#fpHOc
z$3u1u4;V7HIb8>cp2Fikg0W$PJ)RX9vbAYWhMbXD0~z6wLe9jLs_yw@XazF
z#kRCghJ2Do(@o?!lYc;7De(O>1Ngh@|A(jNA&9Zz~0=x7(={!W^zhDN>73mV{c0VGvM4hP5z5en~0CTN#Y$z6~|f
zvS%GIto116su!lTK+j0;RVp9Jgn{z6mHALIEmvNKd4Y%_16og@LRp|z>Lrum?0nmM
zE#9l}UaiO1;k`zwR~P8-3-K<)G|!_fQfrkgwH79`jR>nt32Q=FJ!3)3q^9Z9vXQtI|pS76jb?DhpO1G#lwbXXZ5JBYnM>5UUZ9;hyX5Lz51H(ZE=4_)a)n*-*HlYR@
zlA2rC(A507=X
zPuYo5wxT7w^g1Y4mg+%Ec4Kz8scn!0rj~A%+z2SxgA%qI?NIjW~0Es*Cdl0|7@cSwJ?#AyS{O-Z;Vf^mJZwG$&;r9rB_v80&{I=uw9{e7_
z@4fgvh~K05{SFJ*v5cQd7
zJut|mS|eiQ^>L?Fa(0fHUZzOK{P4>B9MV3Fzt7|Ekva05LJf^D&e!La^L=5Cv=4IZ
zAE7i_r;p-q6o2RN_t+dc(v?oQ*o$5*Ld~~fLNOzJuTdVyD8a;A{8Ro^Igj)YViq6?
z;g)<6tME&x{R#Yy;g2wpPq~2EJEP_RLk_CB22G?qY3+k1o*L3q`OH*bPLm2o;3#RH
zndT`gO#r6gh^sK;p0>roARKY?%{UmAnl-~L9C1}<+(la)jKdLEW5&Vs)XaC5<76}L
zk}d9Y9OpOVV4P~^dsy%3CNuUKE7nZ)c|Fx;GZjo(jacJ10JCzm?=CaV*Q_*wFL2ye
zGY&?tW}8O3>{^L%(!pb;$V!9xMODAw`_4RNk`mqGwuaj91PPDrAqAl)%x;XHpx;F4-RS7&bnBo6V+QY~;8+XNA`6D@7cAxV|#GxE}Y5jNEAUtcnlT-#FTcOWbuA`q8MBi
znPo)|vxHzP$&?cwwu!o31A}O9=4yKI0ItS%CK3cqEUq}E;tQwE3vg;dh8uQvQjf(+
zZGm;}1)+gn!mz_S)jD4bWngG(gno+1Y@MT%51=Dj82avfD5bO75EP;#G1wZZGB;ny
zxhT)}Ga(X+uG6J^Mltmy*JBmN)U2%V!$mdA8#>yyY+_}esCt?t0%kL)oO>WXgf?V9
z^v3-6EpL`vTU#G!<*6aL0GN!XI-F`!MfXRKp9sr6CnI%!S*|D6_P$0$H8#tQh@~II
z(+`p~K43MTYN@9l!PJ1bnjVNCacl>>64*R&gGfqB+PvXzNPKm}4a!9q%dC=Aob)~i
ztv(A2xTZS!{&*dUN382VtalHX#kPatB%s!QjT_Xv_0tMg364SUp|5{%o0ye*Xg;^H
zah?mhSvXZU10WQbqB4l}j}aqgu=!P_#5GqBhZcYG(YOG3i!DdV5W!VREi2CFUibQO
zI#F8xj^xa0fogbu@l3vdI^TbzuHmx!^~GcEr}N+TAc|R6?J%--nM(pM)Jk4Dm3WwI
z=`g5AkklNm!>Yct?XqUFQh{z=1ZscKb;H@L05w@($z&@;l5ru!*L0yb&FaT41ib`-
zO@tsG0{wjgLzs=CqEH2FC^dPbSOQSkiY3F20s%Fx0i@8=Hq`;oY5@Nwa^uoQ+|BS_
zsDYkH7omg(0g_1-8|9{~vgK>nu3fr(#nP3_ZR?8yX-O@m+wv9W@cM;pht`8}(YjcIzgxr(<5kVaGOe
z1KkcKj)#!rE6$6~Kk|5xa?p9Fbl&qF7Y@2zL*F+i?PwS@KXf-?y(LVTX{GQs+0=Ke
zr&(USSRA09gfh?Zn4fLG5CN#993Q`G_CeF7Sw6(~eOnH-ZQYJH{rB+p{ksA920XOt
zwiu8ZH`O)y9~xP2hw3CeK^x^t8jEGPJ*|(#u=D^9`N>Khx)qLYM_4-N{D$L8j;}Z_
zI$$xAPZl%Oe>UpWbuHLLBH==h5H{R!J-z||!HePjIFWxZY-Ehsj;R9iiT2SS9
z%2DZlI-|zYc9Gp~c!k~`-|q+yL9L-IH1
z_Ip04Ozz+|QeJLjMVuJ)VCfBq>4S+J@yIGUu+QRf679A_FKrcCYcmPVfLIqaN5X5I
za3%`4)Wam>7e&K>KFBAnd?X6>fkcr=BE;f)q7n`>&$>h?1D4p{2sjfyPNcV3`)35b
zPBTNt3SW?Biz_Z}zOZ?+e&tm09n;=BW=rQ^3|pK3)}N&9MbdSeyIWsHCH5mogR+MGI%347fHn=9D2CsRd53lk
z;!GNq-%QCp9Yk3gQwqJ2(3!7zq4`u~JoV7|U&{58-U{T+F`~F6LWF!N(8LU4LEGN)
zj5q6az}7F*?3r^G7-{*On<9||QW+*c+kx)D=_s_G5;-7L)KD+&=}ICOS$D(1#2KL%l>uf0$IuBM^f*J2
zL&7jwV@UOJZhZv+%|cD_Ae=)`cj<&M64}NF4INm;MR1M4rxB)dXAt`?IRnuCciik$
zEF0Yql_g^b!vn&vXono+
zNoNXmTn}CVgg1)>PLoP8tgN(NK;ob{14Q?zNDR2J!vb|5?K=%y83CNS(hiY@bn&5h
z6StCq+T>}^)cI`{1CZfxMoMImDqd7E;Mzr?N=Vq?&I*ibj5RP+lMLjk@#Fv|R*e!s
zKUPXvxij7cQ{DwL-bGX1MVE)KV^_&99?cO1C6byKVfT9c-6DJ-h)D~t4ok-^op^_J
z?rPv$=*c^@{g7FhyMkG+NraL%*02-0#g6mypaE*`5mw4!^As0A=;$%EeeEfF%>BU%
zHCkcpBFOC$WFA`OIKOYuG3a1Y*E#fg;kYN#(m$Z}ljjFvB1@d&Akn^T1!aLNNMTqc
z!78f77G^FAyCqz!46RVe5(sKo+#ncEHd>AlS17Dq2ttURr$x$$IFZ@k2RTc3JmG?J
z7ZeK4z*0>~WWoe&04ULPegZ?{Q(<_9A+IvL`X#j{1FkL`Z9SjwOGJ`ya;+{mUQ`hP57VSB9q9h%zvP4`EiAm|yh7~AtR03QqLI&w*WKu3Ook`*#T^bRa
zR$~d+;y8{LS2{&;1Kd!z3CyJS4AI-2=%5KE`$H$86Am@JeqAXX2*l8~OPZ+8R#`q0
zQ@aNuj8!3%VM|uCASK-0t!gB>WXzVa8zq-q`mQD7X<3`BLhW
z*a4c%ZVekkoBgu+IG5ma)n0UFnY{XrWqaint5&0I+n&J%$5KVI_pMsKVp%g~YnE59
zTD5XDepjqsbH~b6uoSTgMYlu46n=3Ce1MyJiL>wQB($cFb|>2+Gwu@MP5#c#)XHuj
z$KP|B<{Ux;8ruC{I7h?$Yd5jhW&%~T~jLrq8lnY$l`v(R+Y+x
zex(#6TQb-MHB0%$PlV5f$K8+jjk;zlYi24JPgO2{artCr%cu*K;q4(g`7=2U*K!(e
zRLkF}o~hk3Rl8-ndh6)c^X;?wMWflgslo$T9+B{Ek%-XBim@SIqJRR~dkk}>YD_Ce
zBTb!A+KLHlF=ixo5Y(FsMm8W4hMm|t=Wxh{EmOy5OtVd+2y<;gCJfq~E!Y{KXewim
zEPNdS1vB~!Lw6SBkkf>ab5O&Xb-fsq_BNWI(QL|tAif?90$N(YulE4^8Evs}x
zyPbR&SlbkthR19jKZ<$BaSJ8@?ZQ~5fQi_tsHvf2$29d6>1%`ff+YDwDf6HwN{6{L5rzH
zwjR%MdSD3T0UO3X!P}=Dwvt8vX1fhMY5bZ;0%;0JIwSalO5no;+ZIH%*2`q9VB1Qp
z^-9sUzUi=&+>_tq5QB=N3ph2O{P!FZf&`Lq=!CH_k}d)EWOSNB5*MVx!EMY_%6e|3
z{h^NchnpLu%BE`->nE42AI;;FtNN*Y_y)YvI-S3EQWw5;5xO=mdZxcy!?*!`JI*?Z
zl}?Yk4W0$4-I0zVS4@6OgDoATOwLNOtb_k4$lF|&oNn0Z!$uJ_+rbtuZe6pL4Awd@
zQnVeyOdzVT6Ep2y1Z)2{Zb^ek+fgDD=cDAdGI=1iGQC=`5b8mgu)#j(KFCC|nT8rO3^aFEI?q|=h#D|8Xr?4k8
z#y&U*_k_T1$}wFZ7yBIB_6VtpuEt>c4v~R3p{+}W921Oys^j$w^!KF-5Cv>5AQ<)u+ZHjRh9wLRZUmd0$s+;l
z$EIX(rkXg)I<(PK-cOKShyJ~HR{F<+N^r!5B^Prq`mGimMO}dC}R?;ddo6MB}suUTsi;AZp84hw~Ar;cG*ZR*##p2Jh1Od$Wb9
z{Jj}*m|A+bXzANN$yYWzf5CI>FRdTl_pfeG?moxOJgIrj=+5iDrrFBc(QW7V!sMl(
zWHjepk5n*kEPnB!3lB{$Tz5TxJr?A1Coi3xso6ADvuVuzRE{MyO1QeCu`V>vyomWF
zY5OfVLhTH_B~(-##~tjqAd6++X71$02HQO>Ve8oPB|Tj%$1;1d{0lw|9T|8Nbm=as
z>9EgcA#TZ%;5iV7eQ@$j(tWFDXF5p|%rMf2Lxa^=^2RSpGsOqg58Z*Zi(I0HK8M2z
zb8YK{xZQVFNSs;GN`z4X^JBcQL4Xm}3K0P0NG6fqZ|BYh@x~T_HbR3T&6Efbkp&b$
zGz};yTP4_>NfJSpkE93@YnBzPe==1j0y>Ongj%%LKtJu~lz^P?!G9TLhunXli>PMg
zhVWO7LeHj)-Gb>(o*8#>o2hQ%FD&e_9p||^{~*QySf@KmR2&h#)L`<8W{BmOs9x5x
z(y}&eHaZnDJSGuE*d1*`V_=CxMhquoL=_S`LvXq(1|CQuQIP-sd99H;7*z?=GXecnhDq;
zf}G=Z@FEV*ULr)FCscCmL@;MI8Ye$cu0jbWc`nF%YJE#AK8Q&cqVHw~uc#t83`j$D
z<5U7q0$l-vX1Qi-6fqFGGGA;xGbjuu!CSUKL*$I5LMTIATJH*-#92g?R*OhX8IKuG_k6Eh3#Ag`uvUCDmCy0;yi%TQ6h;na2?y
zxxSf+BKNovmCRa^S#Uwru;XEP4A-02td~wkKcF8vJMD9)dp0BJ7GS|0=TVIHL7E7L
z5oXCK-D2uQI=Kl|gTG+Of*m?Y!4M3mfz=3Om}6{1JpNX>O(3EubET(4#HYh+TbP9K
zq^76CoM4FvJs?`=Td9kJfj5g5z$N4d0+NsjUZ+XvPY_drwbrEwB6$)st*?*PZmqAE
zosir4I536ngul@YePLh`P&0JwWgh`l4`BfgF5$*_AcnC6Tmg9ONer2-jdZgP7#N(yDvtkTdsIm%4c2^t-
zix-EjY?$K18$MJrX}bHO7(MC^54C*&5rr*BtSklaul3R~v;aL3%4peEu)Y^!+E5PT
zPwZsoZYx^bI#*l>ZIq=X(y}^fm3O@oCH<@?xJ4N;(_pm47s_h
zay;B?b&d)HOc+_oNih=h>5M;FmP09ZylJGM^P6<-N_Kxi4FHW9?gmyj?Poi9$s#Ki%o;uCIeo5eGQQ*{Fy#co$1L_c}gIV%8
z(NGeCxII@AAlwFVOky)+8T|&W$*QZsP^6uKV4w;l(-(PiTg_^*zXfU6iZwMhHYNch
zbqSgwDLVu<*g30)?>n$u!mAAJMZ5%)>!m_1t?T6R6%~@I7b>yO_ifD*C9H(r_H9w<
zg*CwKT_(E=_MC()tR+jQOG3c|I&X@->B&M6>!sa|zewa19>u?j
z;*t*E{$~UXEoXpEvZ7#2q@N92LKagq7T=^3EcK*&a{Qz}Um63&)OkJ0)MinCtPi<0a!6
z*K%rR7eEqo-B)$9K!{>;rILB*@s+OYWh<^1ueedRU{bzox~y%oplx>D#@{U1G_mCy
zIajuPGymFxO`LJIw(*6^=PPFmYA>&TVcqlVuJm0Un6BRrhlX`|l%R%GI3VPC|D7yJ
z-pp<{{=BGdqdN&WNQ;+cIM?t%ieqOS>BOjMBrYyw;47WPh5W2_IqkyLbgCIR=B%S*
z&K^^Z!YC8A({PiMHrxqG5Qdd5;};ScJp^9-k|i?kp|6>1r44AzE{jP9C@fox6mN`~
z+;&nblB!yVM^7VL-6)n<`s`MDZoJBoXA|
z%oYw;RR~+a1L*vl>5TG|1FyLn41l~1h?!nDOD3$!7IWg;Os(<}So7eRLY#>wL4T(u
z`Y^JaTr(Qj*-2oDeNy*ghOYv_jGeYiozgV=r|-Q>c}vs@cQc!f!2ZOHvE`m@qajHE
zhwulvC!;k>ytd(@3x4S4iNJL$-YclHRoSw<#bUw+DbXgQ;#7J%_1zjYYOXHm0%#gEu~=1t18SVL=8M7;4jSn+~2Uboz$JuS~}JD{cYE#OAs=FQyaK#{S6
zmj{TJUAV!%3GOv{uOmNqV(Uw@>*Xe)kD>Vto+hE06!}Zq@4kq_u-~;x#bxhEnOS+G
zTcF1}5cyS3Am
z>)y?D7Z&}iD%$Tnl-7WAWbjaJy7z6~fb
zObAl>u|z&??bJD)_exddNQr)%77f`;u>rw+GHc1Vj(;uBXI(m7!~jZq{|vm7cp&~E
z9rpkq_D=W{r*DU*jmK%OTR+Xk@hR&N(4t7WaGqP>hSz7ryR<4eS#%A1KuH!MM+W&p
zaZ1A(SUjeR1|8qyt8JN7FP#Ja{_-Cz(*W4a2Uat^yr0%WubDxIwKhTSk)DH?`VHLV=
zGP(<@&d)8qw3PI@`q@r2NY#T;rd-rMsTZt|>t4ExSH&KIH&c>@mkM=JY6`*p@aYOe7m
zMyrN>@fzbf-fTQ|n{>s;j|0hxqT%$T@&D&OVXjuASLtv9?Q1EQCeM*}X-Y!8^4wx0
zAI<|_&@mTDhKKWL`v8>&Don_h?mus<^1K^2UG|-
zsAo1!gZCXt+fBFsMiKu)xBp7FeF#frTV52H%h3KWL?yCJNssoQDe0#udp$j|F8{yM
z6Djlyk&1&0g0(PC&q*~?9DV&3@&2L|%2Ok;8CEPpOcJI?2
zs*n@tgb%bSByK_$1)F6Jew^U{+{cts3@5nI2}xv#w}cCPd=Rh`m4dFSvngg?IS+DR23xYxKz2
zw%L;Mi+e8Y8O<`NUEe?Dl#IKd%l~TrP4~RqvNwwtT;4XbaMiVit4Qm)_fqebT@zi?
zHR~?ye5Te01X8tEXSjnqGA1QqH*R(%n$Lu5Wyy
z_4(F`@~d~gx_i2={lea{t>b0yykL_VPUwzH1E|P*-7xW43P5ZDn36LtP8%pNn3KUb%PT^s8CZHG3}P
zjJd|{eygzbV$Fq`%ib&XS58eAt{%NrnmygHcYMdqY^kblYJSVaqF1x8t=MzJziL)q1kW2Y^0Fy;*=*yI7e4#^
zXTeT3?RVT**m~vEU;6%5nY?rF^um1@$eBfVPA$6g-JFcYHJA3hU5Gj$+MB;X7;mD^
z!pgBNsIzpug;EjH4#2)_;f(Bvfqp@ZEB$ycV*A!pgVi&7YaqG&QejX5Pwc^H$E5SIw0B
zr^@{^<#$Y#-!WUY@Nxv+PU^1?prI9HP*Ga>;murR{P5i}9u#Nk8jQ(g%Yo^dgX8$j
zRPAKros;EvQbna}KHzU7eWz{lp7qj?%ggqZNk49#hv%PcEZbKn{VX$o|03yU^RoA6
zI)7H{r00chy8GKQ@$HvcV%^Z*0}y|jSJcSZhh9i1+Kq$x0UUybp5i@gO^{{
z)$Mn?ewCTEzuxn!g1r4To?q2?=(*m7B7U_ft9`NSS4&s7H@JS?;KB2+Te1#hd49b*
z?||F$4{i^hu~X!*Vh;pw_%aQAQ1$7UFQ%!4a=URe1tGM}(AhW8mvrl4+~~V%pa+m9
z^!1v&$Au7~ZWOho^uRYPp0-r`36bL(&mp3CGBNX0_3V^~3JXu>EK&BVhUsykW=1TF^?6LLJ
z#amx(n=0Nh>D%$%jeJ0@3u)fWhvq}+jUxGS`IVIu?jPm6l5@3Vx@gO!Z_CY0O7H=5
z;}4frNS7Kmxst>JrqJ?URQfSP?y`oQyyt=BGKbp|9d<%8
zrpf;Y{?KgVT#lt51RG*F+Uv6#fPd`0%4wbB*$K&LA+B8qSKSbK0Dga
zwc}eHhbID~?bm&G0SlFszxQsYRJh<9*^~K8u==wq-Yh1$T^8habgKPu$vo*|zTb5P
z-T@PtJNh*EzfltT!Y2tN;P`51Z(pnnDb0&Om#$mH-Pv8l(I*^KH{5$WHy}oF!SQ#7
z;>JC5(BseeAjM-{kav2xQc;Im%)sd8pHpJbY%l8Wq@F@dk`5CcL!}P1)wWh>41E_pzC{oOL60wANO?YC
zts1$COseh;l=BhQK|=ous?$hMi)(_DgcLt^S{sVs4@7CdqbEK`qheD%&}CcQ(E3r{
z3n(~7V$Lt%Q`F8ZAHZYY{Aq9HJ8nl-!L1D3xJK<1)lD#;B+DWx5>5TBf5zalEDK3U
zmZdmZs)euLLQchkTKe{8w`U|fj^yG>XC%1_z`u<
z;AAd0o%ctCrjgrx$<*tcL*`*h=dkI*^z^7S<~ZMKY`bXHZSgdlbHs}iznB%fT#7kP
z!}-clKms;=V>9=X=U}1vfDM595cv%i47k-wqZV6LHNa
z6S+xY0#`qXq7ubP5yV!HlJ`odq#*6ev4OsVJb1g`K{|0NI
zfqwYEr;Rt^;Y06)vtNZL%f7B)B17o4Xs@A$7>VxZ;PrC^i6c1uiewVU7WG%OUG-uH
zn9s*Ix3j?JcYq(Z82%z0Q(dmVJUnr9vT*Zg#*N&{ncSAC+?KcTRq};5N@@kuKDr&>
zslB-S!tU|z>5>M#<(G_mX37^&;eY<(8wJ%f1bI
zR23hRUJbuqHC=W0*mmesmR5@5E)QJ!)bnTX8M+5wDgRORE7d<(@M`_!q8-;ucETCt
zzs*M@xFzq_NQE_eCH2zrmleS+&n((rS
zS~FF(W>#(j=O3Rq@~VOZzUsB_O3vyU@XGV$vAyFBV|#yFUiIveZ>)UT_rtEq`n6Nl
z>#lB}F5fcdnQd&ot&xV?;h(ObKlm7&DZKSqyD5mtePrcMZBPLWe2#yMXzr|
z3o2Hl1z-t%QhC+*-DAW5cGzKz*L&~gN#$TdUEnW`nY$dheC&nD^O1=yKic`q&dEg^
zu9s}Yw0;QEpP0#Vd`68p?CL~$6>-zmAL681#y8*{JP@;$3&!@|^x%d0PLcFYJ?RJk
zwx6oLNkH>K?CSvBueaswZg9P}v}EUc=Z{^B@%-aEH{$-2RSR~lcK&V23OxTbQ{J87
z{Apub173cfTf4i=`SVs6J+IH&wbJvtd-1MT&+DxodR|H4udmM9?ee_7nVx^)bl~|H
zE`H9)+Fk7VMLs_lIq12VpUbj#*Li-iz)9(A9rRqs;SHYMt(jeDrg^#X#I)Hg9$=Sm
zMx>*=(#f6;YQ%vv%Hs~}7~NJ9oph#L1{Fr1oc!pNMA6K*r%6MPeRR7(%hv!28Q(`3
zB!uK)(@7z49YTN>r5n+3f{H9;KWis#BM7|Ns6Ssq}au#g(uXo2Gz>mzVHyM
za@lpKpmL@wqq0RaJ}wMHHYh+vRoK?SVA-ew8ZoJLkY6$3yaa}_#=g=)nr^+Us|Fpa
zSg4!qw1pL^Zoxe~kJarP!tTz;%jPy-@dz6M!5&Jt!S5knqSogic?6y8~L$%3UW11u%V#Z@c2*TQ=
zh+(gG%3FKgTR*#O6@8PVWwxn>ej9EqXr5WHZfe0g`o=&NuMQaacwmIsr6vk^ZQvv6
zL-ff8IQunuYV=MraZ3T-pi$w_N-Y3Nr>bLtY;?XYC6$wMX?AZPros+rap~*=%QdG_
zo>i6ww)lXqS!U40P=k-fCp;hCMP#6LBpSVgv*vo=K>(Gn4_$?$>ZVMqS6rP
zWTTXa9njWag91zl5)&Ph>)@RSKC;P=fDRPGY!`3@BmEQME_}Q@0k}RI9u#=?k53hhdAyQZ*F)b#YFo;q?v5lQx@Nco86rc?HVP
z?2!VkWp4l>8J`8WHys-E{b-=D!HdbqwU9D^)(@hcWONTxShJx6a3TPgrqlr}IWo45
z^x?}qFx=uQY^wZoD37y&XMecAH3+u`3h;n#!~>VY(+bS~witp89o{B`cP!O!6Ok$N)QFuaE|4i;^)1Pny8ZQ12C!
zPL5(_cnT1bzfL=>01~0hYBn=|VgOzSp|S{|R*Cl4&AF333d9V%f@Atuv`BVGenS{l
z56bLm$t<&9>jOCT;yd=_PLQV9I8CKb+tV^(mlW7!=sXh310R%vtubH=ttR&ZExLOF
z8)N|%;KBor0%9q?T~g5;I@=qgc4ycDVRE4TO?$>ha%zC_
zL!tV%M0=(=I>z2fwgS=a2svrNl-<6Oez44F5~01@`$oGywS|120NSvJ>Q2MhI2D^~
zI6gR(zaP{FfME!ZiMr*6SO>oRLHxLO9>`vM9Jhq;5Fw^sVVjN5Y8{E{_?faY)tK-G
z_Z>PyuZiOJzBp+jvYU8SVS8@vF%$z4@|UQ{FXCpG=_X3kBAnE30HsZog>5l5gx2Cy
z(7POxuh671-|#JEes=M-+{HJFY9<$aYP#sqr0>vd&iu)o`WwybrkgjMhdXXRc(~=*
z?Llka%#!kIE<3K}*4}8oV{%jb_2vU2MTU{$U8r_0np||}i8ARt~xbU4D1yp|sS1P6pmi11NB;B33^w5UeIzgvN@F^c@d(S=+=R
zeZMx)q_Be^g9y&WF2RM?hGj?5B#`I{_P=BqsP}clPX@Mc;CE2E!n4pB+Sq%0fr9;n
z0yf<(BtMEUcd*b0X^X%|3@twm82Jn~A71c!N0zcf13`t8mlN1Y
z&_W9jQJ=9bC~Tr@xhrRKi1VPh7+l$)k3bK`u$X!{b{8lI|1hKve71bW8iDkIs;S%h
zm)lslMXkdYbqZM2qH$zwRzTEDDT|TUQID8A76FQZV)UQvOo%;@L`_5~a{)Z60)uhU
zgnA7O#bqqxhOnD1;lf1Zpv1PKkWK7{a0!J;(-E`Xu@LXVv3?j~4)oLBE_P#RHbDWJ
zCd1s0nbu47K_XoHm=&5Xe#|{sW~VxAe?)X4+{Iux7loCOU8bP(sXzfuIT_g$vN1soPFJdu+FS@iH`9&8`P|AXa7S9Vzb*!
z3Y!IgRL|_B@WGS``UGUe?fbMoyB0?HA4O1TW7w=Z+Wpx!3V^n5?Mb>lPB%K3(@1=z
z(P@kJ1$ttZ{401$+Sc=uXE*iKHaT`JZR8P@h>iTNv>W+~Yq=}z8~Kg=DqWkXc^Plh
zv-t}q^BZrpZk%r2{8a861xtS0x@L0i?&;P&Pvu@OSaPF&*-ZV0se0`CZ}{Y!xl(};
zE|I4WngF#e5=jU{3UWTL(U-uw43Q9?El&PjypgGf?sVP-Z<>e}*GF^oIEz9*Q?D3K
zkH?m>j-UfRT5^!6#xS2XCc-
zr)7t6YR6UtILU?{4V^ruw>t0`sYg6<@`KBlQIDlNYlIL@HIEGvB_Ya
z9`jrbXIzc21JP@c(x2i&-)Gp{lSU62`o}caxE^-EV$S;+ucfsM5#JgREGEWa93h7c
z^GxQ!fZ_T{4q>B3AejT#f)A9CBP^YjGmRjD&}qwLVF#=;c@NaWAR|aT0PNRIUmO;N
zne`g(>4_Gw_}g^=;!rPg2_j}4`I^L=<(`a+!5+u3Zj%D)`8b#We;xUC2d^P^O5xTp
zxg6dYm`CIG>U57qY1vD}qFP7vPl&zFf%zf9V9UYn2iKTfNf_US9VFk2pbF4F;Y*VJ
zw?ULLKpPaoAXl`18E74=jOpGr&C|Vg@}W?em@d#FotPo{k8z6
z_qH*>_!utx2~4b!(C1&DV{#R1AJ*p-~qvrGKIjKfnKnNFkS{Dr`n+_c7cqDH_oAZ8In
zFFm7Ay0ijwf?*LYX@%)4$Z_%^2)fyHkZOlWbIed7EgYZ)@;FFDJkPd1P@pf#TZmoe
zW73_J&aewNY|yFIkSwZaaK|Gh5lu4dvm2O09tT%`#K}M}oz@_YSy~r?_NL3nKsfi&
zlnSPVYw7MISuFyS1WH6%QbGfw2z>^{u+S6{NovA`ejJgS#hhDqCTzfr08pzqo2;ls
zU}9C2ZXY}S<4-gwj0H_&xznI^*ez6WJV8Upj<9Ok$}#%h};
zxJnX^l8uQW(WjZVg{X@u-BG<)22;?RUp@8p>AWS(Vr|zZ4A+M41YG~YLrU|UXj=Gdw~zs
z(`Ek}eFuh;MvB0~biH{hq|x`d09azAAxpzfiWGt)0n^MJ6IKYhzt=x#-YOsD9Yf3$
zK|W>fIsu=#_$-(?*y5Z315FDW{-?<4CI&r3;ww9Q48H{WhC}PYG-Sax!xKx}rp&m|
zw$B(FG1dc`|B?HP*`D8LfO)=RD%H*6L~CR_Fb*ookL4y7zvASB+^x9^+y@K>wC!P{c@UK6^TZ|-8!~*gqjB0#has`$dO8KC&Jx(R&<)2Uh
zRBfQ|Q&N4cxaqQY)XOK~#*w1wbO7H5#0LSd`>JOPOJ@perwVIHv3UMy+pI75iGAnx
zeX*SsjOW8<;)#*RMrP+Nn3=bDYTn}MdCjA{ZaQR|7
ztJ(^-W=cQF%-Z_@Q1>qIQC;_)_`I$(BaJkYX7qlIMhHou2SU7`7J3*k2-^~N46%jK
z2n+}b-w_66DRI2+RwQmM?6ip5sYT<~qV_*g+U}ON*@iey>ui(l3?o;=EbWqRKG|)z
z?GA`+9H;&N_xt;u`roz4bd;zSh;&@2r;a42dt2
zs*0wa>^-};cNn}bIK;(sj{;GmspODqp!bvzzIqb_poy8&u|Dw+EAcmf2fr40)`V3s
zorVCNL0=?XOi5`clKM-Ps$fb=<5KGH6-p{)G-YWi3WbtNLW>0obsnm&dA>AlW#Fc2
zr?+f#d_w%-Xu99V<{r|a6<#__`~kj3
zGn3I*YF!|AoZ**VH~KNnq_`v2U$v0idC-#iC_lbNu2Gj#s&zDD%sz-;O4;^72gjt4
z{3z3oc0)T;wRW0cI(;rh{Da)1CbJ8g(QY<!8VaxxdnpM^sGBvoeC#kn
zVD3yyDO_h{pykMKY3~&3hHzs>>WCV@8@MYVIstiLK72e$yk_Ea5+=x2&zQ&^I>lZC
zbmr-yLxxojTwBL%u(5(%J>?D1u^5%iJUwsqV6|FvMl*OXL1DXeHuj-I3b0VfH*7)d
zCPA=(*|i-Y33;T~a?(jiq733}!sAeic%Le>pPQZ7Sb^~fvI3hOh)(nYXeA)sNye@cbgYl9>98RaauA7l(0!zaAYfPyW;<_rK^2BToB*B2P@
zA3xHxx_KbrKYskgk>)jP5p&}BkqzrN4xBh1IO5;9VZBc)lXg3Sn~5Cs-J0IeREwJ_
zuvLZ00W6g9zutjUaLZHMKx3=eF0WCtS!lpnlv3@jULocjPU@ekUQvVm;Ccd+Fu~QS
zUNPe*qB8M@wK?MjzCQ1#8{&H5DZ1ifIE%O#suW$EHX*fm1C#%v-;;i)rcraaMUeKfrKZ9@NEN0o%L=uWdKuW+(x>R>px36`ZkF5U;^E6YQepQ466m){u5Zw%)*
zjqkka&YL((KByy^E;wS%Exh>Tg(p!2e8;W40MBtZN%GPgvU_LkzDSOHJT+!n=4d2S
zMFp=kP92>|yS{u=%u^wU>U-rqmFyz9cgi3cZ1;kuxF
z%Kge%1h=M3&dJmp#on7G6}KAJeEsB=lWz}2>YF1gSKm&xRru~&Qy>VPX)3RpIx>AU
zShn_h!P*s=IruK6OBO%KD-P0W;U2r6)EzfDl1-TB~9C^pWj{eu`t(vWZ~2ocC2V$
zZ+^Evt=(pNcSC;LD${pdEhYHzUY!ju-dmN~ZnnO+&4QTkn#_3quGvb@Hb?s!>vuDJ
z?Tyy&HcIro#)|Y$3SRMk9sHRaY=7q}49c
zuK}*5V79BvymnV&JG^GmS!|{
z%=XeRl0~|tDbWLdTU-xVVIj}1SjfZK$e0}#pv*6&jM^_)UV_ZXn03tVmyT=a5TY&=
z>L(Gpm2TvfV(^`oGOXd)qZ&qsd|@#UzSFcA&1#pUeQkz;VV4
z_RM5(rbcAGV8?1co5Thz5GkW@8xTZ+ZUS#&8N_%e7r>9Y;h%~HpunXW3=krupbUpl
zIG>LYi&13)12xks4~v!9H}I0dyJ9Vb>IGAxzilcV~EVel*aYm7eF>2rbfA(I8Y?PJ#yV#vT6#z_}3mWbyI`3B;9
z6UXXgFMRqO9e^J>xQBv?VTjZ~kboG0#Ak!UC46!YQt%CN!kftv!cJHe-4)8Yjs64HYgf^S}dw^7(@)<17+AM(%{Vrl;
zw%E%$WtDg(zefSl@A7gA(vT!-I}UESObU1cgJNumP$uSS36v4tr??#3lGyS&5^NXazsi5OJ{D=t}Y7FJHRym@xEaMd@9uC=^(
zc6Q^#Nb*M7rL?K0uVma(A79Ui6ck>NVr~=_^O!QSUfz9v_r%#LX(}a{UrmlX%PRgN
zr+PB`Hy(MVDVS3|-ijdN&b_$)!uof1&UC%K_b-Y!O+E8^>y-H`9oLIDh25Kj&doo&
z0|~#HpGAu|!Egfja`(>|BaMV#+R@zRFn!0A+PdBL9lMP}XA#9L&uO#Szq28Qp0}qV
ze9z%%+h~0+$Je&T`raA|&wW;8Ko@QPGL
z-68|FGU?@%ms9&}N3khA3BWmp8_GGNEdmOgEi7wDqS_?Snq~rpSdatbvLcBOZIdYCcB0#G+Y*nGIvV}3nLCc+X
zKVn!iKs6kv8aOQg#{W#L5Edz?$}PnU(T_S8A^9u4IFai;bqq#RAV3FkFl;V@pQEr4
zuv@_>d%xU=lXIvzK;99yro~wtk^_v6^vm!Zhy9FBJ#a!7msFQ_BoKmvdbj}P=tt}o
z4V-@sc>c<7&Sa5YK+OUh3W?OK3jU}c2QHyZW6IKq5uZ$
z!$d_ss=QKMfKs;VB{nt6{$H|526c<%8`{Bx)zo#>Pu6)4R#VrBC+aluMBSyl6*ohl
zRX-W;#Y@Sn&MR`lo%6w+bD{WZ1aUcNi$`pKFjN0FZF-deSu$^b$@Vhip$wDvI%OZf
zlP!8GlMy$65>1`Oy=)e%A&gQ6956aN^-EXNy&#+-GCZ3tBn0(}w?Affxps?u4jF~JMnLoRk_1K3$`gmIdnML^J(iXev?Ti+)
z^Qs+B-!`XGXm_-1uzow+*V1hLcC&~5Bq(HgHKVoQK#;LvLSC9oVxF-WO;5QY0rA$6lv9gs#VfHxlAtB73CJ&G!&Fu#>5AUa8bS@%ZlPn{m@18NUB
zjGmz*IFk(w*Z3OhHg9UIuh>o?Qw3*q7a)z(&}R)?RE>}DUShW&3v3rR9Fh}e-UpFk
zVBm*)N%@UF7=|)azrO<6-WzOHQ?3L|IAeOyerVZqOp+2fwGO!$`-UkA0wkSeQUdq5
zW8Xg}fb=a2{u2V&SpdqMfH5aI_>~{T#2#_;KA;IVbC(<>fN~sfnbQYzdZi85OIm|X
ztwDQX#FaH}gE@h@{OV9XjQCxB8hB_p|G_&Zn{*29oy|BH-Y}VLJD4!QP&?D3Q
z3<6Rw(FGo1x+mR;7ru?A(*;8~8k+^_H5^XGC*^E_22CMDd_$proC*JT#vBMs`7thv=*GAxw;{h(CIPnXZ8$eCyju4|SA$0Lw_LtiComWu4bozs*+%E(wZ^m%QQk
z_g;N*<#_A20d?RgT3B@ya1H38!YG(?=nw=&Fd$(0&{-g3Q4EQ(2?4oW0H2>GS3tz$
zA%LoOa2IqRyN3>KGDv|@`;>mKspf-*>RR*~3PY&9z|jN5iL_1uT!<4QypIe;(KXea
zQ;m;ZL!9dOuYiA`#mh-JGDPk1iQws=3L2k@PeiNLEUSe?r;1sU>}5Qk2s2Lgl>`kC
zn!P89djo+ZRt_a`V1d5kOTiQZ)=uDGXw+!M8XRKlj_yegiBwG0it77gtvzaQhrrz_
zIQfk_dmctlpls?FVf2PM5<#qHVT&gdjn`IXzdvfldQ(imMI|Q0;za#ZdwR&7P|rwi
zJkV64NvkXHFfs=pVI7q8zPvM(UIO%M$`*E41)WttO3$6>fBiGF>C4$tXI;osH@!dX
zX&!IC=_;J8db4!a1#GP%=&ZO2*9C1bx3V?tg2jjm*2GT^7k>xEEr5$2OB}`gwgMS-
z2Y66W$9MnQkP>KPyhXp$(
z_B-upr3+?AhqWCs8Mi|_T0uFZW--rd%_E=D09&&0t~YFhbxC(Y!J&sCY3!5aFHg%3
z1IxU}_@ynz@=wsNXj%^|=XT+vg@cPF9XNeB*^=hycW7wa(GrkW7}~u1T)#LC{c_*M
z!3%@oyyYR+^6A`=t08D_SYjlppW--R{~9An>k(r~n94oYqj7v#Bkz-~$1Bp}W0iE>
ziLqI@?l}HGVsPd+e1gHbkCn9(h}$okeo5uiBa`hT;&MhZY%3
zh#WDWr~!D%^xN>x>bDdzEc8n>@<@xLP2in`>++QpbCvLADh~B5gWruyN#rnJTKQks
zF<8I-MXbX%le#X|-C)d&+#JTzDR&}vpHKCtQXT2}h$X&OB1ICcdb|3?^PALs{HfgH
zblphHdF}WXa6~B$CRnIn(sjW?W2*C7IyN7r;q7`F0bz{&v1lF3;!<(@lC&g!)T}s+
zvEumHGJ<2!G3%f+4(B)E|L_BqdIFR`TA)z^e$DhK%+y$uyiZq00qMY^(f&mUi^_GVf#}1G^I)r=m-HiD>Kk&KhMiu^@4V?K
z%B0>@>#*22@$n)btt{L5`^Z^*Q=8HI_xGZMR>W-pK=8=w4V|O{vlh0)f`~<3NCs~Fo=7-tLy2k?5IHtclb0=RR|6$
zhBAQ89y;_Kgo41R?L9k&dT3d|4=Cy+_a8k?7BzGlAwZ|Wl#9+{)~cZJJdmfbCPLWs
zu|WgHpn51=QG*gGO)d40taJs(QcN6;pzVlI7pLk{RaOk5R}O#yzE37DY7NEVLqpOU
z2&J=rmJdRMq)Y&dAgBwd6!1S3voG}3p+g4CH+uD`Zgt+l1(h*Wp$1-5DM8XgS5d-`
zU!dA0aUCGaT%xslwc($1i7fUF_9yh0R(G9RQaZTC&;yzZ1Zz={LYq;ELd!#E{Zj&X
z2t)|J6-^_efHbWaXbWsc48{fgDedc}%Izo7%RZ7Yz$`s>64rrqh98xrWir$UgHuou
z!4PAbvZ@@qQd363GgRxy(IgXPgWfYxM$zSK6RUtZ_Bk;}v;q{XsGXfc%FfI@Ea79#
z51_<9`!uW*F|_kF<8OWq0)?e(dJ^K{v`-nhKFDd*JZSbSEZLWGY%s=33|P(_+_CQ<
zSCqaB*~ou@XCp2z{}p0KY7)_StmU4bhAkuwJP_E{u;nOtx9F{He@WOMNl!B$?0Vtu
ztIte6^Nu}KzUorN3>+eC3Kj1D8Cwy5A+Nw(Yw7G9X~YQ(j__3Qa84YvsQei^jvDMg
zD&%dM(j9pq&<|b>2yOxu3iYe18iD}=h9g7<09T%YF)f3{6>Hw757PnqaVm5Yd|~K%fJd(WkO}|f76yoJIz+6V
z2ZS5~NDH1=3%LaxeT^Cjtlt`O7ffbf*f9CbD_d_CS55iD#VdoJm2t7lrn+C-9`vlZRa`z*
zHEq6Jb7}iK2d>(}a6ekSHR#!TGrL$6^Jd>{_KJ5#u2x+$|3S@rt+S0gBP&;hvT7#M
zCl5xliYK27Wv#f7{-gY=U{=+Sm^*SSJ#RAmi`#GJlmtsV!#Vqc&V3OrDw6dmjjGbss
zY=nBzN}|8{We8|JCqLHGSFQ>N{~GglA-zk?3^6Mg5>*`U!Zc>H%;c}q{qpGf(aH9(
z%NMl!mY`l|Mcs^W+9YQfux-E^{n+iEe5VScB@$@|-4qk?Ad(4n#&I;Ty2ORuL&Mfp
z`Uo5iO^DNo8!zDC+eRMNwzOn?i_t?%vhVkjutf*itI@F^7zK|y2*NXKN=Q>F@ajDp
zGM$-mgMMnvN(D;kSuPyhl%Ad;8N3WnBCMs@92(d@^a;R?#-(EJOW>^;Dz$bUIKJ2Oq+H01WDkG@DzX_uQTjPB&I^qWOlQSOW
z>q%E1wgm96l5v|j+J_;MXX(q;=%wTg-!J|f^q)?eFIXVvk)2B}kf)YjAp2x}VPM16
z=YGPpx9pP_PIvU?+2p;+(RDQ8xAKJlIJ~=?uI!05lerU^%HE*eyTnlZn@wfFv-_CJ
zab5q!{fV}&d&~e@WFEXJ;?=PIt9KSn$LZi;wr6Fmg^bohZ8AvKH+4n3t
zy*{_}^aAUlW$>I~f|;W!BJPS=P+e3duOL3sdf@wt%(!4SCA!qo-gMK1B1DK!H?s03
z{9j6b;6%qijD(UlI(c;(v*-k(%2(09IeM&L=$bd_%vwJ*!*Mu}R%CiD`4?$S+`Ihg$?|*6
z3T8fTX0HW@jkaX^
z@H$HxENrl&p_LBSj<_IPor+kDHXSxVC;gXIo%C8)?^iI5v_&H{YYsk%b;1^YNUQ+N
z7IAJYMCNpn3{qhsE{>u=4*kh~Xm3C{C<&YO;2`IjAaSAbPz}6Gm4$flB$%2@eN;mU
zj9gFcOK@}{`9a@m4Bdl+bqn&+T1_kk13UGe99^XTR7~B2sNKC9w~(b9SL(;)>Qaf+
zet=n}&kv#iHIi)AJaZZj8sKtRF}lUU>ZXy0qyt?}fIQb2}N
z2hWuM&;SCPqLLRYJ1qe~}Hg;Gs->b-7aaPe3`f}f(;;1!h
zJ<)$I>QXwdN9ZT|qp3;+GdEc>lR%JyS)}*$KyMHQo&;)<;3>!O>M6o4wxWhC3{~tM
zciqe>e6<$Z+mM3ldwnhODT~YA*m!B`UwG
z`)4yM-$|Qko{_(?{+sQyH9I0D<={wmOtpfm*zwk$%X@;wO?dsxH`e|B=5K7~e9C;|
z`|g6hmxq!z%%(4kfbq9{ycJHf9Hlp%SrhJ;b`eSF8V`JF!$j{Fx7^Grj^u2F1LDJ1
zpSfCnwQ%;plfkEY!v_ur`;S~daOB$l?>E06__Gb~uLySU54AoP92gAl7zz%Z3T8cH
zU^YUc)&1rDlg*RzlzDRft51b8E61%jGd(Y#IDg{xhUv<1X2ZDkhv`Ld56W6xXJ(z{
zw}|Wa;oWjmRw0>3Dn(5vtrIK0Nb28?(vJe9NB3?)dYjMmo-d4*k%&@^OCPo|=BgpBvvv9D{>yo)wg80==vP*v0swhrLWhLuZt
zNCXfnt}G@9lYBS{Ad_9HNu;fcgt!5$;Lr)6jlSY@Od$f#pF=klz)`W9SG}Sd3HqLf
zk^pRT2_Zo;GniNc5-E03v^t++Q`mI2su^q4VRl0CLvUyV*={U$5=g`+su4c5tz=2j
z2=fz6v$PGQoQ>&SY(_--FQl
zWv$1%0BH#a#91~Su0o}hOvOT~faLu(q1`x!>7mUuMzD`aSl5aE{!^OpKdF|J-nW)J
zY><+|86l#um99yxic$<>sW85*Rz&_O8Wf;LDFD?@n*miZQNB=({~C3hLZ+pevI-_`
zU;13oUdp`_btn#hp6!nV3WSqWXU%&M5XEM+%P>mRwq@j>v}Uxk=PA)cELckoLLb2|
z08EL((s@75hJjE+a)LP8^p-kPTa~Ifua=>@YU2A9CLxtAMpYL#zyrmcuGSnj(5o)o
z1g|KHja9C-v65Qdfv>R@MBS%R4Uj6hG0+u4xsmE*Qqdohkt#?u$F5$|J!dg;(o>r-fO3s-B@^;%2+RYnPt
zEVNqiA3bssYy2D(ZV+IZklqefz#vB+)}6ahB{frvWOLy($
z&5W}6nUVPZTZV~|Wh!5mFfpPTw7n4i)k}^n`ixt%2J&_!S;#7d{R#TSIj
zOg&m|%DUg6O{sn05Xo>`Ay&Rpys@)rh3oQ5-EdD&OGY@K{R?`clRwx{YM|#31#apq
zDiOPnU`2Uov(ksRhw~iq#dlb;H2;}8Z5gt{YI3Tp>1I*sWdCa`#%(XTB2}xYAAN=e
zrgQ1q9&2tTuB-R$yj#Jn&sl;ZEiGKg5DCN7ianP2
z>4Dj}S%tsKBqYk7v>FFsn;zMV{aF=X!WJ(wCn}cpVYK|X60{$wTe%TPFM=FXof1^Y
z4k~OKEnh-fDP6qYS2arNJ??E>p;c%_BW%!}I8G{4^oe>^3T-b=ZdC1}_nfWhyqZ2J
z=ARqr?@`(ppUFR0`Oq&DbxhFZ?1aw3k1^p5=bdR-Gs4WAgekyywhC5B0Ev^wgVhw#
zlElM)5&KuPKm#b^dDFZXE8~V
zcP^_slvO<~&1N;Qv9|Gah|OeV&pAs%&XPH2Wyo3i=FaK;Uq5i=z}ueV-*G@FAbt$==LnX{;nPQt62w0V
zXEE0Zli4P#DVg&DgCFrT~$4nIA_RvWOymBqLs%j8G(G!0gx6
zxV@@oHTzv+Oc67JExKcGI5Jqndx~O}ViT#9!Y`;|1$7glavtVHpOfjA#WSAcM*0dpg%7%$PPHY}HkBLzWTfB#5
z{S@Ql{vKgXMd^=617vLYuOr;fbCFH?A;w-rCTt8c~KH@C8?%X_EwmIS~x$fLP>)k$|YAa16
zWU&x>=XpiI9?4>*LY75sWYk_x2b_(=ya^;Q0{J_502s2!E0QzTRJIxHN#xSWCG7Xn
zcL^8H*$hH(X46agh2Id&kxAvw&=t*0k
zg2?|A5KPA-yPygVXo6nDlm^zIk?D9A4zKDEr||q3tq`4s5Ah_VfYhNLF9cPB4-kS}NM$e1bat;}yNYl?7#|
z4PZB@P=#d*i!EoMs6(s*i~-yc`A_!|5i1;)s6?|^umbA~0ITU^%t_!%icL%6t&^21
ztq^i0#x~EvPa`BeK*`Y&c{D3PuSYS<-
zg-9FVluz{T7D`Ktd7C=zw+wEp*@AP3{%v(z;CN|Ut1kk@-PZGmiZ-*5C|e{GlJFyCTl4Ij1k=^xcGC$E^CBS&es7Z5f$h
zEoXU{8Y?OvZ+mICj>+_)lG=re3H0T&cwj0@d!;`-p9|C@39_Q1H1Wp<$Mp}jr!JGw
zIIzg`h>Ln~I?R@@`r8CIvlG*70l&$qzzZI_M4vOpce|(uS0dx*O}ElrbLk~8sS(71
zu6Nm-cVo!AG3?zu-bPMl$o{xDWDwakb_G?I8p*m^7ft7&t2LrqrfMaBNy5((raCKM
zp$f!$VT3~vW~yg9@h0E}G~|_Y=#a6xSmCs?VYWt_;GHtr%uMV7xsv8h0uwY@*X=_G
z$ls?NRwGD$#xsgHbnt5&EW!tq`HmqOPo$&C!IzF>CS#n*7g*LEWJ;m
zyR{~_iQeO-O~_0F-bOmK_XSk?z($whQ(oVX7GW$AoTw2P83SO=>SD`|Rve%L%YqFc
z4Zae2qj-7(uvk^Uu~zr&v}(al9KR78N>U+DjZZ-haW4DuN>@=z4XIhG^p6}`twDC(
z!C1(20xSO$1$!vyp@86#oQfdsEX%G|cEK5=0zUWCI%`G-pr~?8#pTRj&#Rbfdu!L_
zU7@^s{7%1_?w(6udp&(E;L^*T=R0SeC5wO_T6?_ScH?0&(DMZ+<`&*3Ud(XS=BNHv
z2Q=LHWz^7wvsCVpk(_vFOw-U$&GR8IG%v+eS^ZYy<;I|I>-g}?pFjWkpuPLrnz`2Q
zP-{0H#X2)W53Myt$Y8P7D7C|(B9BT!#iC?qWH_nj2S*>H`a!H8^+T7weD3_YpuJ#W
zO{h<~Uza-mW^jypY(TveJBZHc!SSVvER=HQ_yN5pWQAzWmy*|n#)oS{otk*Q>?a7L
z^&rurS1g^~kRc#PXuM4%){EV2Bnm2{XB3BNLsTgetwQ(E+?=%+L`u9&&);hX5=l({
z36$|k4vcAYPgK)XXj5Y8&*P6rCVSkm5DeS!lDpzC7X>okjq$sJ9S}ugV
zP9H|HR!Yu#x@1Q?0hd{eQB6GgNhsh9jl??99YrgyGzE+5XFM}0p`vx;E;xF-SaPA{
z)iRP~YGg-mbI#I`vvhLk182i+2sAY=>^+Ui@)Y-;E>@mw^YR)8dr%2?8P-PGUr-6i!U?{k{e69{$S}%2=
z{|Nb&SB9A-46m5Ury%?v4)j0UKhRlgi`vih%H(}2Aa|l8qB(6!A($ACi#IY2F%}|m
z<)RsCmAc89VElfezDfiWYWyh8gIeUmssoPfmov_1M4V6Gbe2W(3x1MnbEJXM=E#_{
zmxSyklaGF&C{jhUj^K!jv=r%1kU46H6@nqM(xx2&5agi21p
zvPoiK|7*UxNtYnm1W^~^n8dzHG)a9mf0OC+k}l!Sa_gF|0_4^oG2g2$nw|oVG12vO
z;TTi%MNT|H_(HL$yu7t0_!m!Ex~4E5gnw#o@GRo2G&Pw5<}((v=?Rk={|2pRtxuTF
zkSzUxDodXrabG=_I-Dcw1K;5u^+~_8IrG$He)dqd(*N+tVI52TT&lq%hixRNt$_Bk
zn6E4ut(;RBmKk{lBT7$*{n2EgBSv*n=&NWKq;|Au#;rAG0gf^P!(_Y!gs(`W_>VSt
z!e!caa2S>>I1|bM);6)?$;cR)-KMqIH!wtUEb+(qdKIE(2;Is%FnXP}PH}FRiGGp^
zEsokKn`mZ>>a1GW51_3#YNL|mui{ZSe|mvF`f~~{Bd*piSmQ0omot}Nqm<;lGn&DR
zgwFff-hlat{3rMH;E{c|qz&9y*;^wKp`9)f)Kft%ZeTqz;5_s*LJU4ESSyCLe
zH_NNuc<$13@2m?pw}#8xg23oX>gGzCLM2V%lIHQfv9wgUJ|G#rWg+*nsV8T4hTU6(
z&aEHbO*dr$&Rg{?nuDtz2$#1Yi<{ZG!Mx?u)|sbgv$w}U=hj|pig+vDO1Yf!Rr^H7
zPeJ0={*GR-H?JA*n5&N@8jA1&@#u!iVL}DjCw7XeBDZxuIX-w(_Ckss3B#!bJkj0CyB7p
ztm%L_x2`(-b(%*s*`hW$6%H&^GlZIW|1-b<7pRF->~GR+A>%1PwbES^YtO^jL%uL1
zadtMN20t!txv*tQn(<6*3A@(?o$JKQvDu9Jo9_Hc+pC-2^i1`CwK(Li3p(py#_-di
zvCx&b9P=k)i-g7E!0_p0SgeTu8nuEJ=<_Dh=Uw)tv*RwVM>HJ*jZnR3$GUyA!_Y-T
zqah+s;|GQxN5?WC>ZoPR%6o%0eDs01l1g8Z8wzET0O_y*?$X5K3p<9DVDvew3YBYZ
zy?=&`HITVi90C*343!tSHm2GVql;l2uW8xadz8e0h5_{GEuG;aMT7UjAsipmm+Tlq
zXRjU`Bo?Ok(dMbfoHtGay&;X6qlk3B$!3m+_Aj}GDRyeH?=deZ+99RvuZ5%on
z{cF?Vuc2eX2B~M(BGpf=ZUPs8t4fB7AW*8cpYjoq3k*KarAA?|Y{i>yi21>rJnb)#Pe_RN>wQxz!(|OuYl6>QjWQ!PCAVS65LI5hfp5)r{>O#rYh1iQ3rk6(xJP`Ec4`Q#k4FiouGqGs*(`HLGqeW`oWqz_@_y=~$0&H50xGdj#iMAII`Bs;
zcmD6NBdQ{0C(UEv>yD;rt2S*kU3s>RrH?w5XK4)HcNI?oDPtLfB%4vyeYaJ^L!tdk1Ug^3wkKj~wD?Ne
zYsARl3*TU{=>jQie?Dtze{tmL?l`%VO1Q?{@I>grUoJFs^Yj||CAB|}S0sFbpTm`E
zobJ0=OJAkF)9=H})n_%;SUwDM7Lb|E2{U;!94kaGlUG0@krJ-aLcivHI$#^km8(Y!
z168BB$5$pK#LrO&G-_SP>yx}GRLdSTk800g60{&U^Gj{W*W*v|ryOrg@@=mAEpdaP
zAMCi_a*kTYil}$7Bjz7(N|JNoabhAST%!eQdFmbgV>-SzAsK#-7LKO9lcvpt;?X>;
zTkM&m8BWt!-e~3*ga_|Tq$}1^m5i2r;UU9}E*T~U1z&0!**jX4w0}#EZ&cIjcXef{
zwFO1BDf#yXO0Gmrt={ofdGfDDi|?~k-^clWH2odTtf*cGj8xK=`yG0kQ73yLcP}zq
ziqw?q9pm9i+M5`aBL;@mg!!d$$hhQ$4ZmeF?l~FZ|5R8
zWFDu}mxPP-;tg8)rE0qtNt-cR`kLu08U!H>4s>tn=SpAtnz-xqFR;CBYGG*E<*_ou
zyeu1jKz*mpON&2~*5BA-Go|c!tNM+8UpPOLx8CnE%+E5lm9*y7XYemH2zM#91OcVlN$9Jnw`hB$QI2}kNTxyx>9kYm5H{sYBSleY|#oVuDpDV+>If$Oc
z(;4%yai%;sw#Yj6XBo!RtCq0nczQ9Onl*%fp+4|_f?}tFAmK`M#hxCk~k!yJ2I1Dre
zBvHXbA$AJCV+logp7%b&R0<0P^ajp(&pHWU4=+V+1eiiFGbX7X^eAeG2iEzwJ=UX=1JF~>mB
zAzST3s-1?_FQ}hRi4oGTO%w?6l3p%IJ2K!*JhgM$J7V^79S1Qucm**I8V;jy>#-wV
zmKlUl3~85f)=Fy1Hm+`QWX7WP<5Zv!X+9`&OlW;z*pDA^*~O753$j!FTdDm|4Pkj7
zX!=s#kjcjCz*xasADV_DC_kR~iG8XQKnqHt!J$!yc~NleVeXZrTn>Z5FQ|G=I$Bv!
z%Ie(A$xv#quBheplBhS;OyP7Wg3KyeRx506sP1(ECwP)j#c}!oXBVOowA>9{7vEtZ
z-tOH3BJt`6j-3E^_waFa4wWF}iVXRxirZ{u7%b0(DIp9jvvRk>3!q#e`ExGNAV$(4
zl||Eb0Y%C6H1H9$;Uq99TBtxC7BIpb#wuaX@X)~NlY@#8<$%sSc(k9SHUpagS85cg
zbz&$pw5%1Td`Vt}K&JBAFmqUbj>J~Q%;5y23aNE(4Hi1h9}EI!8J3}ughpGy#HRH}
z{wTq{ra@8xwW1=1YVk4z*r%p2{9gd+p^Ph5gx;)0q$>nn&gMG68qt(GS$Ae=utB_T
zAPvSu(Ns|{d}PR?0h@y02GmqnS8I({p<*Qj$Vgs|8lPa3T}=XpOOnqtyUL4wR-gR4
zBLhQ_XJo?zfxcs4xI+}NPctjDprCaPt5)}~Ze9>ysaE&?vuf(EZ(6+|BXo++O`;|<
z46E^ViS_TJIU)KL4ymEv3=rh&;MoGlboyA*m!GKnu@bO}YubYg>W5xDupqJ$>_vzf
z0;7P)4s#Iw$Bx2rxpJmb-LP<=>l>1f$M6t|aSopICi|$lp=nJ+)7p&-Du7;t*H`00
z*~)7qF5xHZNwJ3{y5G9TJWXudK}0+mKRT7VDez=dcENN#NHGiY_!!eS+0;GAkt
zFUVLGPP(s^v2ZFMw@TcTqYlL0xz7rOV;T*oDvSGw)hw8P^btPlZ}FpZv=y5dTWx2i6yjV(N(nQ3R&twBgsBKrN9m=KKv|HGvF(gu_HzD
zT@;HK&0=#k0$n(R;PYF^#2$#K&
zpHYc==TtNWGT(GhV-KP{2+>rgRGH
zii~DFa~eJASFl%^k2F~^mIPPj|A?>TKcr7n2Dnsl)>28;u@TiEKTau#zbKC0{~vmj
zim@KR$(cBVPoosCP`m?#6%JW?h7ZdZ@VmA`9L#@)O5!v5C+O(_1qUf0=Roq46g))%
z*N6^KlAT*{2S(GVJGd>Uq7LfX9*T%&E7VtyrT`I5;mxKeng;yvQGriJ?J9u>yIcYX
zh*~=LM6Ema?G;X5f1e6}5kb^`>QoOTbWZonB;6&yK*3wo3oJiSfhR%>mb`>ufkRso
ziL&k5i|^5a)DJQ7o;UsEu+`+KyX7vv?&d?Oi2jscc|CvabjG+dLQiX^#_;4Rz3y2#
zRW$A(Q((d&;!RJ{#fL6D^rm$R4iQ(vAz~p}c_^MMToEcw(F#1}6kJ?+Vdd*5rymdJtQ}9qiTC&xcnP?;>B6S*
zHj-y6x==Kp0+G?3=H2G;v`CqE+#bovgB7z3&&2*OJvEn67s{x6=d)Lrh3mJ6Gai`B
zcrcXl;P*4a8IO%yBAI#P)<|~VylK5-<#-GH;7&dMR?p?0nMbZlvsK%^T@&i+j${>F
zbX{=W*t}<=bI!9SyV^
z*Rxh!-Em|6&WX&qEci=UH3JXc&F}X@n!=q4Q)hNlLDBfmm}ObU=3Ab;IZt)SQ$20|
zy8ViM#{G6i*t2fJ94Ran9X#E1)gCNd5iV?*NQrq(#lGuB>!$01%hye$M%*PqcTLQa
zky~`5vTpj3nUrwl`bm4FxH4GWc(c5Ay5{%x%$B!Ayp?aIT~3?c@b#@%w!Xdn1MlWr
zBIcdu>9cQd{lL5NR!R9AyD#mYdiJg7EY|6@?
zObfENf}h>NF=Fl$<`3_lHJeJR;GQ_QC{j@TM%tycsdaB{zPx#6=hWtK<<{APZAx^c
zyk@SvDOBDREL%NO`^~m%*?;ul+?G9|Eqj8S_rCvV@Zm?^4+KlPermN87Tq=>_<2l1
zra!;C*5p}!$CR2;aLUjH{B(7Oj1Uvl4Y>8{vH2J^V`Sf8XgEWJP@pJxt4RS_1fBC@vhmd-HR5{
zJlEV7YHkacx6gVyj75~7h*&!E|0vJ_!11ol^-!+uPqsAgO||^##+J1Y6px
z9EjSw@
zfS1nYoDGK&T7Tg%B74lCAI9oJe4~yREI2H6e9oaWniB;I&)I}PVQpIPQAo3BxK^u*
zWRbl-c?hz2{$tRj?mfvID~(%xU*aQ%i2)u*4fb_aBGAY{BA%#7=^Z8k6=9H2RXNgm
zC|<25JG=MlX19qwq)s|21w;DbSc7uH5{J?p{K$8#3!6G&+7rmUHYJgpKaR^S
zv|lwDZzVfLQMR?K3&g@X;D_<7_`^f~b04pMOoNc!KA0#Wp>VZgqDvF1tM!F9q2fA~
z+@kk{vdHTV3k7y$g~GUe^fX%|VkKX=Qxg`8(Eq2w;?z02fqrl;6`;}3rT~q;0SH*>
zg13U|u|Q;R2p*UPfQe?QPq4|syU561CZr%YcI*@{LSn6Ibkaekt^qPMi~&=JMexvN
ztq$rc3qX!uexC69FHrCTf@r3aN6!h!*B=c;&1XK6P7fcc-ypYBntz9&Ha(iEq>_Ju
zBL6*om=2dgFqv=nZDMuw;Y4?
zyxJX62bIra^(^6KMDhhrpD9S<9;KcmB{*9%D6Pi7oxtuI_%Em)#LXTsOOCw%=G+D&
zY>teVUFTgeqwzy`8Kll4xuucvrbt0$q`2a4dWt7)+
zoS15!$)C;MNV33P=BrOcvI+_54S8416okBwT+0o5A9;T{o@TQiCF$TUvq%XfHlsk`
zdZDt0>9e7-eOFHh%l5sWf~OCh4}W;K8qT#y3OSD~_-6I6G2UD5+?Zs^$oqNBiWeXK
zv`o+NqX5x}FW7ganZBJ~yrbIsZkl7qGV8l;Cy57_OY~eV?O2uChh%XV=p0RZRH)zx
zO(NFqT#c8akKIDpQlWbT`w8ZZRK$05k|f_lZ_g9<0WH^Z#nDz=@%V9{H7JCpUz^ap
zeO$BN*-B>oMyliMv1q~{(AX=rsZxA7VdlkMi`6Dk?=2IhD1>Y$cA~^d7ymY-cSEF1
z@p}JB3nq=n9Y9Y`BxnpR_P)C3kKM?*U0#X?Qz_g5`^}#%bR4ed02)
zH5qbEEHnOX^q;3pCvt6tw@Tg;6V91+y7`Hs|W3d&I2r-1coITL*f_k3N;!A`WNs|1S3V-F(
z7M>w;ei&!Wa_{g+Lf6K<{96>L0)@hoPuI2Sr)cNtVyJS~W#OCxhLZK|W+cHHZsPlo42|_xe!78mv8i1{*$Mre@cN&q
z$=~?YP0j&K(#sUvYrL^MG6Is2f&|xheY$36@H%-M_FB7p4+j!gZrn?#ubAXF
zKXsE`XiyuOfe~;xkfX_^O$WNwf63h%$42U9i5#W
zNL`JD9UUFDzaq|MNUT%dOhF3;L~4jbrN5ykR+BtSPwWWteLS&6QE&@|ITm@2Uf!Uf
zmx5aqU~QX(K|&Hum-{GyJy00%rXZVwdLatjJ`|L9V30PjSa67@&YSdC^Qwmz#`Ho{$IW&5!Ag
zt?gLfunaLzbSolpphdr*rT6D306W_xk5KRn6jW0%PQjNb_#y=_QSd(~hl})diGr^p
zfZp8Rme2I;>g<+@F)05oy`Xb6`I{6xNO9kzryo!dq##VeUsLcS3jQYre@nsNQ}Dkj
zxI@8R3O+p_je>V6_$~#1iXiF)qQWz+v;XX{{0?<#x+1$q07{UZ8pSEr
z-wUWPjeOt=y7m`LH*C$f%4>qQ{7HA%Rud^-7PRF}+QK$6n?$i5Jl>MBW0oALe!4Yg
z!fmGQ4&COhrj#6xkJa##TUs@>CT7BI8Yys7Qs4ibHOAx|?T}HcgD&
zHQ{zUtw`E1<(W6(7Tb_1d8QA>Ot@X`nWx(wuS?3C_Z3U-*cMashM2Wn+7#*f%pJaa
z^2P6!jpDxNVZPsT6wFIVH^0N|kn(Tmf+?0S5je%{V8y_3r^$&{uyO3M;jj+oeCvnjLq`3}s%I~GZ5Q05e#(6aoJ
z=l4a*DucFSew{9DR$k)?`s*nSY<#!HRUmGGp_FK#(9?np?W
ze21qP%u~_4u9dc4+keM|+cf$Lx2t}>y+6#6$_I##fk(Fr#k88GqR8%jcf>(-i>YK;q@XnBc)~0-f@PLp5-IZCanUaxVUA8QNd14tHOGl$I{s^w+)7%qlCrhRR)2+e6#*ll}%(APtpnFTmv2{M1Q$K4lJz#D(
z-!aumjnp#SuG;wazI&d2QID4_i={5dW13Q>4E*34QKYDlc#TS=(-S6KL5xz-e9N16
z(bHpQQ(;APb>WS1J}J$5{K_L{MNp0b#w%K4N`sdnDWv399Kd2h!Hk8tBvz?ixrr5m>)FXw&FRGTLf=jflC{vx+b@Va%*E8xoI2U85SYYd|oPooFaU>
zp+NH7%3B_ja7RxRu8gJ9ligI@7<155nklVtJ{?cD*ECC>NlZT6X4?364OPXj*l|qN
zOn54jDkl5D+C<9%T}1@GPw~(z=M=wk(kl@WOUpopT`?1GQ^*N7xLBg^EYg1S1d`KT
z$%-ChcEG1e%nkxm1gj$CjTDu^XB^;0WOrwz
zrY_>Ej^(ynrAiDZ-V~NbN-H9OwY&D-si0^$xS!~nT!yi&op>tbS{9QyaSBy4l^?Mz
z3oe#lD4)um`utUEuzGW-VoNA{Ys|rK(C%%n#bKW3S7i!biGuy1PT
zbl=RDVEqHvDueayp=BK*&x5gSPLgAC<-R<0erWPYD6=Z&<~Wb3#H&>t9aYG&MJ7BJ
z^J9rAzc^OPk7e{&&W~Ob1O3xg|ngsNJD-qui2TPU|Z=xPr+I_4`m!*0ypA}sSrNkt^D_;$ux=@IiS
ztcG<{Yo^`7;<`|7eN3WAWsLbztayGD+ZI2ef}C5nnjg|f%fnLj4I3|wnux6eaTCYFlJ|zK
zn37dQY{iQtOZw@_u(a%kt(-osirC62x1q4K{D#d-QPmNfH%S3%9T%_v#9&yex?wA!
zOqNrC>X%SX17WH1hOLaEmPKr36m=pj`EJ-sDXKDJD@BxAQ|=iw(nrY_)-;$`9hPct
z*edDM+K8=kkxzqpE5g#s8@4J+R~NBWQFaSksb*H6-sM;5z)|u4{y0Ep5GJ6E_r@;B&X~P4+%0FsH=7<0vM)wQY!pK2zB(E4#1q+
z0gK<^H}_lpmVVn2+qemW6V?|q4oH4mf65VyUwYAYAl0AdPr=>pPkqsJz~Q$eOdB_y
zH6KWaud{UdJz&RdzE%D)p8AM6t6ua>fAgfd`736)?^fTK&Ra)Kzl2Ju3YU;6AtReW
z)5R63QK8Y4-oZWy1aP^k5s2Tx3yzR~9Z#wei0AnXiN6}j?Rgk7
zw>UlOI&th&13B|P23Ou?#1|;RCm+JDi9O?dYRFzNYcGnhMf>zfp>N#wOPSoQOp?bj
zFR5?2nTPQZ@1s1a6)klvw8k6tMvoJXm2i>xjViQ)KDTztZ=kC`vcj_|+Rf*kH_>w(
z8%wp*!*VhSMx*eny{;O&earh
zHO*9CT^n|_1nn(irfI{5&mhGjdLs>Wq?u-kGtl!kV(Cg|8rQFh>Y%+!x-rXn({ai(
z;gZ`iQ(@77=dA5T`LfdkrX^mwMFkp#d#2WOTSqWXqilw-%apw2
zQ48g$rm2-W<-ejq`ZF{vZu(H;$Uw#XiwG7of+?3l<_hl#I1rsr2K-5Bd?51J@VFp%LnGF
z)`zOrhpRTiX>9lPs+LGW;bg_6E#k?&*nXjXa>bPY1J6p3Tg!Kt#q?9A3UU(Dk9%_(
zKM3Z0l71sAlYWcRd#e`fH+71VT$%2l>byCbxnDIcO$oom6T{@U(uo!KcuJ@6bbJO8
z+{+^lRqbcXN9JuXB%^h`{NFJMWF764EYqq7Q}B!Q6&W5BmIej1gB@;?{G-9U*NA8d
z8)-y3krAL^#O)zr-8pwv$XykN8&S)&HR!IJ$(gZTcdyX~W7bm@S=RV_%Vvgu|G95G
z7hc^OTGo24FSKmeM9akSSN39h+?D01mii)
z|3C|wUweqeE(91SM%suc*(6&|_5XKD{c{?>ynHhE)%v-dnov&7bZ$7OaV9;SvxS9`
zU*7h`ZFg+ejJmsN){Na|&|45mPQQ?T>F8_6=E^pN$~Igr441WrvRZGDbLF|5x=>Et
z^b_Hn^{}>?z2R0??(I~oCog8QX5@i*$nw1W-1+Aw9|yuabsDaog7&(FQEu9BJIE^83^^-=oRzOyqgLfX`&+
zZ!@QwH^)j&PSs#m<{msnGvHE}grfTT$*(TVy)nLkH>L-~EMvTef?}!-*<;51r^A9C@PUZ~$kWQ2kYHbTM;NwUrM~
zil+~A6QRBb*-I8*q@n61hg*GVw4T@k7R8ZYHb`MAB4Tmd6U`Q$waf94fW!f1BP5Q!
z?@-s_qAdg%N(XxM@9`5S9{-hkp9TZZyv(_$sSCUUQVF~)lUt=BWV@)>36L8QvZ*TA
zZvMb71ZNiFVOmY;FeM%jQ^9XCd`w+&7WsXAC+1V)vZEO^Ql!){3DUI3Fk@ZriMB6|
z%(;9a7MB;m&z?9>Td1srDf+*tr~VEBZ>h>W{0EApppD8Xq#nUM1oOdu7mS8l;xJTB
z^}*_+B+h#|ZSvW+0v|6i+c4i=G#`+7rlrtKlm8KeI#R<^r3Es6n01f@Wu0C~0uI7B
zt}LdIkSt6-ZOC3p@@b>uDcC>baDTrAlmHDTUw%*ux<@(2PP#irviA@2okM%cMxHk3_EQfN>T8&DLj1MzYnK
zYasI=RXrac0&CAKnfwe`nr&Zy=*mM^J>kr4LHjlVH~%wga3yu|sYsd2NoOI=1fC8L
zt214ng*Iu$Pn~9IyC{QF#!WvJDW50&HF5g+oqmho`nnker_C>EL}<#3E)bzaaHcGh
z!j2TFeh0p=_|up?&G4sV`Z{>}reXSK%GBY#QPhWLFt1*cRP8?tpb7bLoO4Hd5lNp$uV>BE|8_{@B|I>9M{5~=t^I4FMV9-Hp{?UA7&k?$wYqPlhoj|@J_
z+$Y42JFp@2^#=OuNk&@r39ar1btFNpZ7QuuHUKw_O8w#Zg?p27P(_o~54|Qmug2*a8Nv>-P|qu$3)jV_6itmppfj
zEG?Zx)aQqBYlB&1Y=q?AphqLqX)8QV@(u}?ARv1*UJ-ASb~O?I(q^L|=xJ||tI@2E
z+BCyPNgXa`j-5MmPd{AB9ytb;Rr`zDIerK^~}B;YBVsWFVuGr74qD#h@df*xwcqsWg@sSL>;D@&7>U0Zzz
zq7KWZno00s+10L}(Ctor<#q0tVQ#h*Wpg$$1KZ*OFf^&jYpjWAkUfF?OrSYyaQpeap3pByt
zGmuQwfk=Rbreh!wdIw;%4t69M$L3_BJAX#i!XIC80QLbyB?quNYXZ~)(Ff}H;G*Fd
z`d(Z*_p-YKKq?tUAR)1eRL2pZ?bHH|7`Q~E<3+9pI5n9wYcGi-2Ns7mR3EC=JaxM8
zj3)T@Le3~D1SwLgkOY4GI#q}E1>)}HF{-V(^*}5**Gh4;6ah0VM@_U+8FYyfA3|5F
z?KTnWnqxGtk4c`p(Rd_E105G%lubOj{Pu#3-oMp7vFGBt(CEQOGb*@>MZ{~wi|
zk}sxm{!c;M=8Ia;cYV}O^-{-w-h&v!aTY{^FioxJEI@nyUnGj_B#l5L2GM;1*6dM>
zpSk=1lWLJ_6>w)@sO{DSsFQ=!IAF+loJ{~j-c9Ze0!tR6b;2VWvCDpo`g03vlMEV0
z+IM6((RDu|cRrExi%fW9_@q~%IXu1mt3WW^h
zzDJ~Xk=!L+^D_t%VGoEuJ}o%_Z!z@GpM_%yz@OJG{*->Ge)p#)v+doVLffL>-tPb*
znBq@cD%BC3S>kjv9b{vg-^r(&8Gvi){%n6HCXBN`!=K}Ky=YUJ5(hH-GY_~J+GPRS
zxudBH;nDkRSP%@&?wg>50YPuCN-dEcP_R&r1q9@TN-k?z9`5%ZI|+Ac$6#BBoU}uV
zl}y*Mey-8z;~7o$48##vV{mA&UZuqPfUkkLg{}7nZ|l%WtZ7hVVAg6>l(Ll`+9aqr
zQqWbR;B4=Rul5jZ`xESDpv}aZ!FJBEBQTx=O;9ctmJknBA3M@A=-&sElDp`YAjv3C
zrLW@igktq(FWSomupP<;r5JM-Wrl0(LWg@;hMy@=kst*W?OD=WRupcD8309aE>!J7L6aJ~=a?Us>)@*k%xP*ojig9J
zoN>Ls#i*WPMRJTKdvj7+!#R)}UeMgy_|y?YwwFvSf&GelkZvtIV}?OL*bD6ocvpIT
zJw6(LB^%!|A3st5675bzIckItht81a-$ki;r68)i<~n?F9)~t`@PH)`FYvsm#A+-G
z{%vsQd_SL~$qRi)>THE2nqp)Uv?_g|l&H+U5lhc9Ml(8ruoJZ#P2>J=r2%9bIGS!4
zQrG}evJs?lE*7`8We~up-5YVH`9H=Elz^M0ERbQ46ynb^CXGrkwNGF3l?=y58rAuh
zN-S#Whtt(B>{2L^oU0t7FZHJ30rWu+kF6>?d=1mjTy7*!!sR5m>3eh8)bLkV%=y-ad~1Uh>t=ed
z+P>xZ1INsB!Ms*-g&If86Z5?Q-Y8$nxRLITRMgK^G>0mh!xd{OKL{UI&K1^%3TwlK
zE5~==EGnHm{#qkA^R5r?x=mR{9NJ^C-4%BTZMUY%Oe9Wuy@d5TN`<
zeBOw{pHM8iXvpBm`Z|?5Sn#1n2*BX`$NF%|62Z;lgHhfvcy}ryuv1I{Z7s|a78{t2
zelpLF$W)v^@Sa0Nocs+6DrhsK%%Uj}+JTT)fM6BvH>$i2QI8|pD&W)j41Y&E&bRRn
zWGjSkiZ2w8r$n+n2-00IZ~fxdh%0~6I@t$D*?TYV4V5(oU90C@8$zxPVb`Xs{<&=r
zhqgT&c0Ei4ZpAAbCeKb=r+crYhRRpXm9GnxuM3xNxMurP*SB4v@_n}oieC>*ZFp^L
zdid*OSH?o+Tdo&ufu+5v*6C$mufI|sTDCq^ykV|*Tc~(jxcGthZGZ0io-0)RI8262
zb-(rGJWL`LuHf7c!e14jgOJh4XB6tj>)i)&0vV_|
zS%d9YsUri$BkW4bzIO?pm$b_BAg$N*q6haLQqKZ*6=hCB)Mm@^P
z5@g;;g*sOkO;QX<7@%_*81YFn)i%78`hi{OokL2Jc*dO_%t~S9-rDR$eo6~cL>(%*
z7vL%iIo==RjZiSvWten+@(<9jvKQ@%=CPJG6Oc+}1%Z?F@SeMYg0It(`wbMq9OnXX
zoY$C2!3+jcr4y+MGohK!j(fQpqIAJ+
zsPlI2>*gGdX^#z_f*9T~^jQ}t=o4C5<7?g9=Bqu}ROf~K_>+Q-sGOD8`1(%zy?F0!
zJ?U>UI$x~x)^GD3ti~%?gE!t3JLEM`>4q>GoPjXA2_hE%m%KNDisMf2MZ4*4=%yQJ
zpxL)(6SUa0Tf2lnyM$~BTe2(}AsX!hxf$ImK@OPcB%1qtlH8MX-@`_ZXPo4n_xrwo)xWBn0?VGnGhSqV5$F?p3!c{&?|wi^tu~
zgn#H_#mVY5(dspk%rz0un)&(ciY`QBkXHYd^D3f7l(Cpm=THheBs#FqbP5|4+eu8^DqH4CSodwRE;GA
zNCYo{^m9RJ*;z+dEl<_aZ3R}u1i;5AUqkFonj!c|600}LOeF|YM^>_v_RyNFLrVd|
zU`(9t*LX;hWu$|%(eSNiR_qnlM8Mk^g9@0-8+mK!XcBJ{Q>-UIqe{2U)Rq&}7Lqr*
zXnzPqXC^5bD%(Kd1e%jVzZlQq*KvrBniTkrn;&7rts^*}ao&$1s#k4NxZ)1fDKG7C
zF;#AxWHQ
zq|VU@&K@b&wzWq|0*0W9#B(M6|
zF_ntgu#{qqA<60U7td=kNxDyPX6V|h1A<<%$VTv-JK)|IfxJno#2pbJtQBaWhA^H`
zy3gaQ8lV7yCuop>axx;R`qPcUGzlBzIyom{lmbgsrBKI>m{Za?gj*&(#7X^(XjeZ`74yF8Xs!R*D!m(3
zYyD3=vF0e=R%t^;uk=h*Z`IL0JIFpf^S7+ZD0GouK%d0J=~#<^o7x@j^t4>C0BY9&b~gE-M1u{mk`iw-U`bWrB_
z!YQvsVMa&+S#?ZilSMFRD%3?F-h6
zp^^NCuaI8aUMIPv%th>2ok}CwW}D2%zeo(m7brNG;*ut8I3;E&hdqX=4#3Hpfxcs`
zh(^P}HvLx=$A%^`s8c;9;*^Y9v8@xegqOJyb;{HMhQykB2~#V!7oxj~Y+5A|v`LRgT!N|dmNOq9LYC?=Q
zrJ1mh#_R`9;hc8?@z*Z2CB~3N#y2*TF=1MWjFyvv%UZ&BiL_tug%|IlRR~JuaR7Nu@Bk7Aq+sEuGDOR;UlC~k@+%Q+B
zMoWSg_w3KX_W?l+Ji13RCv~wqiRlgRO{HsZsriV+?Mv)U>~);YM+e`-XwbHayZVxX
z);=eqy}Qgu3t=+ka*b29O@w}UlBT|^)!J-1demY$f|~lAeF%)fPoBOMl#U^azYwwA
zb4H5y^{?7y?M+$eYhOyAr`OY)a`qt%zV)RIy{2=}B&QA%wsmw-@
zDgdf{$)}a1|BaE{02t5|F>suAYRBnxvVPh^Si(|#2?VBHovft;Rjp}T`1AzD3Jg!IYkTHFLOivZy{<
zR6hZqSm_P@iTB*;gNMf5MN7AW7cD}WH7%JT){V0ER?Ub*0(pMSvRgQMw@vXX>lRv!n)n6Gan#fu8
zAv}R)p;-7K$|;0DrR=(!)@b(9LEGK@MPtsJSvNzG>UEK-^%MCU5Z7nXvcaU`QGcfmp0ikYM|cymj(6qjH|K1sn3CQRui$)2vIjiim)qPewNy4-?K-Sn}{
z>ewi>XE%P9SfnXqQbir8LtaEh(lx6&>5%SVpgSv6FtvLy3tS)K`@j(SD%Be6lDStBmDFp{q&b0j?jMv)Nf*B@+0K~!OEy)BTzCqOv6e37s4u+|ba#EJ-hhPRm
z0LJznHlt?Q3Wkyk@=@0%Bn?1Wj2046M5Y0ms}et4u4=d~$VM`@Tjwup+|pDgXhLo+
zUNknA)zbUME%di(OJfuMcJ_4CYq3I36KzD{PhzwiDX@sNh?K+;s3!a)8cQ}GMYBuuSXX;c1#T)F8g)^_!~>=8wP=hBQX;)Owm$71JK9-
z;)@dEnFR}%utYC`$x|+apLBM^1DDVq(!`!>Q$V$gC3RL+P>?N`YNN*bIq-~JI(0Gi
zl7{nn3Tp%ojXJwb^3%-dgnHZxQCHS+NVK5kjK-*OnV>hU7t_v~zE}h?D`XwE2eC#l
z=wQYm1f;)RSfOIEVPC0D;1G~xF&+X1N^~w4g4pn6XG*HW`WhBK6G-_FPNuXj7{)_e
z5?r#z&kDgY{mD*N5?0$ojpPO~KM9U+z{`=95U9`?Xk1QAYOPR$M=>I9GS8*rxH1_|
z+fUpcE=B1)dGTDkVvvf*R;fX!MgnB#!Ab|FL)0Z8C@H`Q+IZAr@IZn=ASfYHDX;hM?>tW-rO5mjD%LIia4~!ehYPM4Il=C3=joe3^ppA^cxdIA+fu$DivNb+@AC8L4e!~
zR2wZ_<_(GG1`;^Y}J
z;u1!e_gu(-s`DHaL$$TTtN8fE)8{x&7>&NpJ=Mx&U4zgu?p&R$30Ul$cTy`MKJlr}
zOY^1=tv-Ib2T|WR^YKnN6E}_-Rz>51rky+0CA)Ol>bhksS8`kYVCT}7MnHN1<{tEc
z{$4zPuKgmvq4P=uI$B>YTm%ET2dPu7ORX7oA|8l>*kzY-7+gMoy!%`T59C=c
z)PYdDJ@^Gf3_NlSMf@^t2AIS>3{9xxSVPnpgL#HrG-^QXW5?72z3<}#u9fDUaJMItiF;LdLq
z5_w~k=5h^48W9?fF0Y5R(_)ox@bj*wRtLZ^>wN0sX_z=*+GvN04ZmdRvgIpQu6k(o
z8YuT;IrCcq606IW)ZwimGPtZ;2o7X~=8pCYrxD#xj7zvvfjI~8FT}v`!^)vk0i#|6
z#(r?^Ic?iBSn*)Ma(!Zm>sfKS8llP6-<-KRwgIOgsvy=k_`y8j7f!XKdt`e-_KOf_
zXqGQrhPun^s???A_iOoMt5&O|fr14`Rb5p~rvanETIOniGF8*b2A~Rs0eJCY;!Ht)
zKH&(KvJnZu^Cf~qayf;>ejs8`6sLB*Z0BQ#_B1u`HHOW`Fk@j#lx^N6N=sZn5vywT
zUUr0@7J-koZt6>w^HB6Tfdp(Qt5sRu6qR7wMfg_};knZ;LIl;v_K*tRrah>Ua*Gei
zI=VKUtRs%fTSOs)-o1oCrNog(0B4D}OsA+thz2MdZ6K;P(QPx`8gc8;#BRitk_?{{
zcw+9QQ;JQUy)J3H;p$CRpA-9%d)?}DQlHzv;Y^=n`{4|g^+-LDpjBt#7%VZg)-drU
zZeW^$IY!;2>+4p7<%eXVfaT&=8Vq0DT6!>fz>Ep!fc4|)bty$bn;G-QkW**Dq>z%f
zEXRd%EJjNb({gmSj7Q6<{Y7qQmx&84Sz=nJrA;!V=4q*3gKVjx22Dr7(v{2Ym8F5z
zB`r&|R#B@SCr9*{YThMV9+#khln7Kr)zONHA)5JnX$)UKmRF;xq$d}Y>
z!(2Lh?YO&McNj_`ZntE(Y3)#u67N&B)^@pjinV9s`(8L>6?OH(x~R_vVLx%cWj_8T
zOAjWa&3>&M{jboyX_KQHbfXM8V!g=KrZdhgXBO!>wI?O37fxT#lxe^9zd;WvRd*y9
zN+;H%Y@wbKZ%x>7O6?L4whEemOgmw6x#cfaKJxk2>gkW|T+!f<%
zE$>Gfn;f(n8cMuh9F&q^98%Gq%%GOh@0dQ$ms;<1S}<+=d-JP9mqy??2&*xPrZr-_z8KeQ`0bp2+|M;zTg3c
zo3%EPk07)PR3)%%LdJn=KxqU8OC}h9(u}m%Z{QTwNWLMQ$a3Bd%D)iXm!0cCrpU@1
zDhq`z20ynxp?r=MpId7_w?3=<5JUL6wND{Pss#DRrf|ZMsLynYM7HQ1`NFz%Kyz>gQN!sja`8hV2mDp;(Baog4Iv8-
z;W3YKCw3;4pmf5h15x}iZnSO?6IYEbIGsc^0|ITajR?JOV=8+(O^O&0bN*!KCHC_P
z)D3a0l|Y6Nglr+?tch;4nw4gH+Df-=blXlh6HLy~**35OroBe=k>6yZ6)Mi&c0y@C
zNzsz06X6`S6VehdJ~CRVeGyu1bU^506ZOd`rcI$GB?Yvz03V?rqlG_*T3fLtt9aa3
zGn(J;n(`IReaa~x&sj0r*Y7b1Z$C`Sg+=02M*h_mqxRRF&uL03q88>A4)1&|wI8OBId@@)vVNjuNyJk)<;jZ_)kQsZ{d-Z?RAKS8?IYXY
zXc}{Uza_E~VGy=X6mA=IP30|u)HijisN~wgk%MnMHnw-7a_vOXIu;oJ%Bx50H-g|RtfX6%OE*y6kj%JRAek+fA`&i`Q;mBi8M4o7m9Pf;@pNO0|8S$Qq
z$(55&VrsS2sr;h;=9hPWlwXEM?7rvr4laFh4MM*}JVpIYgXIX4LGRT+_hK}kVL__N
zxXEcd#sJntaP~{yfOfyQdw5gSv-suR5Tba}279hNH}o7_0j1tZjpnQxcRwT?o^Kr5
zIFVL1+CH9Eb$3zqo2RdzzGD)H}Kr3@6F=t#p7uWs&NwRfQGhBW#tYxe)|ySWN6#HoPsOQ4m~>>
zeDmz}v*S5Sr^+kE^XSo=rBE%dd9UWDx#Mded3Q_X;1iPvk4Fz4k1X$qbaX~aPmCnq
zGo&tyl&*vgQu(S#*+aJyZ(fS{HxJsso1z*IO;rUVz6w!gVDX)rt+#_e?)p*JM9rg-
z#g9cEI~b`tMBgC^Yyb8o7&46{PURJjTECY&Rb4ao)bBX2XWl%H`U;9i%fGi4h21=G
zYw7PE94o(R{hg}YrIA4M?Z(?3?>GMFW!2sM!fT61
z77KfNm2W0pPa*|vN;y@E^|~@zx)NiMIs@UdXZ6qTw^}W}>?^B>R>LAV
zr3CRz2JOF*1Y6*glFvi5|Np{T(UNKT%gp?iCAPn8u;M;fBZ5>oub5wT01xx?I_Sf(9F8&EYf?F=BK
zAZ9|D_)7hZyLu$i%6<4X^D@lyGRjtEod8Q1aKz9Q#giJDB(JB+?iow)*pgTED=hz|Ro4k+K^Dr0l^h?5KskQXivF@b#->2>U6;0lE=31Kpx}
z%G`+;)Ar-w7l!aeXS~pfAh~=vZ{A*>r5^n&GCXhjBq7n22iXE9(Z<4X3}jX*hW8?8w=-4~-YEgwu9*BF}He(*mR&f!G_PrQ@09(7YJ6jwTGR
z9^7{ik6U1+`Rw&)N6+6}7Aad5Em#%ttx|1h-*AqnS5M^>j3$h(cyrzLb)$7-Pe+PZ
z;e3mDSK-((ynpJZ?}r8N7Tip^wLen4IhwOM;@yl!^e^PunDAI(J47l3*dVyaUohd%
zHLPpl6pMC6++|e5A>}JNNqGg~#i#0$9
z{oM@zXf8rB+JESN*L|yXB4bO$v*jMCK}|W`{Z9=z`)#^D6pXZ6hFXB(r<0ji!ALR=XN0GB!L298!b&@z>hKABQHo>Dxzd@T33Hr_mSEA;O9+n1xO9@aj;^5lz8
zBKX9x_1mC13WpyZePrbEsIO{lP1Lu7kj>n0Z>0AJU{{X!_4i6E2UCCM1{QACWwdPv
zidY`;RYlUOBF?J0I+7CaAw^a)hO*(T557**?aAwFTefmXNWl;cfFikK_S?BlMB!
z_e>JMb5h_{7e6M`qnjTQ!7g(qg&$!ro;Q=mk6ue|@s(d0`jyd8G^a*ZsK()29?e7m
zLQa>h#pdI8Is7h{!UyK@W4@gi8okEd3|KS>l6)bWvyM_71h_G_{Fr9c|diUJD{kV&l3}9LXG3mUb*694FsP
z_fb@2@{EkFhoH#GAg7HxPtAc1h1kf+@aSOJPoGfaf!r`au1oSpx0!e!%xzi2To)+ymIGl*z
z9>Z@Bey13Irv%~N6Okj}@bhpQv_QSk0`=l=I{v2PZwCHm1T#BRkuLLu9a^IH!#>`R
zS=f&`(~kYb+-(1KtU41lQNhVpRXBzAQM+*K0INP$&f*QEM@g#pH?!7SP$(X#@_Lo!
zO}bvBgk+-ErMlv5Copgx2|Bt@cAXAGISyV@C`+g(c<%IZ|HGFNuBprKKL$OA^WDLV
z*xBn(_4Hf_t!-!s!eLMS1x`@kt(8wB1bN<}MV{Kx8?-aUFLc@}o
zyHFs51`L$s{KABg57`iFPC^AQsOqT!4sCjPJ*C)40SjRxDF6@}sF^WB1^_=tp-$y#
zKI&AwNmy(P2JH=
zM}jp+>W>5$8>|h>u_8{a^=mT?CBKfd-B2Ss0d1IiRNU~?#m*4f`h^;nt$Jwrnl%jw
z7*`kUu0vPqc-hvGm)1H~L#bn3lR8y(B~(Wpt81@Ab4l5-PG8I1TRI;!V^+b8qt|{94`@s6N!xduUJZo=u0;-#ZWW?tHBGu}wS0?^tCPu`b|A^&Hf&
z`AFj7!YD&`8jDCc;4rQs)kZ=#DhQhmedwxaWnS)VS2i9AKD(kXP)EO^64`SKFOCE^
zi5J24%j(ZqWgc20+&T3u7Oq`bdj~D4nlrhSUbI&%OWCN?&?i@V#5eg;r~{#`7cSJR
zLr6=DCXNIz)k@V9P^vmw1*Ik$ZL;fgw}-Y9p1TJMozqF}p}k~?JDo(;3Z>t04$4eY|q
z&v0D#CaQ`v_P#`2O`_Loh@C>^<5CtQ%8FaJbkd!@e;tueAzIYh14`o(xTm^lAD$)M
z02;y4CK&`>yL4xuKoca(O<5lE-mcLtN)@P>n3~LxG_GB*(b$sM+TFUhxS-=Lm1aV3
zfVh~sVu_HdP*=r
zEN3e8-`bNg=j8;rS9iAC(XCdjX{=NLcQV=s{8JYjV5ZP)WPJb%j+9V9c$xj!S3J$MLxHrdRXttWK!9N9+PhS*2;!&{
zns}^ftagiR$Dw*o`$!y$lry}<+@CD(T2pVbEy_jOYqYPzO#+0RZ-){xpe=zh9IHS9
z;J6x)Ox2H6Q37hRerDhx5yy;>JqI!k0^~!O9Ayz^kG;)K+d#Z3k5Q#u^V9THO-TkR
zNt^^&0)lCu}8`z``uF+dE*(C!-x8lK5}Obp1gYLj=TE9%>29A{z&P8
ziR{*hw-r232n%;i)ljStJnbEBzPbl4&LCji^-+p%@Zj+2J1Ny~AG~?+*2z0{+op2x
zg_FOt>BgprXDxp18D4R9gPH~I?=m6sd^A>gSq6si&g(m2gho4d|KfUnw=7zOCcaEUF;A{w#;BkJqhO$v{t-Wz
z8N;t*ZwmDI%($`#;8tJf%9@FRkdJ7wxC?J3P}M(aVDkWJh^Sy3Iw#;G#9tK_1%`$?
z7nV(gP3j?QZ=)Wh)F837gwr)`4Rss(tHbF56`T-G$Lj{}ki)drTIqI>Zu&|*Og~wt
zBHq%NQiq*l;VGRSK;Te2xhv0-5
zi`(+OK%?FABYR!rQd@^{qUjm!vT%IR`6k*-%BXR{62vG_A#?l?6MrnMZZ%DBBb)k7
zOltHSVu)u3o_VEjK#zuHY#X(U+g6Q-`8b052_CduM8vKeu>5`o>EUsR*>mx;K)k20
zPs{=!;eK|c#xA(?sb$&tELw(E4ey^w^N-mhdX(J-#I>{&NCs!dw$yh6*0>!B<1X#k
zHe*c^-$&a6S~^gM_Lgwc{?4`4&-MkN(sSf<>k()|ClYnm-Xp?C@tXWQ?3g+8!jh?c
z6$F|H;EHJ^NI?>e$Fy7#-}enW(WMuyWUcNYa>f0_-6XZS~@bhhh!x2j6{p{0<|DWzM
zgVWZt)7Gcw6<(x?X_rT8Db4lQko7AuneV3N53jnmeq{Y?8z)j1gX!$anDi7zJ%tmV
z;(qIgZVw`=UrQQEdd)=|5d}l`LF?essl0sHWH)|0kpNV|J@BcU`Y-jTEwF}u3+?-l
zTSE&A1h8Ua=G0s)kSI77H_V+H%lVt*(fC;`gRr_)<(wHXq9?eh|bY|c3L(l}qs^v+O5$_;t&#gSs6sMV??FKxz5X&$h2yk=o?oP_lIa_J9;%$CQzvfwpZ1zlE;(Bsv_
z5`sPl#vHbFBGT)ZU^|wJQkeTFJ7QwQMtwXF>(w^mRf1c>odZ*>`p7difwk53i#G+<
zB8Uw&NGV%?Wa-8u%hosGkAY7{MX*&Du$)b;3rm=UgX>)UB{6
zf4L|D?(){3TDnnBxV`~DMcf`r7H&}0nTZQYZ3>8K5Uq}3%xq{?E_MdOYt1u&3dEQ*
zY0C2`3t(1`$Qy%F((+}kq*^?%?Gvyf(ixVc;K
z@ZALL%LGE@;;%DuSL$B|z{e3?(-1VR69OxS3zdtHTyPP`&aWm7sOkxxKQ0i#pR?&E>T1qsE3RT9{
zgZCk%&#&Tj*d@nuGgS!>KbBuW(3H&zwnRqW%_xWz?w!bJiFjIwS^*V#b;oGy)fRl1
z^6rVDP@!>z&!5_@DfOQwTT@m*=;QTGrd34KDn@}%S4W)HqRloIKW`K6%LCb_vMB<2
z3JFJ<%9s`n-3F$J!v0TmAv9sDD#A}s>@0=QT;?Dsbc!l;1SnspuheOCIkiGx==OgA
zR}9@nVwP@YL%OxfQd5hNG32t`UF%p5AyrWs6oo%Y#}5{8(Mt+FJh=bLk)b2db;w#2
zO{IRyfdEaO09q71>B1$Kqv^r?g<|Rj6R%Q4y+m@-Vy2j+M%9D+
zmIb~hLk#D}f6s!cQjj7QHKi?>%Ddp#bd-^?V2aF6*NJ=<1^P%77|i16e%TP&xr2GZ
zoEQf$`O}_9F2Xr`@Bp7k?b+Z&@bU6RVm#ts20PE4hW!XmItYHALNO$oGm62vq!>{i
zot(O-O`M@Br_|tPlL`_hwAlYfFDa^H3buaMYtj8lpltPIy67U^@MYRa&
zr^BS7=PBggIfy5@p$mA2q`i1gv=*PNh$Ev%Lo)Lqk{62cOUm3DRo+eEcA&s?WEqEPL4
z@D+t(G{GvDrY$bCO`9O-j%ZyMtHJNzuu=1^qYjte5`9>}-G&gdr%iX2pz1G&xV7qM
zztCw016&5Y)Mgg}AdmD^Q8Y+;>f$GM&_K%r=<7wSyt%my&DF+?3pBwgp9%qye8d1I
zs;kN%`lGc@m%tUD3e|@oIh3AmtEs2>qVHiFb-@me5n@%-T^#%>dlsj2o)T
z=8k~KXkPo=Q4ol3S(&!!%gR)cV;CMDVjkX*(NV<{PgEKE!Y!&gdQ?tG+;_FF3#8x@
z)CS4+sLj!`1?-4UlW?TxbE^wD?{UIfh<44Zt7w-i4-cSJHI;{JT&29-&#U(d{bTUZ>k{((M{<(vbqO?!ibCbaOF81K+h0He!$p
zdk5mB!e*`&Y{IpILSE|~@LK7SE*Id?;F6W!C&9ge?xMlEaA*(M66M2PqvPHcf
z{F1^HLkZHE0=`SyUUNthwBs#}IA5A;3VsW8Sbgh88c+%9uN3^!lo#P!6TdWdEQI~+
zgU3vmZzn7MUN+(mI(ka9oM-&nlm53i`7L0abiwi^@pTcaE-jb@V|bUc;Q`B#&K%f!
z#!$u=)GhM`T_ht%Po(@>A3tzJNOlo-X{`>juTf>E*3#Eu^K+&$E-`*G2I+pmsRtf?
z@ES-7A2_z>E$kG!nx#&J)(UEUFp=(T;=to)=sO8h;w}gn)Nx0zrEztyT{)Y}`f87Gla1YapeElnePXA5F2EwHCo7-t{%No~KvNlWJ_A`nrg;m)5mZ9rrI?
zLon?N>qu0`(rz}NhSBw_T{HYaFXc|uUu*qCnA^0V_X|r{VAY*;Xk}rv2@vpwT8R%5
zcPW2__xW)z@l!c#XaOmj#$AYAZn~18zDRt`RdLDjbMCste#|t~;-8xbCHdyQ)q02g
zzSkW{vv_Wrx3e@348}mCUoBnR4fUD!%JBWGwa4~l+5@q;4*yKrgR)HAGnm(4=&uw-
z&6i(yw15;QnmA_e7BG&ot-)O6+cJ05RXACueF^3vSGoL^k6#tqFLv-C>prttd$0dh
z#rN_I3uc@52jY7;xX@OGA?R{JOSn?UV2GYly*?0rZ1nsP4#eUr3nUdL5+qRm+*ZA5
zE!zx!ZtV>x)Ca=0>iPhye|MT>*_y@}g*t-CE&7F`|P3llMG(BPxmOsWpv
zqY0NEiVW6#=|BnlAVD|teDG38g*~PeIJW-{>lLfj^3p!L<+AlZ+n%uo?8+DpmKOAF
zQ)xIM5CHp-^cIvy=|(6TUhG82l#6sDs2{>hi`1_9Tl@%DGqR~NKBSV3&Zk{ZGH3AY
zH~xg!jgKSC&;OB_oS#^11sV5p^PrTHlYh1BT3{qF+B{jYGFq|n=JA_PMJm=zvkCnq+wMK&Ib96Nr;*YU9ph5dpBLEmW1
zY|OSQ-=elTFpEz-8BRDF2-}Zz9Z}H9#mXPxOUxwFB=96|!-Jec09T`ht=Z7)&fL|Z
zEx^!PXlRAekg6_0!wFoUN3tK!Mk`t6%Z=fGr!gc@&qFv~+I(~A8)a_>t_Q{%->i+6
zHvb|-o%wo6sWog1^j3#m^|&AD>a7pluqvdT752vKyo9~+8ZScat2Iz*(EB<`gbHiA
zFgnkEJUqPrh|D10AE_r!E1@1<4D^cE&vcrR7$MIfadZHY0Lu62CKujx7Dx~(VLwDX
z?H!#D3pG=P+>}f^*gL869m+x7nRe|(fb^YvcD8JtPHf)S+PG(rLMMXI(IIV}>BMJ9
z5%q#j!+`$jl4@&2ZwOX0>+-ZxUfpL2>5m}HCarvBlu}-&+i%g08~p}7{WjhH6Wtc1
zbRZw-yg=SYx;m9MRpCgetr6;Z4Ai^vGU~5oneMOwS_)tX6ZigpnNf{RDz72@>v(4M
z@MZX4&#M~GTQ{~327+WovU2pfe$PEm#ki*_5+HLzS1GvJ*@(zqJG!`^OgFOqlUbF~
ztjdY3s{Z5;)5zaOq^Nl!V{62-^`1K?;x3sgs2tdHub^tOpe|ZaH&M{gzvsiu5>}Dh
zGm*VF;@x|%7%>E2O1)cJF?#s>CG6f~s=RKj{rU!aELa!UB%xR>gMG&VQCKjmkL
z$-9wvbM-`EeWZHBtw$n7aL%!*fA3UAR)5pa+!^r+ADRfPi&U?_wIwFu-9QZ&Ltk%o
zMgvXcs$|he?$rLC$uxg7%|GET9c>(USE4vrNDfvGh6bTGn02LksCt$_+ebxZZ!90}
znXFnJty(=%zUEeAw0y&@r*4-`6m7llKmw%7%=p-5PtPDZLH5UPM|$?hwxpEQ{=E&@KDq
z>YdTmJKryjuHG|Iyf;$RGPQ0?WL?XhtopHM?qod_X?-k`c_?z|F!V9fk5~aXQ&I=^
zq6I1W3zqVJ@Qceq!;>w!`6Rpg$eVG+HRKwuxK=+>Kj95bd9$XxMN?kiUG2kUeoZvL
zX2M%L<4#OTowYf0lWEpr14y1;ipSl>FdCmss~u0Py;~Ka@Wn9qAI`j%JCX}PhnU6g
z_uO|%n|NFI#Z*I!>hk+&q0yYyyW#JBGDiXX52(c1gA1j=&9TQTEw
zxb{Q;F89irp)>HqQh2=(L7&4n!V}q~%DElk3a;%L*@MTu^a$rU*Y=L=rJoQ7<;U!>^aiHt`go<}fgNbq@x
zsPMliZ7kSVV)?6*x`#a`u0`k|0Ccd-{t<5TDf>Y~4S+rVV)q&WgL1v8@`8!NeHv?F
z#uta*2-E^oT8_J8_7y~~c}w62&Mx%dGFARCIQ|qkj=k50i}(c6c*mp<(5|rbgoW2|
znuX(s8_z}RH{Lq`e)Hs>qtQJ_
zBfFoBq_styZ9;5K^QT?J{^7a&HOv;V#YmS$`^MTHSq*{
zENFqB1TwIeOe{)++>-I67cpRYOKlsNR|}d?!@zn$J-j|5@FaUluR-~XUiy-%ztNuX
z)`U2A!;cBGG6B7DNk)Bd}
zf)@ytG?+^c_c^+jn%4tW9GaznmpV|6B)YU#0WDe7>o`-Y|JI(&Q{$~9@wAjM#ZjSz
zu9O9xROV2}VA8aD7?b`-JQ&EK(}YWd&1xi_)WU<3)KQ8-5Sc)uFUm)g*R^t14M&n2aWm?XvJ*Pa-8Vl4f&C&#vo7d6}~D${lmHM**yahWw{x(N*M
zbob*y5>9I$XtL*<4!InJuFbsDAvx&kbgaj8*i@=E2h9;PL37dq?Qoh2jRd1fm`j2^
z`0$s~@UKU~8W~%beXp<-!`-mrowGO2-YR{&YuLd9-}qYUs4||r_;%%wYkpMoe*2%+
zPvkxfj7uBRuQys66RhxG_ybxOCJrXV3Sx=Lf2Jhwa60TFVS>Zd6T5HxeSDa9B0@!w
z0w@SU3u}Y(VfPZgGHrZ}NerP3#NJJ^%@X@eLjr*h{C|k|_RpmXLOD
z9Z3|Uw7lVR*x{sA!*XIWbIEw-k|}s@s~V}AwTR`v
zXz^s_nrP*k$;vI!$}P8-PgHKdpMp>LUXVT11htxiB1-?U1>=9OGB7u_10M)=&mL^T
zc7lf%3L=$XbggEj243{wJML!dPr3uHK}pGW`=JjyKBx4O#?rJ4O^B&k`BsS2~;@V@^{uA{i|cDf^z^2E-Gt
zHUf33Lk)k$RKs$3-k3?hXmykW&CV~Js;;H)CFQW)$HONj^o1R6a1xj#U19ewPn`HdDZlg+`|VGe!Ka*iv5gDR*I}%Vu{RW8EnF`%A7l^N0INh)3Tt&pbFWxU+qM@f4*1>
z`Vy-~l6d8kW=+$KOu4IN42D2l+}Pk*1THxj3Z6Z4qBgX2nSc3;+Rdfqwab<+m%%nn
zv?;168?-y1utGWMNo1xc$HANT&<(EoRgdJepU>8Hm$Z;qVt1V%jFQY-8*;+zzfO?Vks8m~B{wbKPbWDDtz3
z3~fs3JX=U#$lY}y)xdfFXS7A36`+u}>S?#OUJk$q5HqCr)3*b3i*q|o+*|fNjl-E)
zxVI^h$=X`TH&3SC6)D`|&;N20~`qABFI_ycFYQ2#xM
zM$bXvF)Ef>l9$AWq*;vFN`pnuX
zF;1unW2ciQcQ;Bx_}|=RH&^^{!@C#fpN31utdY#c5zpcUI66Df^!d1R;K`_bo?bhANPcA@BxLZv*KSq|}w8=+?hHVp5G
zx+}~HqgXeQa0B@$Ji~%Ak7iZBT|Rc|t-6Wy)$u+dcSK9p&+8L%$9Tzl5c_Z$X>haHDq!=A447Zk5^CoTJqa&>^aRQ?Q%j$j{VAoN*=BV(YRFCke?Ci1bqI?T
zuDJu1%8O+Abj|)bZtoDSb%$Bun70!U{2WljPsS#
z4%Yl^AHjO&cnySclm8wNyGV|{DmmW`|!jMsa%ZB$0+wS9fl{*B78c-*#a=*t&1ONc3Nye?IJ5zqO_9kw+VwwO3!GS9@b#eLb8^skja;
z**EB&TCeu*g|KgZ>yG_fx7Izpb$?y_*Ix~1uHUxr(fy_$e+@l3u=9}Vw_gvZuHUwE
z`=k4}#x|iJ1wQ;}OH=EkjjcQPY3&Pp(1x9cUppFi?pHISlEYi~?`u1_v$=JL_AY6C
z3y&$rcJE${ElS&C!5{P$bST7U>R46bh_+Np4VK;)2*ggKXL>{56O-qzXnR}wv;s*5O*maAIXI87hR_M5lZXZhlni>vwqPPVqz6HS_p%irh@_at_#On2
zNT0@<$1*+tl0Bs0LV+X`(FE-c=2dUTgF!R_4OkLQnA?FqZ4D9PVpVy}IkD`*7aOur-#O-K!uVH-Y&hIovGk5(W
zMC195%wp@6q+)9;)Os?p09a**&*y;0Ks)^vdaY#9ch;V9F?>7#tXN^%NY{3WrJ(|<
zWeXVO_3b(T(fQeW9V
zuzdo3?YZ{c$a8lxcTIS9L1aJUu(-tD9+snby$DhSlm?%!^%%
z3Cd4svc_?{p{kli@Ek+_u&P;|I!h*$kI9O>MUzMZHlc5p-89zzor~;5`Kb?b0@3Uy
zRpG3t#0vV0MG?H_Ooi(C^H=>ts)y(~pv`IN;9j
zRhn2WlCt{WXo>tOQj)?2lT+}#pLRVh>TWQlYNldHDic5ZR}YNlzIJpXy(XTnvi~sc
z-Lz=Qrg>>APB31w>6fLi!gjwaCE1j~a+_Mn)Akl}qX(w47%b4OkH)VC8-=N?Bv4ry
zx#@`%n&7b+8=metJ^d$V9C$*vTq*r0W|HXHDV|;QoGhN*^z5;?(g&+&Qs_Aq&k=}-
z(&&eme?ZJcKfoMIAFP?lq-URa&Z6gRdaj+xq32xjoJY_3c#dRL&lJ#)LjF-TQ$#=D
zsE_L?p&x$!Q8rUbKcM@FFI6+;^rOO(Svr;BpUPM?1#blz`BNEHpETgZ^E*FY;dA(h
zm(N)6=Vm7VxfS9+?}t96mov3iN3&{B-)#LXF-4;kY4kdDKw`0I(0`V+EsT^RV^!7{
zoQG{pfsyJ`!gR{R-62H$?(SlFPYm}B1q(j*Mm)svvB8OrMfPI(*zCZR^7C~W4)-y&
zN($a6pP+pL@Eeck?3iXqG~~a~vY>u|muWnvNjHr+nMU>@JWs4dN@XqG*3oS#-Tn#n
z&5=@0QA_Cd6RH6JY2AGW*Wu-0b!x8h>3au0$xBl=nr+4_H-ip~^cb}<#KU3NUs@7cqA;_8+OIB%@l31@!(a+I&3
z9$A{sUhE^~KPoxyVxO@l6b+q!T3sB&!^Y=ghjuQS(L2Pgr%QSGOSk!&pMqby;6RZSX6@j7*0@GtJSqlwZ(O69#=c>2!#hFksK|3eab3J3h1izkZVL#H*Nf
z0DtHYgF(|dP3zzq3dODmUpq9ogE-s1H*>G&j=KYQ5xH;mt9|`DSOvFaJgsCZJAX2J
zF(O`!t-c8lsA~poh-@=>>f5PmSeQv)AnFU;@zvb*p!p65~tm2*O8`a~!Wt8%%
zA?KhC`bpqyK0u}k-!dFRIKV|102$W-?bS)-7x5!TVqsWUfQ?2w0+o^Z%xdOrLO0D(fcC^ecWbH+;&fR{KE9C^bX2xsBQn{m1wnWH$Z
z@n;NYH~!pQK1+W-%TII^2uhAh=|BPUlBWnAtMR9Z#`yqW)dsGrI71R~ekAhw;lw#&
zJU?91u07!79U#r(_TNLF_7e9L%t2^TbX-)}*Z&3efG2TgI}QzSB9C{Tgrx^DSt;}h
zyY*l#WTUnP?L(E3nam8rtwP1Z=%WA}*B*F{sH&GWw4h!E*2)%8al-pWPe4>)rd~khLWMx@psGngxu4)#>1)goAO%-q
zj&!ABHsem?IY<{kffRJg^(C#a;ec44PudBC9FpUu=OFuNoa?eI^HgTeNOgY$s7+db
zYPFq7*Xz)p%*%cYy`>ASkd!JTk&=@J&KdX>gt>&Xw`$OfRqAOG^E|o@Xh;SjBqWnp
z{u;OGv~I+O7T#A_FgBe81)z?0C8%5@NWfgEf21t`Mp?{p)C{?lB*K!E3h?kGvc%!1
z#6K#EI*aZ&OAyBRwTlQ{_$$|cC0eqI(AGk*mtIL5NSkz)M4ct0WHNL&r|{KhCUcfY
zbC%z1{^7oN_f6z9lfB7QHss_li`awZvx&i*fW_^gGgP`w3?~x;^ENffw8664@R=vH0n>TkK5S~z@Y
zG&I)y&h8t#Z}}!tH%6Qr#re3vna%VBAJ=?(f5Dmk5!Qf0w;4LKi7w$Y+vjlJuT69`
z%y^xS96GG=hYoA}p~D(~KJ(cen?z$Mdk1pLi`E=nvx{+C;IPJVjf2_2gmog8t7AHe
zMrvzUFx>iJXEKa|=A6bjO~gsaW38RWbfmJZ4Ub+ELR7BA$g(!k`w$^{sCzPlwJTpd(|PA
z;JJcUCZSn#z;hh@l?;FQxNo@La62pFEWP90K9yZ7!LK=*|K}*2;H`m{k~~$W`zXSS
z2;?OoGD5Hh69`!kS_v`#vfFi@nh4g*lD`@t&`wtdt~YFgu=@dxJ&*W&03lr)a|sR>
z)1aS2Mh2zd$s9cNY7yH@g7g~b8?|$2b;o#f-?(W;Z
ziR^6=@3yHF?{}Jpov-d4PbnoZl0Nj%@RmW?rxkx>7S>aTCCX=XjK`~`{}Zhrx|LAt
zGSNB>p}+66JL*33xExJZQ3$2#KmvJvbr|4=Gz(ZZqvzp04+aNfaC1V|d0>-i(?bgZ
zrSW6T{zrr7<>1W08DklB*pDC$O%N*LEnyYte4PdMozKusx%bx5K%4M#3>c01mg+)p
zR21eROj;diSyO+#lgX-n>!E_I~a(*I0<>K83yAP*LWZmXy+Qq0vCae|}aGpECm
zBg&ve9r!McF>|#KA};X2ZI+ghf`TD(>*kl
zX3O-8ApcJ>whKc3udp0VPZ15aTj|sg3wEAUpcx(ieN&J0z?rAYYTgcym#rDvb?b7!%OHTe
zn^!pe_-hp4D|IRx-cM8(h53R0Efi)r&^Hi93>+Ao9n#$}=NUY038ib8^E@f6Uq$6y
zz|R}tB+-eeF%o!;en2l4#C0?E(US1*EDhHlWYv#-FC2jkKQ)pQ^_C(~(UaGojCz;D
z+0Ag%(1tPlJE=EPqnWGBao)LzzztWtP_vPnNi)loG1JIInwtwce@+SM_5`(462&ZF
zw=7;UW3fAyzn}jJ{TT&Oj6b)Re@cHo^CW4=1ZD3)t@8T!g_B7%syLF{Pk$*WsiGO}
zGQtNHqlWn=HmeFBg&*>T;Uk+V&Vh{#K8#+q^_^z|9|6+hU?bG2C7B2sceNNt3L$}cdhii8m6z>lnc|7QU|=JskUi}WOIE!)Dm
z23V+eS%rj2%D+(uboxXGf&YwFi;evMB8eH;^Qucu0=?&GcdSCb2L*bXDOL88F93c7
zRbqH|l086DK-DH`3n@e~yMTeC3Klh-9VKWNz#?1|#DPzhef+o8xg5SBb0P)oF%yYRT}6gkQ72d
z_@x5IC+tt!UtB-jG+O<=mU{#}hf*NyExukH^)@iz94#H$9?h%(`>^FkOEh!sgF;Wm
zimuGz1=#2%-7ZpNBuq?%aL>yy(cxH1FcE(UCgKmlMEv09xu_I!`b{TZ=UF4BfLxm3KFlL+!%s6K{?O_rwg7K%KjNzk=
z#{tF2m>N-Pgjoi_6{k|Rp6evTg<2Nr!4UblYQwF9HApvm>R=k)LD;863E>p~EKH*`
zr5D0ZL&|?gn>qjyu8xYqHPUcyPzrI*q?)^PV|sV~R2$*aAWrNe2=m&h*-er5j62JKND
zd|7*lZ00Lyh2F7su8y(d=5+%{MaHi%&y+Ggy@w0+58i6OWDW#q&DL56Z?14Q6+Z@#
z3p)YBD9Yfg_LdHH33CxN;jEm$9uHC_+Q%xnHR(7#2X3|iW%Ds;x?n-$+#I~;st$7E(*G-I=>2%TRT>mo2?ceenI;5cN5H1Y5l|w?2T>jm!zLORI$%PyOQpKl
z-{MF3%M8Z%X)su6Lvw(P%PGM36}6#Zhg?WKUT!E_c3Z|1NcF78!n_D?<+F-f@Fj(ZWrk(2q$qWQ~iuAInU6Uif=fV-fXDzqo_?w49pbB7&Q
z`|iMTPJYR74u39|pNqujONbb)7oL`ZWp%6aPR8atX`5#gFm&+F1Sf`h8H0}dPB>Z_
z?tG16Q14>jPh{ksH{-IURNgHr9j$!ri9!2!$dRYof}h`aSbRm~xu+6wt%eT{+P|AT
zRah!=Iq>##=63#RnzyOS@~2hl%?Y+Yvs!VV8w8hD4*j3?;|8kJRQ3&1Z#ZRxCL108
zaKOZq5^ojY#;k>N;wJ;_mWw#N-l4f5NDHzLv4g_{;gQmQJ$A4J1xO)Vv}=JDnM>of
zlN3@k^hCF%>XmJ`iMBgv=g`tnevGFWP(q)=+40?IziPPN6iM0&dFWris)67^za*uAY>f5rXpiGZoaB+1Apj6MKp+^b?8A)EqK~_p
zEw3bW00HetIEu|fdXr`nNe!DAN_fdmp&ULmw-DwEr0~VHMQ3DE4QAZa
zz)0rF+}$NBK|SQ1MztIT*=k^{32cU%0_>a#pA5{0SODpmWevp8EGZ02P1rt^B`i=Y
z9RaJ4@6iuwVI09&fgXZCQdjCgQq<`m&Aa2QfuGl@+9mJoy0Po8^Bx*~YPj^;qLD?f
zSC8jCM7tfH2d*3*I!s%+e$YDQO`r6ZMZIOCYd-MSQH6Go^k81tL#gK;MPl7VXt8`3MF8RmWQH-9G~aOZWMOR-|KMran>Ca)
zlsbIzju%e0i>~F5fJ(QfFCT22@?~AwF|>o+0Mc);oiHEnp2UJeAr>+5&l
zPqL(B3~V208D4qEQ)+-yVu@XG4mpQ?lX-z?USO;&npYRI)|lv@Llp4IcMNTw56?J*
z4#!_`AY-HkP1!Qqxli#G$i*=D)!~G-)xx!moiRtj7G6!mZHm2=(^yx;?@{<|+@h**g0L=s{19i9hq58>;Kr|x|Nnbox_V$6Bz8~hloBvi@q?Wvur)`Qjg|1Z0
zXwZqyqwxmr%rP{@yP%JV^HnF5<_b)(J51PA*inQPkdsyul0(A^uxo%77$`;4vb3=k
zigSZjrPI7l;cyk=9k(`v%tVv)qV`sIKdXETSPKR-{tA5^?N6YVui?GfC||^Tvr#@hPm7?jmJhDa{4>C&7XM3*F`}B0
znKEBs?W(7V+Fm(kvp39ZZl?swA8r53Ilv>})?z`hb5&AnGC#;c$RI^GP>F
zf`$j9{@ourQwTN9hgS8y^sFoSLv$jz3i=zTJSng28QAl33(f#n!F>;W4fXdBo%YR5
z!|f9Y5CIRWyM}fRKQ*)$q_Q`EcqLT->aW+|@h(Lu<;mQ@cy3_ImpAFFjQT1gzB;_T
z=Kh`=L@qf#x{*Hor0}qRtMo?SSa-B&15vb771iXAzZC9gC%xt4Kv^zMR;`QTpLg8{
z-g16jHV$;Sb8^v|DE@hY7nj{ro1zT0e7UBSUOPN;c+57IG2AwG@ttRHJp10#vFCod
zrev4C(KKfN{?2GN+`++jfu#M+QLI123>&2zW(OXQJ31ctV%1O;I1xGcHCRP;SxizP4i!a7>~
ziOL3g(Sj_>Mtb7obu&G!r0*)CvkA}Bwx07B7~9bhWL5YJ(1cNpNIy
zV&iyUNf}6)@|?QsDMkc|Pm}EIQKGay;$Jh+cT4%v(n#vo_kHgtMpIj0@1!sBLb1em
z4eS~Wy}XYWc_D11C!K{+XW{Vv51jr5P!^gsb7EaPN{t@$%x0oT8j%1UMrY~5@jMSY
zJcqQG$CJoOcdcdvX>ZllhI_3>vRtrjR2^ZWe3idP2?_x?B?)Vdr%aou)%12gYM3&I
zeer;&qx-_;Oq!%-UrQh0;D3&+rB2hLt?7+XG(+JG6Us-aLFf9+c~S~~d1
zmB)r2`|cqa753X+a!sXW^e6uU+GttJLxi>5%4y8A$H*V(T&AIz9Yr%@C&X+cDL>FR
zlG%6jO#>?C+xQ|U4E3oOw$nFgI~gz>TaP@iwP}Tq86P&BJUz7B7#{0OrC-n@o7v)F
zzcm|sKud|s>~w}-ASqqY(m|pGaM43tZoc#r&J6!BZ?h)ujP)4w(ysz<%-6~tu!D28
zhA2IN6m@X}2Y0lDAAh!QEh!6d6b}fm5Cj`qSiqtE&z35Eh&1hgw$H$^A>+z(a9JFJ
zhEvZenZ}H{qdbn<*)_kyP$*5=LofJk2R(r&rGg?pg1=7h`1IAG)iGMQV=B%m&EUfHgtKv=q(Wpd9*ct7a6fNKJxe`JsZb8
z8}E7xCcRsu-mUCdaB(zq@y8&(YQW>o&KDdZZ%X!{^&?;L@KbNpec)R%m78}h<+YT%
zx#g3&d!xB~rwR%u3mT#Y4WHPoc}wmmTC$3+>>b(*FQj=}t$(+5_m3W%Dx^R*cMJWa
zzSnk57B)l+8>R}2D3Z;r%dyRx4??e^@}JXPS=lpbsO)})#hV3JEoqBJd&ZueNLwFq
zuAd7O(G9T&>5RI9BY}a7vL3&bc#iNb0_$@|hk0l04umbAS7LOOcaid!tLyivt~q=<
zK`ZN(t)|NUK&wo7pPqg~w_0ldW4HzKOcjV2U=mg=1Qw*|AmKPI
zJ0C4xKV!k~_wAq3pP3a_N71lv_>ltb*)seYfg9
zr9U6%C*u{=oABq>hEM6wOfGK2ed@E-u~~JdvDrG4ScNZpKegb`{ry&#qjVO9d@`Z!4xt8HUqt#P9mEirgy1o1Bnp!
zC&TNzQ*}Y%gxKDV{4OY^dVSfC2v#yu5jqyhko!I&&$x?1RT8}
z+=-Lw>N7F|xJbWOqyeY|6#&6;*l!bZiD0|*~
zb;f+PR4w#PNym!&9lCgdbrQhC?>I{e31^{FFu#ZN(_KBCCp#7Y20!V!RI_#~mqTMn
z$3h!%@3qgY0UHWDv9#6?Kf$W)FQrryH9{Bc3AM=TveUt`K&@U#bs3dMuVjk$llXm9
zccNbIKM$Xm{?7K$X_!bqqnz%6yaL`HbxUToB3S~}0b6Lf%y{f1B7YeaZlwQupsuf4EJx7vJ_o#9B;g-VWYi5ff#hOkpg$7HY?4jmwE1BB8_KHnVLwBYUm`=S88wdzYCReW|5vw
zds;AkwU$c%`*xBxuk($HXt7xcaP(UeFF_Z6N#^QhOAzC}z*kBw$1FZ?Ah|`jWBV4`
zsr(nLm+%rb@PRz=`~VYz+z8scBn;mfgd_pPO)
z?URdEeXwX%v~u?^lu48-n3ZHUysb5mBh+vHl-{qvE1|C%#|XGaUzvf!*z8Z~=RvwL
zaYP_qSwcUVamj=gxllS5}u
zU+C#(V8{mxNdf7gr%NTY_;m3Y$K)VE+GkM-jucQoix!UszTejG_|WbB&Y{t)Xck*{JaatHh9>hj@>udN-kj%*yy3EW+=mJDj|
z7S_Do`PRu>j$7@wOW*5!&l9b0p0y>c%>Re{l99^MgpVBwD=UUc87HssTJlJ8qvUcLfeI-ecB;JN(>Zhc`i2(ecuD5v{l4#iH-MK~5-08S%(ZoS
zaqoX$zW=v>W%D^`30&i4=MA-w6c6oCtVBjL#_Ut}Y6?Hu{9^N5NjawRn)R;}-c6V)
z-yJU5O%ZF0=3E7%-q%iEIys(t>GYLDQ?8ZFBdrc0CacDv6{=b@B^7VfT&@{^_;THJ
zNqeZI9qv+7Yv6+wA!_X=@L^6~J~@$k`Sf(f)=DNOKn<929GWlcby6*hwNJsv$p^P2x;yxdFV)&nX`DtJ
zaoUlofKBAxezzRPV+hrD_9>zqu1l3b^f}Az4O*>~L1`{tAUV2G-=J}1ku{F6KjqOP
zkIL})3?`(5^@}JNj#@*%$^*LqF#YvnjcEz3VD%U_uFd$Z7sqn0demX|;PZ@;8Y?`u
zsz->r8e*Xbo24{I3+Ne$1*&AeSQLmg3KeRULs>6qx2mB4q)Fv~DRU@g0C7=|ex+uN
zybb>StuLs$z(6y;j4+->S_a7PGZ6kIzZ>}nWpl@rT0*S
zREOhg@c~^-hmj_7GdQ9L>4e&ef@Q5*8v+C2D9D6nMQYw?T#-vM6U)d8*U$klo+Ekbub-xAjnZx-T5THRe}o_Z1OKwE2}
z0XMy*2^g(e1GfYUl+jQ)DBx?vbj&7#$pG_#PPo%N(I>&-X&jiDp8kG`J>Fo1hET9{
zfo?D2Hfx1?XJ?c+=WF;dK!}y``1E*AAN6`Ry+*@B`1P}ki_YpFQL{C~t9bjw6Jy2GB`a=}tOylv7l;>-Ek>desiL3J
z8e)t~TU@-Z7^h;s;3`6*ZqS%MOypKPa?B>~?Db+IeBP~a9(YPxO{F;KgSD5e_J2;l
zHSFzq%B-Shi0D#}7qc#}ug8ZXn6J`_SRSVkPLvTZLON%yVBS0_k>fNek$=OQ#6O!r
z<#!(Imaw=P9ZNt_jEm{;F_u6xYeL%s12i(c)Eoy#vrTu#DCToWZ@ec}Aox8VwSi+QANxMlbWAZtNz
zu(OuWWV=7eE*Wclz3)c$YGP+^e`Whze#O`mZ=Ab)Zd|(j^xJ!GTW=
zFQ0;&lwDVMO+In0@w;b3P3@tI_EGa|ahKx8VlFvmYB!Hs35gqP9DCyODu}S>T~sH$
z8`so-C-=?V9~B%NYngZ=xaGk0H3xpzbG_goiLG@)bSQh~79h9}36|3-$3)A-*73q{
z&f421SNz5cJBQkaOM#xIXT7v)s15o;b1t}Yd}+<7cVsifl%etP8Tmj;Ke&<=mSY^?teYR0|c
zf|bJwGp>T5s~iQ-W#+$pYUI@GbrZSa%nfkXS!8l$&BvojcWO*UC0MDGZGXAzySt`}
zw}%V23+KQ>({#P5@Q~S0Vyz!k#&2I~{XwG@_eDU4@w*Q&*-K$}LPO73PaB#+@RoMP
zqDYtc438Ovw*WZfG{im-sRt)NPW(eSIAS%-Pb1wmFmEKg172tG+Hm3(2W(Pyya{JN
z^&sjZ2^JV2@)x;PalM%jk{Zl|xB=KE4O%Zg0$d7)isZKl_BFJP_=0^6q*KqEG#n6b
ziU;jpQ^2m-ENSTty#m@5oaA{k!oAy{v7a+*p$Ac3364jHQX`~*Dt4r?kTB8&$D%I1
ziKA-a1ML@rz1yU50v2@Y97JdehH;hj=6$?jp18!^Eg>O3a2^pvpK5=q%g50{B_h_O
z5u}_=?mQ;-od#4=K7D~cvBC`Nz{q6d1eJP~ZpHXMn;;~J6zLTFGle0_!nxT5;-?8C
zHtBgJ_7k3_0xeyfuS7bQaK`z4I}rf&-xJ76M*3$>An5XnUaPrOGxqSMy6N2dP;UJU
zf+cs2uA5i|Iwo)Vf+;31;X?9|W$1CF&Bz^!m(>eKTi|J_koJ4|P|FAKb=UH>bFY@Z
zR)48JgaF6+?&0{ElJe&aw-;<||SBd==d24(}TJO3+^T$(D*1B+)a}b9O(tqxBhf4tN1pEzf61q5PiLL?8G0y``$Zw
zSMw&lIC1kbL97D8Sdip1K9}Fk%iQXU`MxWyb-C^P<@v2<+Yik3c#cqQ!3ig5y>H?n
z0^u+)@RCxo<_uWS+M0|)3W<{BOF>rrv6?CcdumkIxRR3S9A$6F7AtSc%D5FsBTSF@
zxcnQoQ=b3~iv=NO2+Guu
z>cF8bMmRJ`AZ)AiCgM#ge1G22q_!hCJge~(h1=1`0T(l3;5fJI)PA<_fgh6)ZKW+}
z9eC-vHE%WsbFsQ6VneyBhmuu297}vA>)}j03qsC<(Y`5XJtD&)uwK|zdNU>C!#E@m
z1BAIzFO{G06TJF7V!7zmb+pyuwQvNZt(X9uHo7xLT~DC30mXmAB7}*u4^Q~F@y5b=
zv|dYDmxIg9exNep!_ylVV5Yg(PAqev=J6dIS1f`ZNqcW4{w=J)O(m@`50Se_*$pz;
zlN!N{l>bZH5~10;<9~OmPu*g%$|h
zY%04coYFL8`yeTGxcqA;M;l-49m^PdB3RjcrFFvg)~?CaH#_hnRJ?w&|9WvN!0Ko*
zKs#&$?^sOmHFB>!;bM*>e+ZlXKq%QAl$FXv0Qt0Nxl#)a2Qyq*dc?TAk%j?N2<)+B
z8z!8U>V&!|>lOSHO<%M)ilozg9B-t-IEso`X&@P{JxgM3S;L3!nD7VjJa(J+nLo4?
z+lps$ie4+aR5V@?%2_kdFIu;MM1K)*u~A6-@n_+fInP#fyV+(dxt(OQWzOSPJl6Fw
zjQs^%<4U_wpL!|Ke&HFsiWcO19S>~h537C_nZ`n3ACEYVqrT+&5)=AaQ(8U+;0a%;q9MJ&~+|y_P@@4^L3u
zdiTAA`Co=mo^xvgeg0|SalBL$?Ys9$vQ9wdmn&6W0L=wB#PLU?g!Aq%yIa|VfUioE
z*ppZAdh!Xbz0!p0?DK^r`zR{PO?XM;ik0q_^^Hx9tKDnXuDe_C@xzr!TluA0cmfw0
z#4~bLen}2E&VXWR4+Yn;+9EXsSs;$psMk_sQ58Yas7q?q_{cJ6+8~u7S4>T(Vc&9;
zG4+d9nPCYk&I92W@l(}&@bMC5X^*}CImn~##t$jnC#gbw1E~KI;EPm`7P7o4;&A$$
z+LlD{&G>k_N85f9(YAwc#_5Duyn2{B^D%}{Fir@$kdn|B1>@0+o*cSyxQ&7r_8~R+
z91kYFF%at9a2DMvsTgX*-zB6eH2*}AE~Eo)MXhPD@yKTQEqtbH$@T2}9M-ccS$V+q
ztegO*e$`_Klw3&4pssAudb%6#2(@P7G)MYJX4?!~B**!4T6uTj5(1POvo;A=0_5NH
zKO@%OuV7z5hWrtRYl)q4&-VR)w1hQmt+;ifajf`_+CQuf6}Ji&W<;B53K`LS91kj@
zSxSf|IPZ8DeStp@HAg+aSyOygNI9oTMo6JIqnD0bg#1{OE*tOud-n0?)W=?9moI8o=PO
zXLc(?joVmqLP8+J3}%leMy!(0&>a6+G)IFPWQB7Nd2eAcW@OU(mkHlZm?~}!7q-G^
zd>@3vADXB;+jsxfjKkccX<-=G}?
z4Wd~5i_>H)@^+_P6?HA%tQ_P?-SAp+{h`a&Du$(fsRk>`4(6QQ$e96^!D{FP3~>#{
zgDt0uU;~pk}inau#p3?(r+QPYV0Mx(Os{pqvSy?vC1kX>e-(cKxi^1
z`r_z5=nOcGgm;nbLx3v#U}7K^bov%qOqn#897qbl$rP1x3gSb!pG_q92?tE*b@IK-
zWR_(7U<&$}bn1)9AB(4yV{ipQW#CyUyA6xYd~u`rI+%EIE5;zvYiGaDF@Z#+jgubN
zi8?iHsyHTC+XHb%qXp#JbR|IVV#@Q5}P+fmCR4
z*`CV=i&X^BAa;_fp@nA1SHRY(>RSbD&zm*V30^}^J&QAnFF05)ub77jUJ$1m*w
ziZfhsx)Gs0M0*MDl1zgM&m;_+FZPHhFlg0QfkE3i=m^C5%TSv`SDV9Vv;tP1lcazH
z>~X^sa(#|x9H{Sg)Q2b3M-ZMb)VB%nm?&_*G^U4KcCCJl4Aa>SM_ToV2LZf6>C`T?
z=${ovGDcfJ2FnK>zk>cxD*ab#txgn1`4MN@=Yu6wn_1CmiF3FJCxFUpHb9>p7z`cL
zBnd`QLr;9;nXf++N?IX~VG0TD11Mv@3EW@BpxLu=5Zi$#;u9Q|6@cFnJtN4+GT?kX
zEG3?C0A4WH4;2uL9e+qB=%>tX!7pbqE+N@QU66&iyU>FL5*9sc8gKm0syA1SS3D~O
zwOEN4xhp8
zwCe80)6?&hdOiK!PZBRc_TOBcDhLoJO4z49d3F_?>3@%^SY{%fKx?Hxrk^YkiIkYk
zTKx!KDbd(UERZ3JpgK)x-%Y5Q!0(0X@o5&y?CI;8b&5w>KJy*=8hgys532wnRk1?!
zykgdJ<{0b-IO|dHEm)X58z*xyW+_eMtc}p#M(O*giYw?8#SlLWjFPBJCysIImsc!p
zhi_xifOVIi3HeG^-jI{j_~K?#T|==5mVZSoJv|TzmemQ9*Y0Nt289jd^rFwoj
za(uYLXAaSU6Beb6=>T{G5rsrkCA{8nDcH#_F7&eXb@
z;)*x&FXxY+n6ykj7B1dC0taiOW%EghG7R;
zXuH7499j4B#*vL<+YoqZ=No%3@4Ze!=G>QekL(VW9T?s{m40w08^&gr;)ix3+V0T4
zTaK)tqZHjv$r){>ppm7OZ>+z(e%Lvcf{46@BC-f1Tcf4HqLyn-5FtUo#T1j6^vRul
zF{boNI0Q{BA`5Q|S$LOM(BBejSmH?HXcs*fl@2>+@(X__{-=E$HlK8KhmIoGplW-4n&oik;XZ*0H3eKh{(pF&Jd$?Ij8sAKD{yK3i3VTi7XwNl^7
zzM4HrZ7Rzg-UIo2aoO08KS&(j`PsY!`F?t**_4f0vZmJFPj&P0Ncfq*6^r@Zxb*go
zF+YgO+|d;CR~zGZG}?X`Te@wz?T5>q^t`@ed!_BKD_dgm(VAbWoTLUo%*a!W!HM5R
z=Z8jk7p)&}eBCnE@q1U{-+uW_oN3nx_sSxE_A
znmig_>lK?u1Zv(va`4la*tte^?1v9%FwSxl$=82YqTn5*8NxB);1Q5<
zJ;YCCzs6+C;pt^l4;=(+4*z8Tn@gHFrB?Dl)Y>r&bpFx)!fA&xe`*-?qn}vS*{si
zSEm??NB@z!n?|?i=|-DLm|bf^(Q_CBojjDrz}S+SWPdCGyhWTi8c0Pb`XPj(l@XTI
z_)V77_%okEX3#Kp#-D}k17=&&?UON(f6gbFZClM_U1VLo)%ZS0+{&k2!{~Ma;`75l<&qWN%X0(uU_Okd?6NoB8PazQ%8;S(1v`w*VAWo%?MsHX|
zs#+DZtn}Ve(16}Fd1<3#y#$nF3T-3JRz(sTFp`9pV#iZl9c~`kWD`))`lV5B2?}9j
zBs&fKN@b_+Qn!1Xr@N=vUAM`7ST8UYvQiSWMo3N7wwAijAb2!SnjfTa7ZIbn-U-O3
zrdE4)e}Z6lKqnSf3wa=^F!gLJe1>4yqr1k!0l#?+ai*K7a!QJy!e0!BTe+R$iX8Cbb*3L2y_iFKwu-PZE4N@&epP^2moJ2ZP
zCRxIBza^;YG;42}W>ddt{WNTYioGrt=z5_5uH%OjT^EH~2EJwh;^9b86*XgwXfh%F7XpJ))Jg7=B%XUFq@9VZ?u*`f`{G`XX*H
zYmPVcy~wCF3u!+_4|Vz-#**3$!wLUg)a94a<|Vx-D)QT<1hs}%ymy!13je#X)|KVA
zq#gp>-+Re%{{~A?lj9o08^|Idr5S`_~Ia
z;Gys>Oc-6yn;`{~pG_u6rqT!FAO(ukoUjIB@k>qdJW0~xo{57zORWL9D#`HiB#9oP
zE>&7)hqTNvg)A+D(Zt0elr4-Wl9Xal_C`?PDjUH-R;KHlVY*mDDV{n4kd+yfPOZ8a
zRAp8Ox%b;>l0;fE)efDl#eIqdBsxPB1N;dp=_=idu}Y*KlqsF28_9g6GxX%a(~?#b
z>ADS~N`wB0_6ON(=-KtESJCwNdSb!566=Wt|J2A+GwJy==~*-B1)vVI(}?++Hg7|!
z`C5}R`xoUj*D<5nl9;)e(VQW;%9g|`_;z`D4dP)xcHLDmQ(7^+XU1LnM%?AN;hjJK
z1q0D$nY(?
zM+HBk(gKv7FwzK0=zsHc2^GinZ-u8TeTC+^4!6a2>2>;ba!)SqKhUaqmP&h$ZqL(=
z*_0~tQu->rdjYp7y;$Zp<}O{^O)46WLS+(3^|knmv-;qz;Qm;B#NU$W_AJ`qKY*FP
zKUQCoVD;h8g1Z!)zFp>fa{8#2E?!*nO`)$AB)nK;@R0DJ1`jZ7i1)@)Fhe$Ih=bWf
zf|m>)%rJO})eIik$RP>Tl0*6sP4e_WXG!JmQHY!eaZ6b1J_;65w+ORCQL=?+LWK0u
z8#~V(y_hW{aE{+J^LPUZ{OeE
z-r?T5=TN)*p+oy0+S88bme$?wM|SKyi0A$L9_c92tQ7nwJZF5J{fJ4XEA+s_hg$Zx
zyIXheZ$JCKx1#Gl7)V74i+m^sa^)3Vn>9PwPc2&zB~_;imDRIqAQMvPA!jr
zae@3)RliHcc#CJi{ls7Zt+I#xvqPn2r92$I@{Zc#`pWHDl041RulV?
z6E(Z#<--Lx%d3y4&)wM2Q0s17(O{HIUTr+m?o|z#^TP`frVtEfV(c+R+@
zL2iV)XgTYOhT5jcoY75}yUOfYe{-`ouMgg*!<8aWWv#nX38@cul>lOlMj~E+FJq;DX_In8-{tVc_FCl~|`Q;6GdgC}`
zIB+O&@h=5iAy@G_zAOJywVpY+cm&_@SI^z#L*;H_hDNYZG%>?L#ag2gofC7Rdc$FR
zlG!A3rAP=2AEka_KC=|dKaq|!t#(x9--m)V(+$K7y_dT_#j=Z7cZDUw#ftJbw-8~_
zlLe(lW2sy;IV?8#CLaFRQwPJ@4RtVe@c8FinkSVRa2H9*FuEMIL+;nSt@M}Q9W05U
zJ)rInHZ8OKx=qVUc;($y>aaCx<=dj|l(dy^%H^Lg_)7!
z6jFH%OH$tc%
z6#rl>O11@JN#_x(Rpp4^vrX$3^*vK*lTwRRY20%oH;G7@tK`@IvQsA+prO6%*(oH(
zt5Y3`U!a|ZO8LKrc7k6Zu6wrAy=XkuxzJ{?Uv0ZKm+X3yX0t>c9qd1)R)mZzQGRKE
z(Hgh*OL-zUQwTVx=4R7aoYFPeO2zZKOrSe#-4cyFQIlMPE?AEx-Q#;QGV3vIUs>~JHR1_{%0
z@lJo&^1}Y`DALA12~(4c#{=>AOnn|MIk8v86-ZQS)V)hq-mw*3jMqx`h*(wE0!gsx
z)AA-M>AbPBO<&SUa$Xd5!G(tDit0{`X2l!NHhmkS65=PmvET8N2H#|xKI1wPjO&nX
z`s~s=ujAxqgZk`nJF7r%tad=}7A2K7#@I{AVlOE@9!%?BqoyOfQD-0x!9f#$Pj&7F
zOF{=$h5n?HGw5n8TY8TxD`M&MLZ0(dhTIjRee4*{(ch}HO^dEJ=n6Qn+TlEwPmXpa
zh4wenx>R;fmmY8h(z#UE#Ue;*V*)O6H%F3NgygoKyYDB+WE+&aAOT%Jm;#w>N+&G@
zzOaTDoQj=q3$WOi7g~ko=Jgy-~yzuc!Gp?wNfA2ka2&d498q_
zDN<9Tepe?&;&7_YLl5dwRkLd`@b_>?OH-{gNHZIO6lDMc=3_Ckf>nKlI=13t_9h^S
z@b>v9XvPw}{9;DbRDr932FgxC-ADqd7`eNXX3EOn9=KNg-hmryc77{uxaH+-Bimle
z9ewy)$*^#D!-*_u-#nkuWFF0LG9RoqOXOE#n?#5&8x%$mdIay-Vvml3rLZ^EmQXrM
zg&5k^33|?`E3zfwZ=xrXm-3VRO7hVYLEVVv5D@3)Jbu^aXsD!az6_55WxkZZIs-!K
z_%Gg>A?i%G+L>cGo(3xScKbOb4{5xDoy{7U3WL)v8zuVPa@68dX_T^uF$7G`&c=b=
z*?8Im-EvwvynJ}&u!4((3Z%cshuL_AE9#d_lsAh~-@$0jCY?t3wQlY6f2HJ!{8DMf
ztX+AMev9&Hc8HDilbqAe#!9}^ebARTQbS-{%Tv_utEf?!u#oAcR7yW9@l>5*WRoac
z8&VHvt+=n4jYXtLvQUh}-~GNPy!>L{nf}>WZZN#mo+cIDeWaZ`>pbQ2onb)~d?}Fy
zV|S0wEA^rsvv%YsqTer+9M00axYJ@HW)u7SVC&c^+)DbT^%z8d23krS$VHdVXfY{r
zTW+U4_z%boJqQZ6S{QZ|&gB)sMFTctbsc$yg^LC^xoF6Ti-wDPKsuFIzp?A`t{=JD
zN1u4RX7b_pEH_rb&+W_GUfLFPwGXx7hD5?;?oVvi^rTzq8NyNCbyw+?T@z1yZ{>To
z_XdK^`=@FT+=gHOw0R3s4Ykdi@CTarg(YKcmky({4t+VLR1W!=^}Jp<Jx|+lxx|&N+@BM6orU1m+yY9
z`BL*wEHMR1GnrXe9-lOSul2p$zkMvY{*fDXkABk(=hp=^ID66F#ME!>eQ_@ZCtn`I
z|IX!K-#b$xA`je3O&^Mt%|0)igJ~sX8=CQQ;YcBVrIz4ZYQ}VGStzya^25Q@O8m~q
z8cMjuhNNUe%7&yjli)+Qa4eIoH!DI}4MRI-oM~k9d9g!#$bgAqa$@zcc|Im7wR)zY
zkmA^mXHTrY)<1eUT(D<&8~mqbz_f(|-okTn&*dJ3-w0K#ep`YM>$8)daK)CX^cE<;
zjBXzZ%w!k6mUJm;?1>u)lbe$}dhB=eU~TzY;-$nf&yDP=`65(x$4%ZnVZr%o*I3mn
zr>`e3n<*+AcHUlQO3wSR!Q@Q)oDDpG>`0qIu)*$;?uo1)xz~-iyzUx%_zyF$yVr#?
zn}@c~rMY3<2_JehY3n8{Cv&b92UFUhyF*r<*2E+jtH!$!0~jGDew6v>=)-R(Og4V6
z>qf)YYft?3lkYwmeE5;;+aLMn6W22z4cQ+ZO86kVY;1oxyJ{$LCN&RsLF6kHAq-zz
zdui?1j`6OEb>X~?7xoOb4rk3cb4DK_pQn50ZAb=}=@^y0L3W<`>1_{8OShRny&Z#f
z{^@Ne*663V6Rah4#{&A~POT{$!9J|1<*H$4bq(2*R*Yj_I)61@>m%%k^
zIXO~=<7APB-or>KwftwdYfQz>pWaR}Wj$v0cLFy2r;Ls!>$|Qbx;Hj-th0W9{icph
z*7uS(?Xy__s?@#DZvCOviu?No>H896{x(1Dp$7YZ$;fzURqTIRmPGevEAD@n82?b6
z?e8)h9&*}(&H_9KYt6VvoOXn%0IZl6_TxsXeZMk;$%-l(EBu*e2vc1`&N_5
zS+eMVN9CvrGQufi@`G6&{VpACn(2`^+US)1C%Q#@VI(;`3*+yQ7Q$}KA!{M5vDrVA
z%ywH*gvAkllf@DK+)ihugIJ-9fIkZWvW=M+hYbiz9(0Q59V%SiKZ}{=#j%
zTBLoDM%o8H8)*{|VvqQVadJFFE8-#ADL$f){kg!6Vl3P!CU{+-4oTC%<+c0Z>&0i2
z)5jydbJ5!byoCoEq!QW+4rnVR>3%!$JK38EorV-|x;Mj{^n&g2RD4H!yve99Eym%@MS6OaaRN^^>vZEN4#fT
zROTGe%Or}$4dxhma6?crOeI}VJyj+Vz6v$3<_f_neNAH^-aQx_
z6jxCnU5Hr>n>TTR=vA3q$~(A0N>iSdJnYH|TPFI_0>llPd)u{gbsommkm1I4sWmut
zE@RZNb0{?z`3!0{O0A3GJZpdPwoLn_JY7*|4kWPID4q*iM05~eNKvIcYk!eKwQfcV
zq7kDmq#$gUFN`=S;ONVcS!Fg#smud8l!mx4rbD8zW7XL@pNmYlRGHGgn(DZ$JB9n4q`pLA;&*&W!JQ?)iNAz=wZtR8aBYMLAF-f1&Qv#l<HfR?rzZEo3uwh=!E@(mz}DhqrA3)AmL(Vys?KW0zaOXeII!`@eS
zOgYNuvI@xM$m=V|t>LUXMEHV3@UrRL6`|Y}Z?{h+H^Z&TbQZ<3n6QVl){R)_QuAJI
zqZrNO*6FG(p{gxYsV#F^g`-b}v#Lg{z+FY^x8o-5;f9uQ7GibHC1;RN@mDvFmxYs;
z4_Of{V#taR>W<`~BX6d-e7bmLsCXrr4HUv_$aKl7Pzl0MkR*~qZI*|eYqYkk
z162&<8O@=@zRG=nK~qS(9P}DG*L|rwSh#Z7`f~h8{Ls@u`})Z=+=Ofv=e>Fn?}4$g
z@8My|mb<~KHf+10lXi|b;Wb~0QH&!FL_}>Mhj(`|oXBEPlmTNqVAaH!Y(8Oq#(K`I
zFv;LWRs?bw$mq~JFjl-2RmX~RjOcX{w1JfT*`9zM5Gk8#g5F-GTQO3?O%S{TDf>xw
zAw_Ph2MUblf=^Eh!SF842H`MFJ%3}}g>^xPdp^brmHw=}m(P!!*Spzy|7gJumw6qNq
zuU|08N7r-B#_x@M94fLAfM&EuTubDpwnbf`14`2j?%G4xYC8W!d=7sg%`A3_dMqYTUv>w3Rmj{)!8@
zsX9$6Mt6WPDx*yRk1wqnE_;DC5ZWHOV2$v$=c-ViDp*zOhQmn}+tc0|*DT@?Y4{0k
zjDI~XkuovF0Jw}CC15}W?!r4ZhknvZQ8w%Qv|!lpN5q1mbOX6dFPOilRq_p#Lt7MB
zitp7&ryLbC$?2nQ)A_X_{GVJqmy$6OHpJ4bec8xl${
z8#_2%zA99{YT{_9eBD%fGq{YT0CFeJl$ds5`-P6tRZ}9^iM-{N4Nl&6$I_>Z8$-p7
z6No&uDss803knTX_xc(9h=RHIsSETR5f27X*y#9GpsgNS%CXOx$md;p8>73}w{M}*
zaBEsS|DA@sP9Ac5;)S@7UD2o!2ON;6Z|uCVbK2<+Io(svl6&pHizth5j({0L=VZ+}
zFYUME94SOu;Sg+^g^*tPvXsN!=khUB=w0+>7@I2aK7`k>kHS>Dw-OP9wsc
z7Ve2hkHWa739>qw(yFj4<;*Xiy(QNsK83U8NyM>0H{f
zVC{x$*2yPBwe8`wZ9(U@#nERFi!N%^2?HMMyWw07yw@p0S415CgvK!3`yn3mdU!_T
zg}{pHf@1|3%884Rf@h(4L{72|X2bw*doB+%V({J&+UaHlxg4TS{aq6-6ICYVp^=D$
zr1=`!MDxM3w1u8%9u!EknO@{0L*!IZI%D$aNl#C=*VFI&3C$7lNr^g2`9|V}#2M#_
zIZz>4*&oGO;}ZZhoH;=7;P!85?@UtOrIuh);aC}X@ky0K7BZ%enyJE&vvAZu&l?cK@ow6gSeJS+ZX!@WRpby<+I04G$LfV+$v%+&~HpT{+6#-+x
zLS$Yb4`wty!tUCt4A-}TouDNR14y!UEOL0atRJbLPOA>3RR>dR#!IdoK)|k?t2u9d
z8H;|hC78S^Xx}6#6+IY5Zn1jNNDPI%Tcr*7waB(`lBU#f_c5mT$cb)PJ)H4$`Rr(z
zbd}b{3X~Hu^!R<>_5DYx&k(Z|*o{`9gDU(}r9#bB6oVe=3#b!eHdo<~)J!+hY>`^%
zMhqRnG~h|moJNsCGsn=Bh%S*BBW84rPg(}~vZ^Qq5;u1*;f;ZaZzZHFuI6
zh})BEwrv*fsWyL@V2aHQW>$o4l{c*=3l>vs)r_^|$F_`MW@Xq`b<ZNFcFObSaG*>ysv>m(R1>z=K6+NuSZT!}Xw>I6|SZ}O1&TD@aL3+SVPVm{i
z4xjy4EL*lYUr2(bTN1d#2OObE2g@UzApUGK+}
zxES9CfYcBkula)c71QsL!ZQ}OxNwRn6Ro_$-yt(%SI4}dQxIcwfPq|$Hk?P1BQG8j
zSa^}q&e_ww?k=UXR17tYRW?fS5KTgWxgl47!9x0DnonwCvb-4`ZCLs{lon-%`ZXjR
zXfPZpm1(C_oRPInatX}hAK}DT{1c56p100VZVxSQeOACXRLwYeBa%qW{#XZ)p&XCY
z3>_kVM9)1eyn9o!sN!WP^;4XX&eRLr!9XJ}UHjc&c+Y!wUWM^tz8
zLQIkuqOt^TB2j+SdTf)|V;ir>Hd(wmhm_k6!Wk~Hsb=GjlW$FE_WTKLO6FWq>=Jb~
z5hTHH0S5QuA&P>uDqK5exXN$`NO~j?q>x)G{4xl@bx@k8-9~!}j8GLw%qBpO2(i%p
z@TQ0Gp-NMm&>)3h8rf_CKNNnc9)e^>O;RUWE_HU6(2$X?F+di)bjBwURhd1SK5h-#
zA%Lg@<36tpQh;RWn&3|&R91$pH|)7QGo+KJUZem>U0f)`T~FO8=YtWkOzNi!ux7rq
zzC^ibqw@p#tN{xoTJoSmzNzwV@I{q$apY%*+D7#uU{jE9#C-i#7=v!tIe)+(qqU{KnVsV<1HpC`T~bv?mxoT#GfQSbkv1>nNhFs
zQ|UXFsVxxSsn!>W>sN!>C~EggT2=>+LvR%+6GvZOOFxWY#MMvOEnfjO{EJcsML^9p
zoh(&SXn&QF2PtF=*nmUmRC@c%m2_H(g9+%F(YzXlZc*y*uT)A>>Kg!Vf{-bOqbtSr
zs}j&bXD{NhzJMS-F{XespoV7YU#658a45CV3OPw^ny5>xS!Kq6i^X+Fr|7i(do22a
zSPn_*{_j8g`Okm;nR!bDDMSmDu^pn~i3*i58bN&hIkGQ`I8hzB-3b@v*wl-WmR$q^
zsNiQ!V@=Nra1R=YV~BFx2!=4Mv`OfbM8~;wi*5u+8IzWNOi#rG!9JrT1fPU5X%*hh
zT2A<$5?aZ*SgsPOh)QF)&Dz*%Qu=R{hlnS{(qx`alnf{V+7>6^76>sRAl7BPkTBKR
zlruh`)amv017j5NBk&b*UFBzpe*xqOv7UAI!pPp|?L3MiPR-iHpJeE6boT&5?>x(?
zq~Ak3{6yywS)g7z70s+A2DO%k@Gv^SFf=porAMYS%0n6DV<#po;f$uC1gM+ECw?RT
zLj1HnFJ#Xf-7$7@^0A;jZ_2*?gN*Fa+_6W)8TCU6Gl&(w;nIfjgmB(UfZq=?a$kBR
zShPHpv3#QJo$9OAp^WuN1a`*e7dOx36inyTg3KF#Je;$3XxCg`l`Q=jJNQQD<<3d(
zU!MN%X{d-oJCt-o6LY4WB_U_YSkoKLmzya>a`j4zLQ#Qe;IEdBo*ds0DqIuJT^n+u
zuv_*txuwTmKX4^&eAior;qtYUX_GEQHJdJP4VAZs%iDux+pc-uPq-Ec<{zB0ADTl*
zhnjFo`H<}v#ALOXYRCGgE7yf8*M)PNzxUXm9}ea27)ri{)^B`q<6LImh3!AitQ^{Y
z6Y(Z&FD1R6J-$3#+#E`2o=$ELCAU+Q^pj)N@aLV9fcOvb2?7=P8>}b9h>yZqTWA6C
zg5|}@>+*Ser%~xln;T)YVgVC9m_oC-7ukT#ei&mxSla}vt=&9ae#bMctHuGo(
z{c1BqQE}a-_xo>Kpj$PQUOdl#8xhl;e(%`x5&iu*z1SwVo67G((dvcYd@XFkpGeB>
zaZ98^l}yK3K*vE@ipg3lBGB5Iri%w0iJeVs=|8|RUk~(qr2c_VSZ$e{V(2{#E1r{y
zrXnZAM}5b!U5G-3))Kv7Adx@|A9O0->wPywRG^F7S}o%EknRI=R8crqo#PL91;*=s
zzxyzM_>$%j;eN}b)E%RxIJr4!Z`MG-n+b*>Ac{xFRP53l|3mCS
ziEa;3bLgn&jc>Qv=hI_sC3+UyM<%@Z*lw|{2VrXyY8;&PSGcDgE&Y2C2!MCA=RaaN
zb(%OM=1+WY`*WG_Y_PnI-ba}4Do-~N^Opa;X8{Kg4@Bgw4
z5{-j*pk?sygLqPX$2zHv)lu=HsZ-U>YDv^5;YYlGNw+nJxnQ^u(fU^@;zd(#?Q6sc
zAO%MfRqTJgW|=-KnJ_g2S`-?udPP}61MgA^z@zcdAFYT5W{p&U*9Ru37^L+fQ0U_
z7oOXA$aJto@R*Mr(TX{8#O>|FX9
znZqCg_8ybxm?Q@tcV)BYISj&5Pv<%K)dSpq1b?bLJ!ejMbiU(6aU0!Q!ezROt5BBa
z_l%sJF)4+@m{6+{xtF;QoIS%b5l#<)yRX-`Puklj`Kr`%YccVCXFB_OH*zKd!~LB+
zznxH+2fkKS>8`9l+1K4$t#gg0R(ZIw)?Hs;|D`DG@}3^V&@e=J=-aVqYQ`V(gNNUJCbO{Epl{(JQS2#k1Jw58)eumqj3*9}_fO0@}N@b)y3N
z-y^tWh-H$ipd0qQyBq=}0$ozj4Tutb2@tPw;@E`T3cj0-v=e?KW+SmeVY&f~6Z+dH
zfX5)<=%1hzVYwM=MDa^o==)mSm@z@eECO;g&`XB;>AF6vK>spzdL`04YXZ3oDR<6D
z&U9*VD7AR3YP@xFT`;vcoZ5aNcE~)ma>kkbP4m#UTZm=WI`q_#@R`KMJH`u
z&>7k!KnQ9hvl^xgofvQXY{EleAN#y~9K4E#&~b3o2Tbrm&jYO-Xv-p_2TvBg8r!SCk9mSf}e8$_4dx`YcdxA%ZsUpn5>MaVT}M
zz?eHlrJ`n%G;zUIXt4(e+eWSD)1=|EccNXHVluJbhF|A?iATRzm73
z`MEGRjVqmb@={s4DOw{qBhFOixRkSM<3q#fQL%w$HkWEXvIi)?B
z5QEVa=GdcJRMClcgkCA>TG4KQM_>QW-Xol!5D=g*Sq(jU(z|S9ct;Ar(qUzg=1fx}WkXlkO&`uboJZ^IqFLRVAhD7WT|}g0#T*zy05psn>ee4w@KV~0@1+r
z4Dy%VGd~x=hXSb~@bGq77)XknN}&wlWQ=0sK(h9Ae2-H4r5sV0!ty@}mVfl6eA6?3
zm=y$=DXzQuHPp=2puU`<CR5+f8sL`#UT_XU7*{GxXBy=8DIJu-azkPMFUhEaj_ui7U4ED
zOwXDSg*@?U;`e;l+TJe_VrzJiCLr8SI=FE3l=s^B{q_GgwrFZqdxb)
z{4v&>rVZX4RFIN@F&dV!yyKvY+1Onuk}V^KEDzYk#J8wIu1
zqWvm>pMV6U`eqFT0o2~5eaZ$6#N;B>&x7=PFkaID@WyCI!&0?*W2kLPeUZQ5+6!QE
zFag$qafTyf*V#|2x^{sC8eyeGWyDxzg~tpIzv4NZk_s}*pcn%wxnnS%-D^3Xaa`O8
z=UVuy+5brl6veC)(cGeRX#@b4xH~3qlZ$mXXLa
zlwL8^K9iC2@?#^9sWM<&IAisNZ9^?X{`oR;JHjOAe32=q;I;Tm@vravgWaL*Ax*TMm&opJZhm$|K<1l5{kSmiiggE;4&YzMK
zld{j4!SI8e;i!Ss;%p!q{fwr#(8COv1gZrl~j#mv;ri&twm{bllZ
zli#<5)mZ2#KeL|AS#pdqpA0q8!5HCu;(}nQWTUZ^$DceS&tf1TW+tAnrsCf1YRs@QiJQM
z4FIcB%OSG;Xv~I#En7FCK#hQ{b)WA$%VT)ja~=_Q!6^nY+eNWT6si#10xC`HQHAzBTGUHp*X7HGNyLQWjN32!-h6
z281>(5ELh*l}}_mM_)^5^+7vNZ-Fj5mbB?kN^&?Hb6oS#5evP&Sg&ORDj-+HUMoN0
z9QWGz$wnPPfs4gp^!
zzi@fi9eKB0nWMR*&Y-I-=q#fj3B#L%&JxD*I)qOmn;{5h_)4QIc$Gv6Nht(b>Gm^%
ztaNmeI!q4KVOBeAvMmRFjsTN5W%*jzhCk6v%}9o3ggQ%{kYLH)ddNFaJhLwohc9qq2Wwp&GlrIwDiTEtVTb$9GL2#yk*OjfmeC^op?FZ1_m-6cqb
zG?b*I-Vbw_{wlpVsMOu>fh`Oj1wtzT_BjaiPVY_$79k14B)7(j(($s0J%xIosiHap
zR7-&BAq4?L(b&_DE;(RT~KkDuUbFLGd1&zx~
zIh1D735{kdKe^S*+*N9Csh|3f)rU!*rtgIue@T|a(irOnizW3XEDjZ?Gz7QDdip&5
zy7BGp_Z`QYlLd_&q6$?$Lp<3kWEOHnhO!X~Sp+HgU?H+5ikBC&n3u;KF9it`@kA&$
zUr;;Nl)eoO`riTop-bigspKfQH*i;Sa3FIV>ph+AB}4%NXhzR!-8cs{jW1?CFoQ$0
z#$>8y34vU)*rzI^WiuTEtI>#0qEx(61ChWa9*~bPU8i^Rz@U
zG+{2HO~0WrZk{sl2KKjmsh_!`pUJLob%9u{zEu5EZz#EJ%pXdw3EFE!M_9krVR%+Y
zkxQC#TPg8g{)ukUiYjz|@*!G5^-~Tek}^RgHN@Grm?Pzu^kyN=V#}IOFx!@mb&*TJ
zWujSBP!|uZd{fvk3*&g9Kkp&HbdXEQSIw~8gzYAI?PITiR$r`9EO5T
ze$vVIov|+@!^2=4)q?1Sz#hC#Z#;;y1aBfM$|gWjRuhOOvG?MRH_einhKn&kD?QQA
zE(Na8N>SI(|A8M-Pztf+7fBo}PnrGjjt(>#Xs=$15U{|zyee@(Y!H>Hr7&QmRIEs4
zJmuk~Kbj|cM!jkJqb@B4o8pt&Km_Fa2-Xz$O-ORUh?6a5bz^V>%m;L%Nd(52_73viYboB8Vyt`#?t2
z_>qRpzFrTF-bOT#bk$TpD$(OoS`{p98Z95q#2_ZIUk^B$SdSAz{O<&7kLT?NueIVzjhw)g=$ti
z@I}8gK`-OszML@~Ka+R7&*htrpv{h2t?HqDoEGdHdVxb5h8{S`rgLjTxiv${GexD-
zMJq!^FkZBuB+UGUU3o!=D7ZyMVBq21)nx(Tn$Rb#DF&Z?W4
zY%MeKSU7XDAcp5-objnM<<-JJP_TGauwd0t$4r{*rmOH~IxF=|r8nGk72hmqoT!>?
z4Hs+~*>l7=nAj{)k8R)N;H!`tSTrd}z@n{e
zbPz~d6PB~mG61n2RzUDtgsg}zy$6kv9-~_q-Ei2;2dIOd9;Ms!^x+QO
zGvNi3h3At)M1do0hC=7Tzge&&p!!Y|=cX{1(X;Y}QDO|cbl(G7@DJ3y;
z*!)3y;ph{u*WE~On90t0E%BAax$M&E?7gAvy>O&Howq!cxBRxnoYMf~;EV$Dbv_?s
z&S^LQL;LP`zc7=(9lLriAD*~g*)^TNJe0qDCcogdy_fbb#M`!+b0JkIEB{Gqd`9Mc
zGAg?R=|=`xbySS?kAFFwydh}cAn?mt8nnN`S;P)m7Rw75_htN>$M_#9Ig1Jy3ua`F
zSy?=?hNv)37PxW6?O__fXKDQ4v%qfJ+-jbWOSI*|h0vz0=GzWD-b#XqX0#xfUIF((
z^EUbjeZuUQi$;pZGR6icx`ME3gQ;5TdL?IS7I{4#vyGjeI1sE@8*;CM9ot7#)_ftk
zQ5jr-%~<+^GuM{)@!D+L#t%)niJnuFXhEqLe)F}Ek3UfY2Pg&t&$R&0wVk)Z0Guo-
zJ!i3y5(s?n_nq*2ikiNP{%+_`b2CUtAnX2u%Lb)0Lsc}L
zfPpwT9(YNSPIvc$*8%>OpEQeleLY;B+g-(q0_I)PIm
z7-}RnkklcOi_)r<+3E(2epQEA;cfhjDN*02)-+2+)KK6`%xKbBZgy+>$`QejOXTrz
za|mrlG>lcQsccP?nwVePU^H8dk%dixtSRmGKtmFm=a5pt$`LV(%}V%sYt#?*#l3=9AdLCrN<+EaIai;C#_|CW#yY%5w%i
z;aLY?9L#FSZ8g|RyKTTH^|7KYNDXE8ectCyL>)^XI2w$XwPt_qM~m^PCm@}2;2;+I
z>FypV+XA2|l4*58AK{_ykaB79N3vI?gqTzse-nO0QXq`Y;ybWel{ux40KjUH
z3bH}o^}e0&di|c)jm2tHOlS^9l}_K&=BE5|`$Wm#KB=^8{ivfx&Uo
z4Kv^;Xk&CNrYq(#SV}9DJ=w1;!-xT1s20&0AupApR)PI5X|0&98zq&T{t*q+Ze+$V
zkrS;g<~djP$eNH#Xc_GcyEX-#n?9LKDO3s8E#?_l=Bv)J{o~&0`c0wwO;g#MgRafj
zotvSWg91Kdy8f#v>85X0ZMOV{d9&qL2&;Euk_N0_x;v~c()HX3SkGY)q-rcY0XJ28
zU@vZ!ZOmrZGu^>V_bzoP
zu>BBN=f+2i_-aQG9dSU!iO
zq_TXP0okmLpJ(GlC>)GScQ0kVZJIz09RBWLOT|}RNqyAjmipC
zh8%zKHeL5qel$)iM6O008i>~bcabZ9aaqqov#vME_?yUgEM@@fgi2>GTm~i$Qa1cp
z6)R;MxA`r3CCOf`483GwjtQporSm)$*H32}Ul$PU`s;hq7g*k1iG52xO(BdiSI2og
zfQvhXdLE8=VL|5h;6dIiY==y!l7_GNWz9Gxjb>RR)6kIB_qi);E9>1`&r^|P;>E^H
zqA)ewr|_sCDw6zApb+j+h%Pzdd6Lu#ffGIHW9KiLvPdnfA(D9y=x@I;hhvuw$PcoC
zaS|$mbWNmgFBB}u*5M4|UJ)I3a7^b6B98W&XqNmm`|fk3s<@AJys7D@;^
zxg$r6KxD*F&_L)c)wottYJ{YTt5Q3lEht9~QQ%WFaSQw%g8uaf90
zTUwg8Zf$ODZEkC8Zg1Brj(o4HxPx6L4&;J$q#EQ!_}gq4sD>e);WxG}^gTg3s91O?
zK{#QoPS?rzp2t2H;iH)6NH9_Q2fz+Gzp#gT`&lbsHeT|aW4oNwQX?ZVbc29N)^Jyk
zH+G6P8`mm^KvOcQj@LGp%Cf
zKPIH72?Yb)ytCTm%v9n_x!lvPrjV;?;$Ya-3@etXU{JTEV&?{s$lO!9@$TllClQZXX
zipR=dDT43MUBGF-xpow8kS^Ns$bZV#l739F>`!dG>^n7Y)=c!j6Sx`()wEKygB=%k
z3_o#U4_WT)7}*g_FT2o&R8?jEeVm>QIVdGjOT<8Pr2q%MzXH`m*q2;9om>@4t{PAOPX3$u)74u-
z)my^VTd%eKb;r9M;p78B`vD#xG~pfO*w)dp7=4ez+(|uF7>O}EU(@_w8hu|*-J#np
zTFD%NggN=O%V)9+X3DDY|9oPzZQXo|sbbmfR6Io?@bnFq4jID-M(ctZmFUoX9KEx{
zX~29uJtdfu(!bGpp>y;=D6x3nL9d(d*l7n=%L@Y8Y3lnQ1|36q{=gqv;Twg~j*UKc0w<7tes)vk$|8BNnMX%9|7>$X2ORjmDjFjjRVe9nD5zrk&JN*ZY{CGOD0Lq?
zK*s5abdCcZdawdTbbH*Z>b%{@;R<1(`%JC-OwU=wL{&J3P4Xu?aw84Lkr+&Q`B>Dv
z3)Z4x&_CU{ij-L~##NPdm5TZ9i(wf7S{9Exowq(n7t=4B%x)Pb+s3QiQaDQ3t)3%nK
zdzvY(g7D-|_$qA&k_bV}z{Wc6Rn@g_L^|m8HN(>n9PTu))+r3n#>tDh3mZ(m2=3AE
z1tR{Un4PK@fG98AhAx(kPE`=UYF%I{nmVaAzSvv00$PYsN`Vf^TlYbQ5y(Pl=F*bJ
z-KvIOQvRbc$}NShO@Tt(Fm5bPsS3ZZIx-`qCloz|<`
zH}#?1df-dRGx==un{yvb)pQ(3ODTm7TA@y5U0Q?K$gl@v2HC+~8L%B-z#1yDkn$M5
z7%*ecnx$H_gy4VFCFN_Tx?}+KmVCTINi7zP4Z}Qifc2uThk-tL;OK~$cC7O*_^}2+9
zR-(LC;5Gw`WeL-wL|POozxXh%ia$gZz{rHb`cV9Qj3YjOCbv{5VvVnzI51fq-2X^0
zwrrK(
zmOC2MP(<@>Q_+!u4B3D4!dJ%@(~rA|YvS)FZtj3spqz*AuxreP}r
zWW{(R0$(fnyk=rS{f335W*j3#T87k+yTP3MZe?aaP?_e7%izwO1F3mq32Fg#fYa|R
zJh5f0v>PBm`fd72Ty*I(tS~rTWyvEiKK7Te2ZH3$LZ1{f
z-bS(ZUP>CWeUOwoT>iC_qm3{2LXG8#U}f`_)(P8NyCzfL?7)vu@%qXB>&2~PF!z+F%Q2S;gJAl@+)515VU3k%inwehQP75(kMG%db4)@NAzVO
zB?)ReZkw%`@OS(X$R(BCg<{o9VT~@lhgW)rypY^7OWuL?W+=TSB=TgMT9*2tm-6yj
z1UhFoEH?igYo0nruAdnY8jdiP+7(%+(!o@Lkxd~`F(!6H*qGd)9WH?}Gx+gb9E
z4hOAdB16acS?K40Yoc(=WN(QYBa^U5JqG!Z;#tYi3l@x#kAwTC%Z`wLrBk*So5
zN;5}rMV-ug<$;86F0g2-BQ&43p*r%yB^+#Wi&-s~8*HQ^1(%RykEAe;kBdNvel+s@
znQpRYKJR|wY#$jd32vv}t_&h+=#
z;*L-=k3roBZXB0vr&t%d$GCP1tJfR!h;1fmTT9>+~2>Rrcbz|KI#L$
zjkX!JPhDXO`;}5Da`XdOzX$u6t;|gjy^WN=>)4{uWFS*Lc6BVbP@u*8&h~@CVY7Vq
zPK1-kctOdI($={f-MhdQUjfuV67xsSQdk-uKu9oX*__8?o6p}Rbu$qpie2&^0DG3)
zmhL;_(-`)Yx{j`8e2;$AUM}&Z%N9v?xPkAZd97$BEhs$hB(VSldBoUs`_Ds}>om+9
zJ^mAmT8x$|*XoENbGz3yQK5Z)c)jcH!sCH6z8)a@$K4PbK+_L~j(hsxc-~!A+0%DC
z&a6CY@Q2p=?`rvaUhRH3sb)*CHxD0Q4sH4teDAdDOJ{p=YX
z%w*j-l&aPM_PSdHDva9G@S;ll6MGnbUIUeyp9Ab1Kg?3`Isym?qh?z3%!r7nfI%HO
zT_9Uia#}0ABCy1yo?ytCs%nP*K2O&P89t~Mk=^yadLfeW>Q?j7KCkd^OG7NcP$$D^
z3>R;~D)bUY(hTV~ik8Ze0yKJEmv6C?SZ-Y>*$yL_Xr+$S#{xSAx3Y9_V1~%MA(^CB
zm2}fy?Zhmy=Q;gID{DdgU8ZkzRf*sC3PYmP9In6BrJ6}b>((9
z(-(D3;RCvlcS{$gORG)^GEj4LpD^rrsWwjia=3C`6E|CiC3r5mCom~N^BbF%Y(GA!
zM
zp|QFzqEn*j{JI0`9kGNI?CX^%bogwXe40xX?{qd!#uua=K<~Tok1wP%5pEA62l2u1
zD~f#s@_&&@rA;=eBwxao=a#bLQ*|%Q5WDD^IIQbHb@Ih59i=tGj9eA1=okq$1NV(t
zU`;^M5PfMey-=&ly6BB#tqS!wOw@_m;|t|vE6>{Bw`go|34Mu9RXc+jO$WCPxH^=e
zqyi}-cu}3Ci4J+#nad>o48_bk<>_FKghUJ}oj8+CKxt-lG$z@yE8Gf>1;3NNbMV?-
z^u)>8D3tV71mM)Otda$&SGiVi6Gip{k`mV{O|=Hin6ek?tU(>AK}P{e@OEF=JsLaZ
zEMlG&Y~g1VH+u>%E0^NVC6j67u~$z_IV!>Rn$BGj%3U$B8i9r2U~l)WTsOxK%v^S*
zO9V=Kt2dOn;U3oWL~IMkHagpIm50E_j#$vqmr+PK@UILdbzit=ksDH-G{C8sQrt9wFf=EFZbVOVBx-EG&VVD}WJMhZwy{IzGLk5sFKx@Rnx`FHMtBP4^l(?#YgIUV>KK_XzI3s#
z+SaiR*1E-51X2mzm?<-kCs<@M+ePF4@eY{AV&LdM5(h=oID+g8q7+S$_F%g};#p76
z6Lh;uH?HCuJ#D9Y+(tw?Ev!-GIsl%D|7g%mo^UBRbH~NuZU>n|RGSlz1yO9Y)?s
z>7(}RN$#2C%3$)!AG?-~@0d6?<=P1L%dO=6U~<)ubI9{iCL)%>6w?})n0Yg$Xv{ud
zG1(4RNHbNrwsM-=OVYF6jN~DhTBu)Q3&QGJmHTJCO5_$OH>3_erk0pkj^>aTDlB
z?c~YomX-|AQTxEe+Mok^V%vG1K4SrrOrV;$0s}>iNkXV+O@`@^keA6W4O)r=Dh)_s
z`ScoF1~MK@1|27LWM+o>C>o5OQbeE6|}t64Y^8yQ9VNqaEeQ11_oeE2Zd%+
zIfHW#_TjUW#^f{IVZem#X0~C_6pZ-?2}jO2P~Z^pF@cfVI|%Ls!=Ykdn4dZkGof3e
zVq&j)-}lrPTwm@Qwf6GPbK5{az6w*|L@H#`hB^`Z?5+CmPT4UvLEc_WnU9H?UXTWW
zYH(ipZrvI~k1d7=xv3u6tjkHpt6;+-h=q-P`k>b9dBYumGBUXMD3~TO}xLe
zZA_P*)*~ti<55_U;G_$lXOiJ!loJLqT_JX+ge`%Zo~DL!*??`12japwXL`e|P-ob<
z;9Rs5WC6cG_*?c#A^ea&Lk=ax51et{{8tUJ!G>$+YZcS_l3{&_6#!P
zXVQ03lQ7jJ{gl})k0+I8&&|bqB%1@8{dV!vL~&EBxaoTNY;nu=1F>SDjLce>sOAcD
zujR7y=an#5O4eiw`0Rfa(KEN=HB=$}OfRGwXqM0>C(};cwDwY3h#};t!tlsOzS0Ex
z)%JsGfJ#FvDTFN=hzEco(}eGVPETi)i!OW-6>?+gPJA%F>#V~BN
zQTPx43bV|$xl#=x^XE^JkFwz6!OxTL`xN#y^8GV8|3c1tmd<9ALExyn{K2R~
z@3@vsE`7CR*0u7suRQ7~zvEwmy|yh`6i5`+#fs`^+!rKE%D?>7=buWHG{;JSEI(^4
z#8&;wy`S$*l&+0IOco(UfNe@x%VXAZ+R^X6ygT6t#2f)Yw%OjaB^vj~8u!!2p&~_w
zd_j?xRW6RN;K-L%lUa=(tYhr;lv(~k@i>eYut7Ap0uX|>THeTNvD`Hbr
z0mDUNvr*=Wh-7KfCL*1kRAn$=s-WqgU4$Qx<9qZ3#Q=j*hxEa|_I=+81{!*mk1_(|
zT#PEBiB<`0q%TDy3twt+`@4LRq03`H&v{5Cs8{_aYtooOt5_xpD9B4-F3torbFKy*
zvPqj&GsQ;C3>*r8*W_z_giP}+K(s~uS~#fAs!V~kmR3t;bdMQFjeLZL&<1>Ud=i6Y
zq=m2SL|>}pAJ@j9LlcmzL|K4lg1I~xPNicg4zY;{t<};-49?nY-2i-yQh%BpHWa(a
z$M9Y>SQn-M`b!KqMN#%9{D5QPYck2TF|hiK3bPb#BuDERux#GBmO8}%GI}4qBCjlw
zS0Br(pKhDYTRSbq@-|FlGpLu=8AofZUYT&z94FhfOD+g~7O
z^gOm=uuj*303E&%^|v`EwuAk&PHa-T9&UwL^`sh?h^ygV#Z=11@6*%
z8+1rIJGWDJJCDqmtvsiP=Ip4WK|bj|
zj_1t&{PNh6<%uOtu_aB({GvpDO)S4Ak-svQzw%c$vomMjEO?$0G4p#Kf#WRYlbSla
zB6}j1SZC`;C{1eks0dnojYmGByN&;b-7ORn0nhmGE@yZ{J!2R%Ym=EyXVa`qP7ZWsO?juqta7
z$R3px%%pJ{_UKTqyx4@uC|4Tt-64Gn0VQYcz6RO%SWQ
zeJooe$wsp^(@;v;u>r`2KCFE-`z$8=#nJuAN55Z5Z@>@Kd_Z-N-I$*sYUxs
z7qyai%roj5_0Sj5)r-CRJih;!=UI(@&xv
z8dEIDwJt~j6=D`7j={J#pgxAd{D4(tMswhBuTn`*=GHOE4A>P0tLGH3(jlP{?yk+(
zEfB}4Y#KqLZ5o;}jm}vmDhC9|q{H-{My@kY
zQpXBNXC8-WvHKB9_5QeUhwo36wQj?VdjnhRT4QbqJEvjiS)OGuJa%22E!^;~V0M;Wu|&j36Ao0auDh~sav1W`$?}S+1Fz&p
z_T2I>na{#2V6c~#MeMg7eomG>l`LASkY(vVWsT=
zz(Js=*%YWEf9M!;NP!)_x)VIZIw#M8`Bi6|kw|ym(=iXR9>sym7TpIN+
zP3D(P6(!17#mZO3%bTM4P4BrVHJ;}CDYxJ+UJ$C0T(YQi$}|;<7Ose7C5y|Z{8K~G
zqWXvx#|OCuI3d}2+h36^2uxK*s~@`=f(apj`tyXz=-Rqh`tLdf
zKPlv0D|lsJq>mn<$%)-_M}P8IxN*1V0LeTY+{g0iWanf&FqimI@m+#&7}Z&rWj
zM6~!|tauepht5s6UoUubUorp;m8qO*)AZ44XR>m|wd0BU)>wUOynb`Eax)lP@9h?~
zR+!%-3MDvqn%tKxtG>46PfK4bjn}S^maUH!tbcE>?!~(YA!59A-e4+OcDr%Sn_02O
zwi`7!w?z*ei8nrh#yk2)&i8LuuEMcW$+G0u-8Wa=D2@j9;=z-z|NI)jH_jK)SNZTg4;6Htb%77V
z&te#S&*j;*!uY-NhV~_fzh1IoSB?4me*gAb)Awsc^4FH`uxI@s%K-lmY$EyXE6KlJ
zM64g0a^e5s66UX>cYavy-`QgN;YN!4!xr1F{H&X1=Pqy7O|O~!`5uJdtT7_)%@yWd
z%~_HI11fEojo+M>Bf6TDV8L2}k6*-E;rfa>cu#V{(Q`K>vLZNApbTANeRp?izyx2T
z5ljpuoLVYo?OeVI85^H6Rxa{0g7SfdAe3w=b0OSRh$TuPxYU}i6o0NS1+xWMq+>W>
z?oltb6m;hIAfh&0zqpAq@s>YP2$Go6TXa24Zew#E1oO{0qyfhka9
zC_&1uJ9wVt3d75PhMsL*bw0@8HpMU@}z=n>_3W_!T1Rn?5KmR7)HuwH@@VQ4yQPMljMr5fq}j
zr1sODFc?
zU^_AvgTA`A>=iNUt(Xc;JrVP+nAn!#BUHrP6;n;K?rO%5D~?%tm#C@=;L!
zJ>G$5@mLKR#zcm;t^a~@^*^yhXEGvV$5i)1I0_+UntssU^u;nUjWRKtLT1_taitle
z@PD(IU7+_kdY4S?S@w;XHv|Zz>Zhny?=Oj5GLdC$sT;q+#aTeEoX}#LC`4^A-4z+q
z9S{%QgNGm`+kZN3;;N)CT&&C)nV_wr^tJnu9HyJNoAsH64$NOPtqvyRpe!_;$M
ztZvH@zLQhdw$hmP{b@w8Y4R9658iiwB1hYIv%@Ql7iC9=9ixh0q=XTc{wO*;cCzp(
zJX6`!7Nb0gz+?yBP;+WP-a0NBl}A0MqW4A|O0#wiTp0c-H6uj<6-P!HVJiefgpo{F
zT3!Z3TKPNPB`?=vTsT~j_REjK0|A#koaaDkE0@Z1AhtVWq$*D`_GhrNXtb~^(`=Qw
ze`0ppi6`n2l9B>?!N!l^H;8A|qY^C^L%_z-A-}M1McL`f#8pt{%XF;kL6zNgnUrO*
z6Q(_|vI_@W)x2+H|HsER5D*VL!{x*}_BP;D1wLLbjgjd7$H(;SE+&~yC+Yn#vB%X*
z!28nnMiO-|shS+dWOYc4%f&*wD3ozk+1jM-RX&N2l?gFhQKDsA8&Y4*q(sXQwDXmI
zvj{r-@2Lw7AzySM#?5M)aWpaVe*^HE7m@!!i1718E&#UJRp%8afUk2O`Pn0_Z$6VO
zSa-eZuT3`&f6t!SawxXt5Xj(lc^K7!@_X49j~C>$3UnO>x#`*zwQk})QT}cy1iz?f
zDu@n%Lcp)gI1ATlo>42t2&AK`m9Gy_G3iab@!RF`pD7QO2;=mRmdU?RCS=``Wx|Sz
zxsgtN*?^X4hs80xpP;at_*q+&QT^}l>G?0nA!%0*o6aU(CKL4(u``d8LyU6i6#1B(
z6cJO5P?U&JrCd7dk&}B_im}foO7@EglNWI
z>RE%q?7vnuFW`2)et~XxtrXPEgIZb8ywway@VyJrHT0))oaXX*q_JtLYeB$mzSv^U
zkDR|J;C9dLGH<@SOt9pUjX-ntEmOsUQLxk`O%*>k=SK6YJ#HsEciKrLb`53!7hqe!D12{+o6~N>??>covdTx8ki&$5fQdMClu!}Fw7vULn*TLw~K~^a*>}6
z5u!xXCu=s1p?2E&kSqd@kIt`QzU9DD!`2?wyYAu9YkGD3|Bir6GYP#tlAm62RbIjZ
zmTZ`~Lzqcaxd=bmyCG@i|KQ?7gbe{(#vzcYQUr}xm|0(Z&b*;A}8L{KkP%plsSqkm_lIdH1{HWW
zbT|-Tyt6Duz*FO0z$pv_qrx2YOToNGHiNyVhX#feo4TyW>8&|#guD{Y3S}e{GB62g
zq!2;eg_#K1FtTQmAkq{Joeg$DORkmab&_Zgr-H--t
zqUlF5g`OI0%lc$nwY(8(s+$^CHLqG*U8};gHIcqZ13B!0W)HTKGa^}2(D7$~H=03J
zQzI!Y)ow7WAdSU`WE=RXeAPs#)Trovz%GR6vbe&(QH^;M=xYj6g!Kfj7RZF@m>ok>
z!-BM2A3i3&oCbXUYu9u8rLJzK#HoWeIl7^y5s)hcyT$5E$}#q{1HJu+SVv{^*<3aS
z$ZBtMR;A}ipP=EXkd~OW**wSQy3gRpqPZ@U%`wv_45Oxg5OFZrWR%<>H<9AvOCim%
znI+gzN}pYf_n_oXhLCg;XzUrC1G5XWDB~pPZ6Xr8M*1YO`=Zt?#sZ#Gs13hue{X?BzOKGlq6t7}>1ud0kP^_{(TDktpvFjh7u>U+8lHKlv
zqdev)pLJA%D+%cpr>aO&2;+)`iGt9#tV{TuNaRWy*NU2eH9GCk9=sERsYG>I$<)lm
zkx*!9&VJEOB$b_$exYIv8lv_<)v_jf9)7NL!`7xSe&>gD7?TC$a(M;PhVJd3oRDnpsD=j!UC<0i;5^71kChc)+$Y
zo~3TN=u$cqI-QBQFTZ2JS&?Z_*Re9TkMXR!ThtQFyhD0j&Q-ZHJ4dR3oEBRXU}MT2
z=)##q1|%QAU^48elzK?UQPXMcRYy%Ab%23>5gFjj=LiY`2pG0stwfOY=Lnc{b_T~K>$4wR;~WXOrisLIO0*hEP-k<
z;^`6kxaScY`(1C*)rKn#ac{*$R?^}7Y}>@1q}BDgmZa15($ULDBTprA>teZe*AD+_
z=WCtu+}5}g`{B(u1`|7gbTlT$QrrVxvehqDy&K|ds4c`LW*>i#SHr?$oXHTUTC
z`6?o>$LGeeA-WhAEX_JdI2a-aL8H;dS<){sdV-S}
zm}vwJhlXIn&uk?E4Iz^Jp&x%mq!AHp}ec3r8VsIlS~#|fjQ93
z1?cwNirD*Mtm+CtQ2=POVZx*UodPtAAp(cs>!XaiOHi|%M$ih+7Brbk*O&issI-F<
zK*@pVQ4PKX0~dzrZK?w6zXuh{o+Xq4LynnMR>+{mHg=%AtvpKC#>Xm7Pk7|f03NdR
zX-(-F>hDq?alp7VfXf<+t5YB6OFzX*r>rV^U>XJR$8|tRXe4EAN}Mhk2Dhi5Xe^F}
z%c!l!Mm=QOqGE7UGeGO9$y69E@!zU6#}^lelSG^VvG9+dd1JK&qhJxSp@ONsj!{h4
z;*AwaR%oPzLLitHZL`>H$$JaUmJ0ud(FQNlEWjuNT7b~B@)0iEb>*-oQ>lTcFi|X&
z;kElWTim2*2~f`zd!Z^tMdc=HgDq&U!tpi_(N(mu4$*A$B7-ta8WlW28lhb5$%7DML$a*`ZaFAJ8ABDfNHS&;9T%GOx_m
z5EpMZbp?5vX4pfB!8oRg?2?)6lH0zrgs%$5CEmdSaqk<&v%a+?pjDV~2V(9(+zl3k
z$)7VXm>@8S3Ab>v_T|onEF}oDa&Bp4W7NTAxfqk@wahzQwn(t`fvpM;UJz&!Wix3z
z6*qw5vIW759d3=$Ts3)O9(2_kjRQ<|sRkY10-oN{dK7$V&l+bT7&FDdJE4Ya@
zK&We6PSVPODiOLkhfJq!mYt>x79Q$lh#Ns^xFN8ekTqnaAhyp`Hm6c|4-O)rz@#Xt
zusvC?6dq&=vFTUYVWwx?I|$9JZln#dKzTiZF4d_avMj?iBy$P8yIsq&(h_4*!va}s@1>aVnWINc8dwYj&xpx5jbVlSiGQcGhwX^
zLyEt+0=jk_oM`KC4WP+oH75FU4CLz9wy4&}@Rd#hz>h^7lAzCaYDnq}UdUi(4dtuh
zWm%!altJzUaoXR_ZRpgf)qxHgtONsqsg*_gH7&wb^6k53M2$4|fW}JrPfYu3@%~q}
zPxde?a2#et*G!fAZ>ANVdMMyM8SNk|UA5x_*YK5)Jyo(Hgj#wgGbn}z2kN=%A3Ju?
zO3B%TXggg(YME=*)Y8{+`ihI!SDuiJn37hNU>Dc|{J0|&=;`h53$aFHU6X*`d%K}Q
z2`OF(XF-CC+LIo!(M4TG;Uf?`Q?Yh;;sLn_!<`hjM!|t$anm#el@vf{96E5M?cjEz
zGsvPJ-8Gwj^b13HKq8OU4e1wE9zBt~yf5ltMD91o_iLJ#(`CVI(PhX)@pw$
z+eH^mZLfNQ4~Bt4eQk6P!)JmQFpQMi>z>GY;+b48^%-v|_29!=zZeXr_o{v8`UXErulI
zOQG11qEQLc+u|3xnxHI9jQak!J~WYtM}d;Mc9-fAUa0+6e9#6po-I*+X?LYujG6P$H%P53
zW6IDk;<1@%xmQUWqT4QrZsYuuUm;cCf6O{+4GGU16k%i19;7V-M-w3)3R58*332w+?oUNsx*0ks0T9?#}p3Bio
zm`pD-r@$CBr%@`Yipo<-j)(RVOyV~}KPPC!evTZ@$CB44#VScUA4?YX1x-3<>Ln>&
z8&!pAl1o28YGK+9(Td0}E(gW7Cpm1YP?;G0`>=
zz73>~rWY>(u68WxF1Q1nl8;?kOJ+%yOjf;WoOM;*&M%y7etG!nb61{==hs9`?`RQj
zSFFEYaXlEX*b=c#R(;m>j>jK4^m4)EfzOt_Ix<~39ei`yx9VoAchY;6*Mr|!cB4FA
z(aztUw`6&0l7Y&vT3@k##U9xWGZML_lflSi@1O|7FK?PUFymWx8%DE-->94QKXQF{
zqGfNaW$$du{&$wOUhlo>i7$IJvU@W0S^2m4jlP?0@n!pX*!*Uy;rv#S*&(3~S+cG%
zQP(n4*Am&C@Gp(|m&X0oQD05eapXpAV(X#U)Y0kwk=?WbYlFP6
zqwW1vwNOwF8Dvil#FEJ}_dapKXe`Q$Yy*=FlDy4PfAxGe9&?j`->q3rLlWobWu_ZewX4sQ0HE)%zUQnbiysus~?bEez3eMs)
z$B;e!_!$g00ClhvMAN67$E+ckAq9M`1*eHN*-t>5F4U
zf-sTUi=iPpFlAMwJ0aJerD=qpR;r{D4hUgbDv0Db_y}W9s@oGfr9Ic(eSuh-=NS$K
z+Ku**GIx+u#A;%4`B$s8)u1!$*f!_k^R3CziZI(7}*=?4_WmoVtPYT2mwC-*PNqicu;5TUMEib`&qC9ZJ%qi3v)I(83UzkA
zgJxo9FT~XaxL@dM@0H$Hi)XVNZu^S9xMOO~7xtpPt{sW_R!1GH-yxH@S2j*b%1D}G
zkTfkubD3U_iulcCH>!x=Tz1cHGB3a9fb%YF_Il@Geab&sPlkKB-7Ie8Zx7N^kvw&+AxJ_2?Z9{fG8l*&B5Xq4
zr-n`gP@Avvm|PjZSvdw&!Mr#(jz1(w1O`jYb0PM)mTvtVq$Nu*fhYiTg=iCgkcr=HXTmslq<-10Nb%q$@N85n
zMghhKDw<}iGsB_f{Y0L+4sW52U3Vw1I&Wz88KBxwqVs?)>kJK%CO@RzI=jx`ytIZl
z$RccK`53mkx`Bj;YQlgr?+(@Av=#=fc#s^8EMKX)Tm;LKNKAzv3KZ$VwDLfVEK?aY
znnj^N!|7B+MY!)==q!x1_QBjhUkFa9uZNtoJt~;>{lvwlO=`!mGMS)SvT!H{vWDxAVP|w+OePJE2`*9_R
zQ|DdEFr<4n{u5(l;RZ%0Q6ZPJ&QkcIi?m(^NEBGWWq0M>wxO=HwF0=@v7ccVr;2Wtm@
z>z8b=%X5(k9e4xkJSzMiOep;Z`Px{%*`sEbuF6b-+?1IyUUHP0fbmiXcHFeo2=D(;&AzYtb~wp$GmC{|n$wTulKJx$vRbFp{n7yCYe0Kb3m$^+pV}_7S_*
zuST4K8g)|H5E#jlyA*_n*hFPRKp8BXLc
zkL52<p0F0gtOb)Br!GyMozD7}>H2{i;$PUO
zpS^MLrg$TKv*PA~o7p98!%~X4qX}>rp`erKb3YmM;T8r!xK<9An8Z!0iXCi|j6tMl_#F~vNO0S{^
zaSq*!_#u%~N1cR5;J6TJiv+KG`ID2)(*wJ`NI)!{{jdRAXGm^wO
zofqgEKBQ_ZscIxhGA?{>+ZTVj|LqwtD6qzOpJX4QRgiE-KRl-%$bPuz^sn3$tI12rAe24$o~k>rwybe`YGWB
zgALs&lUV440gO81r>vTUOs3DPEqa;MLEBa3LhX|S9E4^%c40ZNkBLtSq)_^-ILs7F
zpA~gexjASxhWOsno-xEEsXvWX%-r~*>3|1=Klh;#;%jQBqaCxUFhaQIqq
z+3_}{_@TPe5ZDSRjDd@weulw&zr?xq5-g2ex)6XW!0{6#{;yA*(PJ!AW@j|*U^mRN
zuc@E`bON?RVB2R?pn`ySU;k@89dd6luw`O1-){Q92_1t)gK06Oa%uIdlhA_#tO2Be&_+S(J>}GS)RMzy7+!3=
zR9UIUq!%Gj1SP8rWY7qep`J_SCYWgKK^Qpd4BZ8
zhN(WMdI{B-<6hHOXX){%-Ms@t!@Af!xwiUa7*3s4^dO)mm^Po;F@+F%%)%5L{k%OY
zXmge_Q-=-2-GCi;Ov#HcGS!`twU!Skm=!A-glvN#F(o=qocA@U>EFNp}6@o%3JKX+)-bM=Xs
zfBOeg0}3Qj`fP>6VG}!#tfT-Eq?g`A{&Pmmw@{c7FNCT1IznWm;6VjBPPuN!+h7{v
zB(VI89kZ_G5McEAp2?mw*#9_l+Ua#BDu^BO}Z?GHgE@$$uZ-qEjbN;K_@HSN3kv3S#gMAH+orYC0ej>cU_
zqt>JE-_G{G3qG0mwhQ#Q5uOhjgv;-)Z595~*5)>TC)*4+t>I~z%UrODCU6(p3i_WnVJr;?v
zi?D2y_M;tC2i6{}U!9~C2a{>w8ZpCn2x8Lq_cM-Id}fFZQ6LzA&n
zNWYim$oOEeV*tTSDmhkTB{P0t#{kY&txZ2{4b-sp4ArKZVqr#FpyRld6;U4wt;Skb
z+77sQ@R%B~P3sS%q0Y-{b|>|q^>RIlHI`P%2Xo0XRF<_FwVRUKLu|}9HU?I$3anlo
z2nGW?b_5!OfyPi^RZvZWlF@9w(=R5`N2iEN8D;6!hkXYSTn#Lqj@_lEqt*>}5j(*}
z9SnnUsM+w!%=OlsyC-M-)43k_8dICmi2qOeyhaeO{u@AuzDySu52_t5B
zh}qH@9+0@<2wqElJ@02?e$>Z24*uk-N9qDi&2-0))oa#};t2jX;m6t&8hiF5TKstR
z-lvF@`RML_JKOi~CGU>?2kF*E&aV9j4{cYDQK{trSDNE^^**%n?l4i}fup>Y_xA+$
zqm|pWR^Cgkyi;lAL%fx@4kHp;`4CzeQJz98%csX(Snbt|CU{1OwZQZH*jSDl+J%>l
zT|jo~GMoT!bu7G_k=5k&p1tZItKV>j_fmLyr?_ig4!ut*i>fO
zoC!m?U-}$!kXFJ8({7g9Y+PP<-@xyYTy>ml^v#9f3$*l=<2jbTWW&lIyBeoLS4@$^
zQFr-d`>eZs#?=_LHhzE`TYrDoy~M;heZ=I$HvSddI9JKU^5&(W45hEYVUbRrl!2pc`Qso0<54(Zx>M^+|t^
zqD#b}n=``{ba!~pwu4N79EKmz((KHwFD(5oh8!olpQrcVC8q`{f??*Qqdyc$HXU-9
zk}|?zk4z16I(*I(gfKo8uTvpyq`yUndYL-t1w;Yk(+)()t9!5PeR+SvzdYt&KE5}Z
z<&S0+C#^ZR{e@Q_z4GX*X3{a8E{Xd$<6&+^B6meBcSRz1RV;T^Jhur9U31xG+k|PN
zi$nmrzS#O!cI|ZKe`)x$2B0{-^w{OcCjDgYHz
zieD8KwRG#~U{5Zc7`>!tPU3uQ`G;b~h{B-Ja}+`YLqK@o7IecS&DAV{YF*OR)gPU7
zb;hJg4N^J31O_
zmrHM;CyW^J;z;Rv=q8{u_jjiyqh?)!^BDVLnOH_mC(VQs@&TB0MD8VoD^TED=LUqN7|1`+8Z#giWhP
za7raY43OM#=1kq#5=pc+(cvA5L2&VDhFEr(rdc*qyL9DfpcLp3h8vam0m?9ERqT>U
zw0Ox
zgO|d+Bi+(0eO!_vpEI8t#$JM3y}3!z{()X}5au+}!)6leUM+=hB8S)q9ILvId;{bh
zA?Fw5Tq0*2&RjMbIN+-4C|h^`Grd5lkycTLMiB5^o_!w`wHpn|RbX#Z#onSMKo|-V
z5jfK8f7c)j
z$nNATBKu)yB0dM{z)8xdGW{i`OZ+uP>@$LD&J#M-*U8r|1tiE5KD{VN8lVb)4GlQw
zzrX+(7DdUC$F7ouo%gzRr+RVBd;w)ApR^CD%vt#13a1WfHJfuGzXLX(Eq^a%p&i09B60rsgj4<_z#4$1y7=tNutGr&Gy(cMX6_8
zhQoN$jg4%z{LtERejqf|*S$${Vgg6|3E`h&)&?_C6n|wG#L~9~+uMTkJ%d9uyeBBm
zUFItk#HybNxp@4xko~scVz1hNB2>LCxZf5WKM~4)A{4Q|g7-|>6kl;t1%g<3TgdyF
zu;C}dvOC#1FKxWMaon0LEuUI5*)eXNSQ;@!x+1oiy)Z7+&NmCDtc1}QGx{RW%ot04
zYN~zD0`R`Ogy5I*`bB@FG$r7cYVe6A6VIju+){OA;_^sUO2BQtT{MYRlN+IOFIHV^
zUZC52j!9fP`6vY~z1B`aOBWDS30)M(7g%ycZ?dTT%bP#H`C3z~Xyv?-0yb~|_H*BO
z?q)c)`49`ZW40}r@!)QSU@A(QvOc~46Z<0vuO7Q{?CR53o{m;+iRZQf8OCI|YZ1%^
zv!*3L9X4C>V$x(!njA?J{5JLzA@bjRzN5ep75pUPke~2W#XMExImx`D$!$}<$z4|l
zqJocpJ$9{Tx+S)JOSE`PEU%3Mb9_j0;$Xx#aWrPiC4b+<)02my&OppmPCvUME%*UY
zdFRrYX&Db`nsngjR5)f(I#D?hj_jZ6m~M`m016s4ZMthTJoA$>x?Vnk*|FglF+{fe21LO8Pjm=RZHv+ky`dEH_TxedftQCFpV5sjE
z4~lnk-bWuJBVW@4_d_Op3h=ltB_qdZ)0A&kexrD&AbjE
zSuL>G^A(g(wpBdB6C%$Yn`7Qg9wda=Sp@hCSX
z&^^@;JLt%NO$w+WD8RE>KG8nWOf!c)RrjPptex1N66l_K#3BHv$lz;
z22?ImFW1q75PFa9shWH|!4KS0%>`%)M8Pe!w$~t5Meu{}sbl7o2C;l%WlErXYKQrR
zL2R8UO9^yOZ83jL6k8+sN%zzl<2eIbV`6hkV4hTm`K*Y!u|6fxJ=I}s741-HO9{BA
zwivwPM)nK$)bdjN@GeaWxTm&?ju5oM1@|-A^v7E@0YBz1iRL{ymp435WmKb0;+VZ`VGyZpB5I}=KICvqH}V^ynx%a6$^B`+W~>i
zoENhorZ)pIz5KYfeB6A?nfK!HgtL6cSw2-4cdi__-^%vBxSnIgOrDKr*N$6nxe8w#
zOSqQKxRy@!$6ag29rwrjxyv8TT@!b$O}KW>xOUz$6#)v_Z5Vf8Rq+)>3s%OxjR|kt
zjJNHUX$>Cv4C5~LXwnh)E=_pX&Un|}GS$jYptET9L^fjvpX!X6n%^9`vGnH0W*<2a
zGaUdGDN>?2zR1Q`3a(Xtr6lHSm@bO>TH?;uar@6r*%RA7`PeOsZKCp%XA+jO84K*n
z$1SyYaq_tQ=a%ftyCY|(HpcQA;*OPZOJl;)He+eKu`F)cP28nDB9hL^ndtgt-(9Q<
zKFZBC@2(KN6J7IYc5ejmytu(c$OZrlT{aqe*KG&j3Q1InkV^>#M)r^39f6>#mz?V%Eoh
zX32T}Ow>hjIz#mmUVT-?)~@U+f&TBDnuhNBtY(
z&W+T6JyCC6JiC6}dY9(<7oT})?1ixxpZk^3P;E%svtL<$?ZCA2t%^<0x4lb2<2fMX
zPQYLdK$%4Yt^ZY6?7fw6T*c##q`Pz+W*PFZu-d&?W^)S1v)Rv|i^!)kE>_(V3Kxum
zVQEq*WMNftap^4q{a-LFOA19SY(-qGyCsxUSbb6`M_8mbE*9Ssd=ylI`v>n1J!25^
m4u~JTyY(3Z%Eg3Mf3(^cEVcfP#RT_fkK_a^O?Tk0H2ojOMTk=X

diff --git a/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/exceptions.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/exceptions.cpython-312.pyc
deleted file mode 100644
index b6385eb66ffdde804b7038488f20d07745d9b89f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/helpers.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/helpers.cpython-312.pyc
deleted file mode 100644
index 7a9a1e7df916615b0e5de329104922778d292c90..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 48489
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
C{!u&t

diff --git a/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/results.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/results.cpython-312.pyc
deleted file mode 100644
index 48751b879447e992b2b1f4dc8b11557a764e11a9..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 34098
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
ItYyvnf6wkgUH||9

diff --git a/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/testing.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/testing.cpython-312.pyc
deleted file mode 100644
index 7822e88f3c80ca4d620af9222d7d3ae41db3f3fe..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/unicode.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/unicode.cpython-312.pyc
deleted file mode 100644
index 13b1c703418763fbc7e37b958107e2f48c1e0300..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/util.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyparsing/__pycache__/util.cpython-312.pyc
deleted file mode 100644
index 62f22d4495e3b659a4475da3d050a4214f45ea34..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 14892
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 ().
-
-    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/venv/Lib/site-packages/pip/_vendor/pyparsing/common.py b/venv/Lib/site-packages/pip/_vendor/pyparsing/common.py deleted file mode 100644 index 7a666b2..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/pyparsing/core.py b/venv/Lib/site-packages/pip/_vendor/pyparsing/core.py deleted file mode 100644 index 8d5a856..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__init__.py b/venv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__init__.py deleted file mode 100644 index 83f9018..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyparsing/diagram/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index a276d8a152c601d8b140f12a95245b4bd27f5bd8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 26801 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 diff --git a/venv/Lib/site-packages/pip/_vendor/pyparsing/exceptions.py b/venv/Lib/site-packages/pip/_vendor/pyparsing/exceptions.py deleted file mode 100644 index 12219f1..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/pyparsing/helpers.py b/venv/Lib/site-packages/pip/_vendor/pyparsing/helpers.py deleted file mode 100644 index 018f0d6..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/pyparsing/py.typed b/venv/Lib/site-packages/pip/_vendor/pyparsing/py.typed deleted file mode 100644 index e69de29..0000000 diff --git a/venv/Lib/site-packages/pip/_vendor/pyparsing/results.py b/venv/Lib/site-packages/pip/_vendor/pyparsing/results.py deleted file mode 100644 index 0313049..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/pyparsing/testing.py b/venv/Lib/site-packages/pip/_vendor/pyparsing/testing.py deleted file mode 100644 index 6a254c1..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/pyparsing/unicode.py b/venv/Lib/site-packages/pip/_vendor/pyparsing/unicode.py deleted file mode 100644 index ec0b3a4..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/pyparsing/util.py b/venv/Lib/site-packages/pip/_vendor/pyparsing/util.py deleted file mode 100644 index d8d3f41..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/__init__.cpython-312.pyc index 46e8bc745f38c464d406b0b254404b98f7113226..e69dfe20454a3ff0b0d30466a502e340b478a4e4 100644 GIT binary patch delta 20 acmcb~a+8JoG%qg~0}wp!owt$Oj|l)jVg=6t delta 20 acmcb~a+8JoG%qg~0}!0tJ!>Pk9}@sStOefy diff --git a/venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/_compat.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/_compat.cpython-312.pyc index 9c1c7bc9556b01418460f203e928bc1ce9249828..dbc1223b092f79f9961c8014dcca18d8ffdf38cb 100644 GIT binary patch delta 20 acmaFG^ooi5G%qg~0}wp!owt!Yo)G{+!3F&Q delta 20 acmaFG^ooi5G%qg~0}!0tJ!>O(JR<-?3kD4U diff --git a/venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/_impl.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__pycache__/_impl.cpython-312.pyc index 77919a011c1d96f3b99ff7afbc2c3dfd7af6950b..b8990467084b55a12609207c948495d91a1a2a4c 100644 GIT binary patch delta 20 acmexa^s|WjG%qg~0}wp!owt!Y&k_Js5eGs5 delta 20 acmexa^s|WjG%qg~0}!0tJ!>O(o+SWOTL)4A diff --git a/venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__pycache__/__init__.cpython-312.pyc index aa6237a1b8a5b6d481aee6581f5f7a7a21a58f75..cd3bd477ee1d2a684eec715f0184c401b6c31c69 100644 GIT binary patch delta 20 acmZ3(v4(^DG%qg~0}wp!owt!&kp%!a>;+N) delta 20 acmZ3(v4(^DG%qg~0}!0tJ!>PkA`1XHHU(k; diff --git a/venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__pycache__/_in_process.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__pycache__/_in_process.cpython-312.pyc index fd5b92e19912389a246524648747d86417a18d16..59d90d8275b6c9e1d2a52e7d608f317bb09ba031 100644 GIT binary patch delta 20 acmdm3u(5#qG%qg~0}wp!owt!&%>n>Ohz4Z< delta 20 acmdm3u(5#qG%qg~0}!0tJ!>Pkngswz(gt+^ diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__init__.py b/venv/Lib/site-packages/pip/_vendor/requests/__init__.py index 10ff67f..04230fc 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/__init__.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-312.pyc index a48e62f5ef8570b4b2799157adfeba52ffcb7c7f..5f741fd9937930e25491d02fee55e8e2e1626456 100644 GIT binary patch delta 1238 zcmah|O>7%Q6rR~#uf6MC+qVHIVkRjirV znspnB5J3oTMG(!s>OH`rkvJknYI7)DIDlZUZ~^rIJ}s z+v+|CfdPEz8zfCLC<6h`1PM{;_~tg;S9}B`g+g59icA)}e$uxF^}!KQZ4*03^C%Bx z(|l)g>-WmB6d9r>Dnyil3j;SOyQN8ymQX3m!Oje?#j|r6T-sI!dlDLjjGz(mbjS!T zqq3;ee3y*U3aZd5szz~^n6!p!`~z4^naGT|9GRfU5dRXEttieDjW$t}{|Lu7BjOM_ zP3O@(T|f)8g<26eM9$E&=qx>l&P8#7oTqKnjy5>bx%uq)WP~pa4%FFtF)OA}-aeoQ zI^h)q_~5klB0k}lz8D@%5rP}a7{EzvT~WpXn?9IKNls=n(J8;!;^l7^$DYpf68Ie6 zY;Ayd)k|OlicXH`qKl&{$c=I*pUY_wM0|b&>~z#wb!heAdx>@u6DZ@q#`%5yfqLZSoZ{2TuVR1bz_9s) zp5I;dJXYhsX6mozrJekhnA{GNW~?C~Oq~e=%=*Hs%~+SQip(6AP~|I5)pR zU6>1X+VwFB*plRyCA=;mOawTPrwiB{lDjB5E9kHEuLa(!s0i4b{7<(&IxMqA0skaU z38!lW&$Fu{ls|sJ`AoKA|KuL}F#S+3L;GP1a-4mnTvqsdIkLPcG`Di+XTeTpQ3Jc0 t)}8^oiQ{5@clJcPsotB05@+IzP`!6r75pB6V!a2WwH8~n)jbOe{2$db``G{h delta 1544 zcmah}U1(!P6uy(2+}xYL=5Ld$+)G{cG4}$pMLl++`h#&~X-Gcg3@I@~OJ_xelLn-*+ia#@x)>H zch1ar&Y8)tC%1+oUx&j1iG5#w_U@GjlIxKSD6bC=w=~HBhJyX33N;`Z{#PX!G*o6o zn&gpC5Xto@PdoY{4JjLP8v~NqBYTetujvhZKv`&w+tUEm$`|y4owLEI;zdF!~9yYpeW)J7I>M63h^h-oxQan&w zlHLNZ4_}q8$xG5zz_>7qT=6je!TrAW92a0{_1@!X>;JC_@*R#t96bMzgAYX|1XunS z=LM3$iwAhAyKH>W__-9;gOBM=6WgQfS&M675I7&YbJ(JHe*G=fvWmJ7$uaecKV?9SI&E-`x z$e2r;_k^baU5RW0g_b({Ko`Bx@kcDqw>|Irb=|P4x=xDpa&+(#f6{KES!<54Q8WyT zjPS}?jYRY?#p&Rj*|dl=ONd1XuR;<~PBG{Xtx8lEN&Uqy@u_pnL{WjJ0%EeuodB5#qK)*=f z%g?gpca)h)>4W5KSo$=xaVE3T#N~R7x*M;hF#-Uy4hnPt delta 35 qcmdnPvWJEHG%qg~0}!0tJ!>NOG&Vy$gG>g)iOcmE6*gW=V*~)RrV4KW diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-312.pyc index 96329dc9db9b99c29b2185b6442c8cf5c7ba2e09..33f10ab03901572f4b428d73db185e50decd67b8 100644 GIT binary patch delta 20 acmcb^e}|v@G%qg~0}wp!owt$uB0B&=YX)-w delta 20 acmcb^e}|v@G%qg~0}!0tJ!>QPMRou}wFZL# diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-312.pyc index d63aa10e0f8959756eb4159a8e4675b15033bbdb..1c4ee8f46308b4d8e42c3382fa53770cb768b3d5 100644 GIT binary patch delta 11006 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 delta 4713 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 a7Noz>uxYPk9UG(WW-qpLq5y2j2h9Kg diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-312.pyc index beaaac465767827c4f1d6826b5d2ee1b1e8df33e..c8db122f5f731cdfb4d7f235808ad0dfa445d40d 100644 GIT binary patch delta 77 zcmcbfb3KRmG%qg~0}wp!otJiMBX6M|M&3d_#s{10^)@pz%563_TFS_1H2J1+4x`m%Hk>J$|VwGq}afRs)Q?An;2PV&{PVvdM8OfO-o~UZ5dTJ|A4A^f*)Ts!oJlf&j5>WPiFHp zJcc890SoGIaV_4BeA8*SQ_6JYhuZ-KVW!ECbf&{BPIvtz-lBkFZR(A;uz+PnLTnou z>ldHxjiqv`McSmvzHW)x`uCVBoEhV5s*D`Id$oN1+NtG@9{2EmMmd8 z@sw<-2L*Q+zXn%!(x{W@Ra)j&{>@x5ep-llqbg|kYJkqIXW{rw6`a|x!*hA1cs6iu G%Z%UGU52ax delta 330 zcmZqVz0S>hnwOW00SHd+o|VQnkylbdijjd~IztLW6hjJQ3R4baE>jc}BZ$qM!yLt& z$~@7}l9730$6-e1$v%vycr+Pru_tFF7Nw+?_-*E5_F@#{F32p@2T;6-6GVXAa*HLSq@mSL5e9M9^efr gi4V+-jEo(^b diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-312.pyc index 3c199317a0bce2aca35f2e8868768b27a4d2a2c7..b34bb7889b8db3103fa2d3f08781ce521c7d2995 100644 GIT binary patch delta 197 zcmbPqlySpRM&8rByj%=G@VIwg+PsatdW?*lCfhK2@nw{h6zC=A=Vxc8W+fJF?q^J5 zWc)t)6O$jhj3+ZUH#0~{INt(R#-o#e2+u)NGI_2@7FY$Bs6I2}$H`U_o@gpI_ecnF dFm9VXUqKdK=BPq}G-KgpGaGeunKT<6H2?%FMqdB` delta 191 zcmdmRlyTBgM&8rByj%=GaB}yow1$nmdW?)~C)+T3aVF>IXJ@A7WF~E%!kEO!_-XQY zCO;&>U}kP^W{_+m-vU;~1CyCV<{)GzuMx=tOG=9BGc&%K>?z@iklegLLWo0sBNGFI xbAE0?Vo7FFW=>{Fr9yH}VsWvxLT0f-q5{J5dkO{8j5(A2ZPbxWXtB{z0|1H}LL&eG diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-312.pyc index d4f28d6c2354cd0429bdc17629b0636f6b4b0b41..3ad3bee6a0b5815e16a54ce140c041167adfc46f 100644 GIT binary patch delta 1472 zcmZWpQA{I6816z#=>qMRwrop;j8V?3SLtEyTIAs5a@QajsCbQ+oH3iFJHQ^>T{7DS zQIZ-Z@e-p6{>Dd5&L`tN+=aw<^-W^J#Rp>}@xfPp5O}+XbN*>r*SN`i{b#;!zWM+8 zCw*MFcO`l-Fdzr`_s7RytUgd4M&A!hPr+VTm5uJ*!0pg>FdN#xA8vH1RS9LCubcnk zILX1E;j!j79qwizE9p9)$fWaC)+y06MvX?5Y8t80`nqF~s%}}-AY1FyCYxq;!!qqP zQs+`<ew8WUxWaK2>oj@SY`F)y+ri6K z4KpYk_l&Y#>}lSCmaJ*bv-{0TEXLPdYzJWpj_er@?+pL#Zk;_zPJR0$|! zzr^y7V)+NbpJSH~doQyjXO^-(3>9n$K}AR-L=n&*ZYT;Y%F$swd^hlGFn1j64P8A+ z_J#_=fra32IS*gTGg1+bVr@BME zZI8V0_%UjXPH>(f+~VWpEU|^QY(mI(VoT~Jlp(yyhnN2)*ied)R;JYg@(7xrAAx9m z624L@@+9&IRgmHd_%1#HrMRX};WEM+AD-=XSRO3Gar_ndZ7`DB@KgDAV$&kAyMq<= zDmoxIe%T~^lqkaUiG|Twc9P{xi7zvR zcQLqzAo@@eo0BOGo}?nFCSUh9&$JbDu$QvcdE9~UfnPEPKMfUOamZ9(MIPZpKVO2k z)JX`b*VIMi5kB$r&%#K$2%o8Jw2VB$r+&WDPN6K4tfX0H8D$8cWAGw^C}SCZPt)de zIL{*BixZEE((7D6&Gp7L_o?hH94Hu+;0O*Zo A1poj5 delta 994 zcmYk4O>7cD6o8?CuoV{MZ-K(bKdOY1{sj3eY=bRoZIGBytB1xAyEY{Jv;!QlF(!sX z4?Sq!&7*qpWNL3}VmvlndX=PiJsE8eMla5rX~~kjFSGA`c{B5v*R%f;V&7&P)zRPn zr&o`Eio4=-v)&6Y&62Teh#2=im^&keI}sD)tpPBJc4%5f5&fR-n{ndEXfY}9!rIcu zz-Zf+!?ZvU(==KprVWha#Le>X)iDJFTLyM)g5w&dE+JU)3M;OPNq+=$h%_$bp%G!m zq1Znk#T+6>qh+S(>3)xxOcvfM%EUkRcTx;R#0{-zfG_qm{Bo>GlUPR-X&jv%_cnZV zq~PtjqCA6j#9bQ0>%{psGi;kVXI74*hFI2WA+E)lw(neqEvMjlpf%FmNHF8Q+X8LZ z3dk4&E#=TSq{X$&W@$hADv-grySdDIY_xR|4Wnl}lv(nGm`8AON1utSb_D6kISB}KZ4 z8ltP!!mukPq3x?mi&#fI)z%A;^CcnbzYd2!!PC>0F7q9h=xwLrvwsune!;V?HOky5 zvNLQ22*d({V}}}K3c;Rb3C@hE`Y^1Ig`Tn3fPeE~^j@XbQ454L2}z)vLSztZ^lZ3n zbU2fNQ0{J=*lZf?u6UP$d8I-c)y6tm!Y}87xXS=&R0QOK!nas5^V0H*?14rS6Y;l zlbK|!mzt4xE$P#zc_4i^HWN5QtgWT zfjSt0xVU~Yw}2Y^4KBV0_75zRtp&`OBAF+52*`-+oe#7 zV;#ab2riE5q?pkuqv+-m0)m5^4u_M}#rOS!9(=!h?|I()p6B<%=c4_|vUCE^#}6-B zOU}Taqu&Qh52_gw(opTlvFV$Xh%c>U$Byq%bW$DHcf~vFXT!`>;^#sg=!FI_AI*g3 z;N7`vR+%sven|OdgPg7(kVC0K4(K9@(8&nL0XGZBg^i7W8_U+xbJ^Hj6=E5k3xJ8bwS9}R z9%FbPOCuD-3PR;Aqe?aY#&}6D@w!=d7eJn*+uc@=-Gs3^JTe=pnG!Bft+?6lvfJ=| z#DCZ&TH>}-xGOR@acLGXG5YQPTJR+5hL9_vEON2?H2exq(*|O{9`}1}PxR!E;XV!h zRm5e4sE&0+@I(uOZZnR8fYng@U+zr19{0liPIQB9fkENyKIh+@i+YllsP{F!m}uN` zuRh$7i01twlzL-3cT!6vnEoWX5G6V{cJs$|aE@zZZ}#L~qJnm|i!ra2N}jw`Dn&BN TtCfN@I!}>Bqp~iI)+q2V-rk2a diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-312.pyc index 0742196ae03625f537971a5917b0d71fa6995b1d..eebe302f4a633c03cdfa44a217f56487f2e9d6cc 100644 GIT binary patch delta 20 acmbQhF@b~oG%qg~0}wp!owt#jl?4Daj0FAw delta 20 acmbQhF@b~oG%qg~0}!0tJ!>O3D+>TL)&&j# diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-312.pyc index 9b906fe68cd9a8bd5d03830ea3c1861926cb4573..d47dab24afff7c93ae3a1f3380294dbbedfa53ab 100644 GIT binary patch delta 574 zcmXAlT}V@57{}lLdv?y8xnY|V*~w;lXc@!rC_llR2$klAibF}$m=O&8!YDyBRMZl& zH!)dQU4>m~Pm&M>R*+!e#3+a$(CTW%oQtRn>8$=255EWg@bLUXclg8%x2&7Z@l4Oo zjfP$ z<|x0YUcwHImv$)lLAw=iC6v&Ms$q_ERB>ikLK~f^ISTZN=JT&mNNKg20k=hET?nfp zuYLxvX{|mLcthVBYJm-LvT*|+$mrb%J_@Djrs)f3tlI*{#AdcCmYZhuJ7=4VI3hH9 z;T{0WXuSo*(c(n|kSLbha;|r#v-B@R=_1tTFE-}{Q z(i?*;s;~rG@WA0uHpgt)blC&#k^7;0%a*+uziBHDCKQL`Sd#kW(r*Ph^yi9|!%1d; zqXe(;b!Hh8O{rs*VMPQweaaDi32S8R%H+6Cxjo+{Op^0zzyPA>{YxD0$Uksd!dH4f z^qF&Rpl8Fn=0UMKGM{0T)jf$RmN1Wz^^}|(?gMjVuGrVKJ;^CM!l&uR=!%r5yE+)O kIHN2EQ6KlnC75a~V0TF$;f&c&j delta 547 zcmXAlT}YE*6vv&}M^T)5y>%HE}4loT!k3Y2-y=2_{Yh zji-?xkzH0-%1JPSE{tGd(1rv?7s9BnjOMneZmf57E)KuLIdJ&@W`cb00oQG1W@a$8 z-o0At+X<}cy!yo^({ISh)wgET!V3;cBNslVcD^5u*Mm*C;s0E zlO>8`I>gjE(5Pn21!E#Clgy{d2zC&XJ(0 zOOF6fX5T$PORHBjK(<)#sZ^R&Jr9}q-Q(g`E>8P9#IpZFu|Z;NG*4aKVM&D@%9$Gv zj4$-A3@#3CXO%r|j%3w^)9a|9_m2V_=znd-t)K%k>F~ zDY_U>QF^^>h}{4)S~v6|OF}A=jWHKJnc9%5+SNQ^U15@?AUVKYGHSwx<6)a4$x{5Q QHRGHDQ=Fyxh*M4W58=SJN&o-= diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-312.pyc index 3f3c362952b8948d9fd5890dd3c9827876186649..470c72d60a9cefc9cfe14d2ee06a5ad13ac39077 100644 GIT binary patch literal 1275 zcma)5OHUI~6u$Flhd!x1q=Gd(B9WlQ2pA*C!V01Vg1S&kp&5EFFfe^McZ$La!loLG zutH)~SXslyr9VOA!YPDU#-(w=uE36!_tKe!AR5kM=HBm~^L^(#cjlYRWd|gFy?i%P z!;?4Nm|-;*dma{mB>(|rWDo+7g`CX9*bvJA$ln5k3IHJvS`ar)3PL;!kOlE;Ore_W ztZN1l;@ZiIAOZs89s@k|GHVED7h$p?8{#J}0D#MpZM^(YqOn9gv{Fs84m0yUWF!0z zXfZL!RDzK6cs*o0L#mHIg936=ZrbsDHxK4j9w2sh4zc5v1UeES_laDIhAa1fUAf-? zXno6?4h~!$JFi0jp<-104-ZAi_6EFVsRuH_nj=k9)D3NG1g>QqmupL~)o<{QHc5`rKhaK~GW$ ztJt3uqZ8sN!v5)!zcGb;o1o#8&fzJnTce3sQdAExT`=l&PeB2}h>6%E5h<2TC~734 zTjfMll(Ejs5>|B~mVhZ4VVxrj-HugJQSnnr9n(1(#dUWoo>b6?^o)?vgrZ0!F2)e0 zA(^8{)tv=m<6KZsQWm4=BiN%e*}s45dib`acBh7``<28vQWH3gQ?wHlCS6X3d!*qo zmQ-}fG#w@*X)l^K7>4-??7u-(-VQu+SzO@O40Y9M1L* zrUS2n&x4xx+UJg}_s+WW?v6ki^A6fdz6|gVjXRxlmHlw}vM%3D*H&@qA#sZ(P!M0J ze{th=;CG7?E6l$pvd31nfHOJOxj{aJ{i$s8Zp~XPylspO48^m7Ml~>e;h4Ng?-S$U z$y4f&=@#N-zreREsKR1V3FtM>@K2dXHy6eyaMs*s$RlarW~le*c>ZYK-x7mz#FLEKTd zna5d8lv{`iPv#Y4S1yO^g7W_<@H(L1ljJ%-ZYnMi=FcF3X#IVqoHw@AU6* zo8W$9^7jOJHdY}23)g0uL>5M1peZJaFfqz+HcJU*WYpT+lgh=&s5g0f+Ed1q$+hVc ztk$f$pQc{v=YO`p@MMg&B&CfGK nnN-V}88tsLfXFW;>^|&_>KFKwzA%6opX2y=7)6V0fNliUAmYi&EN`rF1_rF!E|nWSby3 z!Ey7BxXDcZe9S;IBf(~V;9*cwTQ0j$_PV0UMMaa#ie{e}m^tMy^2m0CO$dL$FVtVz zS=n8EonQ4Lzv_at#WQT#A{kjl zK9x<5%1{;dVPqBj6vHIT8pim^j)&Ec@srHvNf{Rz8BI5*WQ8)RRxmSaeq;cVU&`2h Z*%{R@@F{&^05Lu%@bNH;7TEx80sv{YjD7$B diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-312.pyc index 18a23af61f013fdc08227a4e43e12eec500676ab..d429f5463a2091dab69d4a979e1ffadff88c094b 100644 GIT binary patch delta 412 zcmXYtu}i~16o+$dQj(N_QA(jx1r;LLfHInw~Wf6M1(TbQ0VIQF>PD zQmIg!C8LYGARPoDqy7U0!9hg4i@o7{@Vk58d)#B;v}imVhA#2*ao*i~e=xS>Tq4pB z!M8CXj@LX+<2txUbNh}*Nl4{c870`Qn#)C|?Ryk^v_^fu=GLK!oi36jE5V-BtO5pi zvN!b$CE1HMosBYqH?r1uU0fSAvrnzeUljGpbfgJUJT0v1iz(D%XJdC$7u;hd;gT1) z7U*!0Bu74f0xgj+RyEg9n{~{E$`ucy6!C%Lh9$=xQHna$#UxVV`Y(`UL4GARL`u!^ z914AAjQ6TH{A$BWK~Jc3LLsne0GNOn3T=U|Kwm(t2cjbueXGj{ej{*k1@3vqze6G= u_B&om4z!uDH1UJXrQtT(M0#SlgCs>AX!C3}Q%CEppDCbn_?oeiEOdVk>3UuO delta 337 zcmZqH->t`cnwOW00SHd+o|V?UkvEEkm+=-?K~a8kYH@L9Ui#)n7A+P=#>s0qq}Vg( zF)}b{GERQLAwKyJ$2Uf%$)7n@C+l-r16kQzikqi%S+X(qPrfLyNTmm8q9$`uFOVvl z3?iliiDG6Tp`g%E)DIGwFnPM5JL9Cu_XW-ECISU+u@&bRm87Olp@jj{fKq;%Y(?`xMsXFF6qP2Iloq8H7lAA- zngk+dgNQ{S0_40RkPfgxzc_4i^HWN5QtgVC0L6fwWGFVB>?&-=)FHpQPWTU_pxTFM n#z00crVlZU46Ga%IF%=NizYG}O@1q?$EdeiMl6|;1!Nik1`=Jz diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-312.pyc index 168f9b15ece8a734785ceadecf476a22595c42b4..6a28023353b753036713787e550de8d9d6c86217 100644 GIT binary patch delta 20 acmaE={ZyO#G%qg~0}wp!owt$umM8#6(FW82 delta 20 acmaE={ZyO#G%qg~0}!0tJ!>QPEl~hS8wTV6 diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-312.pyc index 0bd31ff9ce4d88f0cae52a9553bb9f9c3033a7cb..f01d7c2454a519faa27cc2db11eabced91a348a1 100644 GIT binary patch delta 4488 zcmZ8k3viUx72f;rJCDsf*^m(O6jlSc5J(6y5J)1A2%!NY0PQFCPDfg8&$*i{;6KUP`=5L6 zx#ygF?sv|A;&J88V~XRA^z;-1J)b`OM3-mRDaU$?aH48?KQofUY<~QP5!15@)>&^8 zdALK%!9i>0#OU$l=#14N3h;`x*fL@sF+}q5%`L^4X8TY$@JpN5YU$Df5fyNS{ai{j z>1?Bay$VZHcBXvhEcsdF_~whwxp+LKUs)5@@{m4);e~lP+hLw^qY86UV1wN- zf`^OpFf442QDY>1a-$vx4mqac+m0L?8EqLc^km~HM**IpZhJcobrX?NdSrgY?Rqq3=A>u}kTj(4num(tP?E!)5BaOcIesry9i>Fo8QrZTg6 zj^R~%W=lC`X>CiE;k7x1Ee_+^bip($wPl*|Y>8l6p58LYc-Adi=EU5&bw;ridkWm* zA|5N)U|UN&yK7y42V7ar}4C`o&_c-SX4<2^TF9`4y&&N}OY6N_qus6~T zJ@}!sKs4gNoK;ge@8gcGYQ&Qe@J2~s7ctMpY6?G4GFc&HFzIBXV`*{TEqiFFbC@Rs z$eI z$yK*Sz)SaQSPO?$zcg2e<0P9F`$w5#y!8kT`sch%_4@tvHQGYWtFK=)9ZwN9kfW8x9Gdq8WV3 z=0XF3BWAVaDEtfH__-UsQH~AE7+K`KnEchz>ESvBrBFVhRL-j@GKNII8 ze6D^99csgd!q}(v*OZwXS#}eVcy_ZI2G!?{XrW-I7lK-FD=g#*t1r|SrrQE{U`pd+ zy4x!oOU>`l%oiAL{6#WyvC2j1iscOJ+l#eLVQ~t7)l^C1=bK8+e&xuupyPGvq_0Q&dk;!NKj3Af< z2!Rf*Sl7CM4g*@M$cVh=7` zYaC;B@C6Z93M8Wg=b6h}!{3=OFvA5R@w9b8jp4b4cZbu=vacNqC*H}yE6mA=fJP7@ zft=#1!&k(;?iY&`GOk5~8g6dOG5 z;DATs{wZALnLZH~oqVGS4MIV1)9TM-2Rz42l{c@Bo1+BuKxpy_>6*k(Z1dL%3-0mH zCof;}w^!8Adg$ie6wv4=(Yf7FfuI*>t23#Y+^pUvjJRJdUMq7>;v$DYIskkQ6y^{_ z*l52#s8O|J;}Wgke_6FW8rxQ{CUc*Vf0((oEHod#Q){Sj&gz;%2fMthD656o-;*8s zJv10MT+NO}yNZ;hEKR2JEMz6jPHMUFOyfD6p%YQ^gdwy|ql>eQmeu3M?n(fC@yVxlYKTTHyDpgNbGz4o%xD`iwUr4AiN;Rtj zi-dRv5B41wdTdrOO}M3Jce3IYL|nFnzf;)hmC5Z)zEF55;m_K5I42>vmE?MJ(|oTBr<4%1~fHO**@Q1nv;GidwHPA%T@^s@S+3@j)5Zu8`oknppec8ZJ+|~u&t$k`RA~ou%G&OOS{F69O zC)GFVxA4o69P=nC_z;!R-4dG$W5-8l2#XB35#PMOa}+s_u5wuJmcunsTmU7jpQgIdt`M|!8v0x%OuEpXsfs_9PmcELeK}zyp+F;<(HEDqL5z&aGZE?$Ak%e-k^6Y;jC=Y zx$_3@l7ahOc!i1VD7lvd?zDhAq(o;U+lFt)_?`O<;OZW?Q@#wVL8?4pC39r)mL*vN zf1-e1F9s6#B}6meO1K0@BVdF91`yzD4C`5cm`D9gfC=9}7!`|%?%*NkolG3y0|bt{ ztXC6|L>jKy8u~*1Xh3a*lQc_zlnjUuy_H{S&b!(s?B>~5ofeUPHG7E=bH7=ELkI3O Z+eE?Dd^~%g*IX~Mz8S`O4|mH{_&+v;dPD#K delta 4514 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 diff --git a/venv/Lib/site-packages/pip/_vendor/requests/__version__.py b/venv/Lib/site-packages/pip/_vendor/requests/__version__.py index 5063c3f..2c105ac 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/__version__.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/adapters.py b/venv/Lib/site-packages/pip/_vendor/requests/adapters.py index 10c1767..7030777 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/adapters.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/api.py b/venv/Lib/site-packages/pip/_vendor/requests/api.py index cd0b3ee..5960744 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/api.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/auth.py b/venv/Lib/site-packages/pip/_vendor/requests/auth.py index 9733686..4a7ce6d 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/auth.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/compat.py b/venv/Lib/site-packages/pip/_vendor/requests/compat.py index 9ab2bb4..7081da7 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/compat.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/cookies.py b/venv/Lib/site-packages/pip/_vendor/requests/cookies.py index bf54ab2..f69d0cd 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/cookies.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/exceptions.py b/venv/Lib/site-packages/pip/_vendor/requests/exceptions.py index 168d073..7f3660f 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/exceptions.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/help.py b/venv/Lib/site-packages/pip/_vendor/requests/help.py index 2d292c2..ddbb615 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/help.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/models.py b/venv/Lib/site-packages/pip/_vendor/requests/models.py index 76e6f19..85a008c 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/models.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/packages.py b/venv/Lib/site-packages/pip/_vendor/requests/packages.py index 9582fa7..200c382 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/packages.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/sessions.py b/venv/Lib/site-packages/pip/_vendor/requests/sessions.py index dbcf2a7..b387bc3 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/sessions.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/status_codes.py b/venv/Lib/site-packages/pip/_vendor/requests/status_codes.py index 4bd072b..c7945a2 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/status_codes.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/requests/utils.py b/venv/Lib/site-packages/pip/_vendor/requests/utils.py index 36607ed..a35ce47 100644 --- a/venv/Lib/site-packages/pip/_vendor/requests/utils.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-312.pyc index 3a73bd603228170635dc9b7fd262ef6da8bd233e..1a25f800b24684ce483566b9e039f1486f7de571 100644 GIT binary patch delta 20 acmaFI@{Wc3G%qg~0}wp!owt!YnF#O(G7|to^adUP diff --git a/venv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-312.pyc index 6cca5ee5448a4f46e103bd401922e954bc81a80c..1b0352118b9ceb5e899111060845253058d55db7 100644 GIT binary patch delta 20 acmdmPy4{rfG%qg~0}wp!owt#DjT8Vv4hCZY delta 20 acmdmPy4{rfG%qg~0}!0tJ!>QP8YuumSO#+d diff --git a/venv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-312.pyc index 32964044cc886c11d2b05ceddf1adb953e9164fb..5d302e4c516fefe6dc691623c16ef671082e413f 100644 GIT binary patch delta 20 acmca4a!G{yG%qg~0}wp!owt$OoeKa!k_F-b delta 20 acmca4a!G{yG%qg~0}!0tJ!>PkI~M>z+y(Lg diff --git a/venv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-312.pyc index 56ef045cecfb4fcd74d48555001ea41abd08287f..f288b255839b28cb79af1c4f58e23f15e043d72f 100644 GIT binary patch delta 22 ccmbPxigE5KM()$Ryj%=G@VIy0MsA^009Kg?3;+NC delta 22 ccmbPxigE5KM()$Ryj%=GaB}yojod=109NA%8~^|S diff --git a/venv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-312.pyc index ca2058cf1006dab0d9642b52ad2bb183f0207e53..d68bf6ed213a8ea121ba1fd035af32928cb87c74 100644 GIT binary patch delta 20 acmewt_%D$AG%qg~0}wp!owt$uvjzZBBnN%~ delta 20 acmewt_%D$AG%qg~0}!0tJ!>QPXAJ;RZU>G4 diff --git a/venv/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-312.pyc index a727602c677062163beb9c46989866f911262b1d..26632ff6e66f83cdf25317ef330b43c57cff99a6 100644 GIT binary patch delta 19 ZcmdnPxQCJZG%qg~0}wp!oi~wtBLFoV1<(Kh delta 19 ZcmdnPxQCJZG%qg~0}!0tJ!>NOMgTQd1>gVx diff --git a/venv/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-312.pyc index d065a7a0760d542dc4e9c715e2d9d92bfbc1ee18..a51ee4d71b7b0e769eb6cb10e6cc375c45ec4c8e 100644 GIT binary patch delta 20 acmbQiJcF70G%qg~0}wp!owt#@mk|Iq6$Oa^ delta 20 acmbQiJcF70G%qg~0}!0tJ!>O(FCzdpUj>-} diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__main__.py b/venv/Lib/site-packages/pip/_vendor/rich/__main__.py index 270629f..efb7fb7 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/__main__.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/__init__.cpython-312.pyc index 8b415a2540093089f028c68f26625d36baa202bd..3543fc8488cc85eab72285610ac06c1da82be2ee 100644 GIT binary patch delta 20 acmca@cH4~mG%qg~0}wp!owt!YKpFr>(*{xi delta 20 acmca@cH4~mG%qg~0}!0tJ!>O(fHVL{9R^|m diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/__main__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/__main__.cpython-312.pyc index a3686d0647458b52e8214f36353154f2fe0cd515..4213abc08d6aef56f6a219e5509b34733711962c 100644 GIT binary patch delta 40 tcmdlIuqA-^G%qg~0}wp!otGxNkvCP1@#f}Ywe5^t`HT!KQboo7AzQUC;h3l#tW diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_cell_widths.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_cell_widths.cpython-312.pyc index f01e5d7d56b13e59059af00a8fe1b3f5e01f4024..d00f084e71948cec50feda030499c0284658266d 100644 GIT binary patch literal 7860 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 Wr6o2JiTv0;_w>#&b#c*$RsIj&6{Af6 diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_emoji_codes.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_emoji_codes.cpython-312.pyc index a0a667f0b2ee3522a3934e3cb9b3194e21dc86e3..a63a3197fad4b958e61823a7a3fe2f21888602c6 100644 GIT binary patch delta 31 lcmeA<$$lc1#*viecm7BRy1pu6>2;u+$ delta 31 lcmeA<$rka3ILsh2=V{` diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_emoji_replace.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_emoji_replace.cpython-312.pyc index e355bf50e8720851a80d5c5d8d66cde7268c0bda..9e336d269bceb5a6599bc217b6d210df5cc98156 100644 GIT binary patch delta 20 acmdnWyOo#wG%qg~0}wp!owt#D6&nCN3I+K9 delta 20 acmdnWyOo#wG%qg~0}!0tJ!>QPDmDN-R0atE diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_export_format.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_export_format.cpython-312.pyc index cd2d6399386378d3a63fd057a23418e01bbec82a..5b2ffff87ecd17d26459e3603dda0498045720a3 100644 GIT binary patch delta 83 zcmZn_S}4SOnwOW00SF%V&PxlJ$ZI0%&d9)Eqv+!A91%12@*0=` delta 52 zcmZ1|)GEY#nwOW00SHd+o|R@Yk=KMzn~{ORM$yIJIV3W`RbgV-WR{GQ+?1E+Q&CAQh00fVF=WXO>Vgdj&f&}XT delta 20 acmeBW>1E+Q&CAQh00bv@&)Ue%!~_5{%mn)Y diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_fileno.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_fileno.cpython-312.pyc index f8a7f23eb0a9ae018239fe5c559b98b4bdcab2da..16abfdf82861f5810401332e10653c54ed57e2c6 100644 GIT binary patch delta 20 acmX@jcAAa*G%qg~0}wp!owt$Off)cjdj+Zh delta 20 acmX@jcAAa*G%qg~0}!0tJ!>Pk12X_U#Ra+m diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_inspect.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_inspect.cpython-312.pyc index f706f08ee8d82597fceb3384f47d48cdf7ea5800..13809f279ef8d195301530cbb0b0f48ada5da797 100644 GIT binary patch delta 20 acmZ1&w=jPkm_7hQ!3G!r diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_log_render.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_log_render.cpython-312.pyc index 5dbc4b2b8cb25733429c80b2b7a8ddecb617b276..64089f822a81a96b98a9cc3b10172c8963176c64 100644 GIT binary patch delta 20 acmZ3kuv~%rG%qg~0}wp!owt!&MgRaikOhAL delta 20 acmZ3kuv~%rG%qg~0}!0tJ!>Pki~s;T+69jQ diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_loop.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_loop.cpython-312.pyc index 14276ec51b4c2125e0b354017f3d11ae80a75e5a..778fb5d45da2b5afb8a48a0f4a3205e69d455e33 100644 GIT binary patch delta 20 acmcb}cae|#G%qg~0}wp!owt$OjU50#j|I>G delta 20 acmcb}cae|#G%qg~0}!0tJ!>Pk8#@3$*#+PL diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_null_file.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_null_file.cpython-312.pyc index dbacc8d4dfcaa54688722f46a98c0974fe9e4cfb..2f3a93f8588d14d2f5811c7e281384ba5bc4fdd3 100644 GIT binary patch delta 20 acmbOsGed^^G%qg~0}wp!owt#jmk$6qrUgg< delta 20 acmbOsGed^^G%qg~0}!0tJ!>O3FCPFn@C8@^ diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_palettes.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_palettes.cpython-312.pyc index db6d570dcf33b8f13ef03dfc92f9b77756cdc323..244ee651c90363c22c9ce6b6649d21e00ad46d93 100644 GIT binary patch delta 20 acmbQEF-L>@G%qg~0}wp!owt!&Py_%v`~`9V delta 20 acmbQEF-L>@G%qg~0}!0tJ!>Pkpa=jvMg@WZ diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_pick.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_pick.cpython-312.pyc index b9534fcd407f583f9c462e47ab727cfc3e53a5fb..60981a4ec95f7b4c46165a809563f0e86f43bacc 100644 GIT binary patch delta 20 acmX@bdWx0%G%qg~0}wp!owt#DKNA2xE(Rn3 delta 20 acmX@bdWx0%G%qg~0}!0tJ!>QPekK4ucm^~8 diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_ratio.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_ratio.cpython-312.pyc index b29ea906a6310203c81f7b61a3e5fbcad0326986..2724d020cc0e90237373f293e36f7b27a4cd5828 100644 GIT binary patch delta 72 zcmZ2(ywsTYG%qg~0}wp!otGBBk=IU~QyIu>Wq2T`v^h-t52FY(tK0_$An}=*fsOwI W6Oi?hYjT>T1*a$ji&T*$P%!|t6A=Oc delta 74 zcmZ2#yxf@gG%qg~0}!0tJu59?Bd?t}wm$$P6iEwCaRwHtB1xcf0M1bnG5`Po diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_spinners.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_spinners.cpython-312.pyc index abbfd074e49e1dc352a0c37ee1dbcdfa3ffc524b..f4f688a4908a44f8b83f7085726aa33252e571ed 100644 GIT binary patch delta 20 acmaE#_CAgKG%qg~0}wp!owt!Y#TWok%LfJk delta 20 acmaE#_CAgKG%qg~0}!0tJ!>O(iZK9D6$cgo diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_stack.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_stack.cpython-312.pyc index 67681b99f060f3446e78275a937eda65184be1e4..6eb99a39e91d8e5acfaf587ea28d06921bf7a70e 100644 GIT binary patch delta 20 acmdnVzLTB%G%qg~0}wp!owt#D9Wwws&jt1X delta 20 acmdnVzLTB%G%qg~0}!0tJ!>QPI%WVo83qOb diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_timer.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_timer.cpython-312.pyc index f1c1e9e7524ed9528c087bf5529977b8265a0fce..413abfec26fe37da988f9d443dbb6f95e5b61f52 100644 GIT binary patch delta 20 acmcc0c9o6$G%qg~0}wp!owt$Oix~hv3kApk delta 20 acmcc0c9o6$G%qg~0}!0tJ!>Pk7c&4qRR!1p diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_win32_console.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_win32_console.cpython-312.pyc index 8f7ae5025652930d54e5b9acd69a2fd7bda94196..5d6d62b16e351aa6af4ea483da7b4e5b803fc96c 100644 GIT binary patch delta 22 ccmZ4Th;hjyM()$Ryj%=G@VIy0MsCSM09$$oT>t<8 delta 22 ccmZ4Th;hjyM()$Ryj%=GaB}yojogxj09(WdZ2$lO diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_windows.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_windows.cpython-312.pyc index aa41700c33be980451cfef6770a5575856fd5a4c..11b6f9de7a108e37dcb699b08a49f02433895037 100644 GIT binary patch delta 108 zcmZ1{yiS<+G%qg~0}wp!otM_Sk=KijQDbuin+7AJ(&k3?Bt}NP$xk?J8RaG`aRypD zGBR+A&){AVb%EXB69WsQ#0M58R*4H*4qq97^aoa;$gg4{pkcEenVeJ@4yo`tnKB+dGAc|~;taHQ zW@O+LpTWH#>H@pLCk9qVi4SZ{tP&Tr9KJFD=@0Bckzd6^K*MG`GC8R*98%$PGG#tw H!U!Y*6Tllr diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_windows_renderer.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_windows_renderer.cpython-312.pyc index 6ee62c3af3135a2b59eb985197b825508dffe89b..0d3e086c6c5f6bce48c644ef09da4b81de3cfd33 100644 GIT binary patch delta 20 acmaDU{Zg9yG%qg~0}wp!owt$u9xnh!DF(Oz delta 20 acmaDU{Zg9yG%qg~0}!0tJ!>QPJzfAta|Xx& diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_wrap.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/_wrap.cpython-312.pyc index a3452bd5a57649bc46a5102695ec609161336e96..aef2dd868ea56ab87edfaf78ba5d33ddb23a58b6 100644 GIT binary patch literal 3324 zcmbVOZ)_CD6`#G^`+w)Nu@C$YdpRg@#@Ho5qN22^i3tz`pn)L zThs>scEz4%qb$f+(V;lf&Zv`)or){%j=IyHsE0u|B-#3EO2AM4Mb{0$CN1g{t3~&D zHtH8^#E|GY?}!GZ3enrY9U=TSVEdF{x-wcxu_{IX%|O{QC-Klp;wWX$p(VJqi9-&R|MUN*erKkQWRd1RLdJrftY;i!=9Ml5<9sA z`uOUu(*?26!~QXk{|tjJ#E`RQa*RPIN!MpD56c4+nM`RXb2ig9a=^6pIm*-J!Hv~X z40b(d&#|E8Do>UNB2!v-&SBb3)^sH7mzYV&wEr0e`&1On#ZIzszqAiB5&Q7Rr)5bI zbxsoEDQ-~1BA38gnln-oXGmuaPS81lGqM>)@^aAPnraBLDyvCuyKV^B;AK^m&bD%r zDwc)>CDO)qaA7hEbFvC>vQBLYWLg-aSh5;dvLg5aUqal-3Q92mK@~Yc9pVO4vLWdi zAr2}U)xvTzWwcRaOj7h%gtc5);)x&2krs@2%3{GnwH!&TWit_{#gbK6?u@3(Brz;6 z(dCP(4!Q!%4zXJ-k?W+M$uc?atFF#{v4gU4DBH^&$6B9cXnIV~W;AR_u>naPh#ir8 zV*o1cgb4eEq@>3(a;BY!IZ?yySdORK`9UmX+A>3ygQDXQ!298+r=a@+{WFhNyr{A& zf9PIS?c~OZjZ?6FoC~W~&!MJIA~$9^?xxc)5S+#N)Y+rjE_bpElW` zkFU*DvSRpV9$%#lmV^v6?R_A8w&hsJc!#md43Mc#qnyhoD&=M;>X}6-28cOV&Yknv zkm)o%Uzg9NtS?#Sye4BhhJkByKGSD<`(rTjn||y!9YvIq<}k2u&T(KRK|lSh=l|0Fh()ITB#PLDD{x2$Wk@k7 zO5MPu47CI;)K(}NC>w527L63QJuL}(7E2;2KFVy7Rt`%>786TF)(tO7a^F2W7UQ0JuBB`!&Wq`|a# zsjm*4)c4U5@l2|6AJ<)C832*a3TauDiq%b2sBuw87!YKIFnKZDRal}#T0&FAeca&$ z*NwAME9DTKQ#3URK^iGR<=&zOZvi5#71lxwU~7QNG}sMQ8iXAoo@sO^=q{}ZwS(># z*(;zrIWFmB$-P(-`sqrEDeTJ{R{D^EdMC#aaam3wlL11&gwSdETTV>&HiO+nLaNWQ z!zC1{#1%wPO9U(l&6e zDP3f3p7NalU1vSI4fonZKp6V=o{47bj9e-gSIer3Gt-q!ZpzJ;wXe~Fx-_G#}FJ0&hP za7&HhnY~wzE;TeSwd}s#d82*0>p|nDU!0t+xpsQKv2FUmqX4KsT8C;kF4ZL5 z!aHU=ueDEfSyhc6guqSJhVktCfu*Kxv+QMU!ne}Fz&chs8RT!6W9uKo@{#4{;jWQY zo`>g$>s5G|Xz&~%?@7D?y5aBcdSUmTy`0b+7o|ipCHM6!X;sVo5OO3tFgSE}xMTmT zod;e!c*?twr7Wim&xH|Pe9iV)dtsVVdU2F zAtR-!g^^z^-8*VDS)XvbC#u-^PTA|vY1FfE(2-6*L7we-9+!l+(4)eGXJ}tIa(-hne z!(k7hHe%irskXd4pU48`Nj#73MA3#N%V`W{fHpCC(OC|jya)0X~Le!C6K65Mj7p5G{|d+%Km!5rp5t-v$|Z zR_a%wTd^|?b038Z$a5bx{2ev^4Q+eitr-jdsO3V-cx=HN&buBveN5Xw8uu^_D=LFn z|Jd*yd)Y}~wf}BKbN=8W>wD+u$kDlV-FMkjORVQY%Uo#J?H3ljFWzNedRpzs e$dU8M%KC}BZ1MpZKP^453^_nM5Eee}*4qm1l+ z2-P6OFomu)g>7wdix&J$=}!v%Na@$c6x^v0O9?c8Yy2stAH8>UEj`0M=brbObI$#z zVIz?HMUp&#z|TK?K7Pgtz#o*Ufvq9TzMlc$GXMc(R1l|>RhbkUXH#69OYw1@0g!{d zDx@57hkX}RXUY|KrQC5h16Y8-M5q?@KMEb|ITDycT!c>Kg)YP*9!cc$j<}PR}?G z-E(}r4u)+T50apWe8iSRlC5_^@0<|#qk1Ua>H+|tCB@XKfmARaw37#+Z^OS{%M?I? zi5SgE!5m~F7f5{}a@;TgeK5EYTIUXwH5Udq$8XdQ<25LuV}g@ zj7(<5daQyD8FAYU+@>1Z_Km8 z8&?IxGecwsb8C>a<+kBDyu}R`U(nq|WrN{17|3j}wf~+Kb@50i*19kVJ|fM%M(UmQ z&PwJPN9c9Ki`^_R9EMagniUos4W}+0xgTj}h-}um*v*5*kBRdu(wre^%;G18li<7N zIY(=5#SrXh?pie4M_63rfx%q?G47ySG1hXW5_e=xnL)UoWQsX0MWFd6{{TnKW_LJ8UxfCY zATr;E#{7HRQt00Gh3oluw?pCl(2hTvzqE6rt$1$b>Prw2ddsecd0}2(8mUB@i~O4S zrMN0>Mf&E&Z82JSt1Nbw!cWA$ZQt?2hfjQMmEf_Rj=qxq5Is&j?f776Xs7e^rnJ>L z@Dez~r}Sm7e}hxPEzgXt$~L>no+u>S(#CZ~4NWkJ#@8 zK=ecakgr&6UQR_a*w-IsQ~4a=iNeMK&NdlrVO zy`=DJAMghA!~5hvRlgSywXg=Cp}q|IipKld%bWWxcD5cId}?NkO%s%QYeNm%-lwKamO9K$fb0rxY|RR&$p zLDMsEYS$B*Z@bsM(7kkR%hQ&3Rvk{JZ;7h{LJF>8xTuxRZw8CA<<|ak^woVT-U~G` v!KGvs5K?TnNhvsD(}yFE+P@#&r<&@3dDq($c*H#Qyz?u6zA6I#xLxAEA1-j? diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/abc.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/abc.cpython-312.pyc index 9a71bc4f0e468db4a2b558eb39ababbdf91ecfa3..bca5536af2ccbe43657cea71ca2774025eecaaa6 100644 GIT binary patch delta 20 acmdnPvxkTKG%qg~0}wp!owt$OkPQGk{soKx delta 20 acmdnPvxkTKG%qg~0}!0tJ!>PkAsYZZNClh# diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/align.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/align.cpython-312.pyc index 033689c9208ff4f32a3aa0e5ae9622a9c3eac8c4..22793cd8d0946524860c578f96e834ea7b05e15c 100644 GIT binary patch delta 28 icmbQ1FfD=mG%qg~0}wp!owt!YhK(sReRC$;T1^0dDG1#F delta 28 icmbQ1FfD=mG%qg~0}!0tJ!>O(3>#B==H^VcwVD8b@d)hz diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/ansi.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/ansi.cpython-312.pyc index 1209bfbe36a8ca7db428749344a864e29c218171..c84aafe2edf017b098ca16716b22b24c98d6e735 100644 GIT binary patch delta 20 acmZp3Z*%89&CAQh00fVF=WXP!Rt5k(_XYg` delta 20 acmZp3Z*%89&CAQh00bv@&)UdctqcG?K?V%~ diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/bar.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/bar.cpython-312.pyc index 60b9f833c13ca625af9628e5be28abd6e153e997..3882913049e10777f9543db42dedcf48a05cdfd5 100644 GIT binary patch delta 88 zcmZ3YxI~fnG%qg~0}wp!otL(MBkxXbMz+nzxnr3a!#1n(g)z#iu*%*Lm;1mBqBYII h^aD=O&#XZH2cO9^_)(D}*$qKlM(Mgahaei)np diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/box.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/box.cpython-312.pyc index bf64cd6f801e3d541f10ac1f8846a40ca7d0006b..bb0cf55c9d672857fb3a6b1dc42c1565596508df 100644 GIT binary patch delta 556 zcmX>Wb1a7MG%qg~0}wp!otNgXwULimyFP)Hflu%Q6FV#K2LT3d{x8B@d`u0j4aJ`s zxEPr}N-*#Xp-A#GHL!Is!z86-Q6#09E-(mAFowxOw2FRa=7j0u1R5#EAT0;d1rnEL zs=vS>G{N~Z14KqZ7$n0Flo4QRVDAuyh)Y0qfW)PNRv>ARk%wuJ0ZIr@2!`o^Ivc}o z5pl4Kf#M=e4cr~U^)L;h5-K^jm)58@z@IK&4q2MLORJphYEL8b?5!!6G(;{RWG`1hpG1oE>I2SokKe-I&a)Ysq+bvb*kAu0%!#7O5f!VDbO}*HedX delta 556 zcmX>Wb1a7MG%qg~0}!0tJu9t9Z6hDEc6}Tx1E1grCQeqC4X24b#O9G*XH|S`MrWC@#%Z ze}O@0g7aqvh>U=qG+X%Jy*;O+>n zhiMR%fJullHSlyK!^F`wK*XgOusc->7MMWK!NL*ZHDNKB`NB*MTpchk*E8UdfCW58 z=;3mZpa|FkSS$)MHE?t&gQMbu0s|{gN7xM(u^H?)SOg}h-C*JDFuTFRH-YWOWL{lM V#;23rb-!{YGcvG96*&Nt2LLe*hl~IK diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/cells.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/cells.cpython-312.pyc index ab66b54a5f96abdaf44e5b3e99e4e4b7000d1295..3be51a64939f55bea2a4fb566a8682c850d5a27b 100644 GIT binary patch delta 2479 zcmZWqU2GIp6ux(M_J4N!yW8Dup+m#pLMvD?Z2(cRicrxQF~Sm@EPJQjEz{j{XUb2r zb!+6I#1b&`KuwIn2MwkqnqYi1`s@qEM#?0_5)u<%%nCdx@xgQM?Dj`yv*+G9=iKj} zbMAM~{J#C0p32XWNQl7m;L_(qH=1F@m-^#(C-l)*l#r{05k?I%N;8z=Tr#AL1f$3B zjLI2V=w!n?>dW|G?qxp1KN`pcD3ORRjR5xlALgH{05Coyt?sy5X2P&gW`Vhy4@3;d(3slHKt6j?U0X4Wz%xtIgw1XMQDifi=N6~7rp#)`yPE7YhG zoAWHYcY=GownZar*5h?37M}p86$tcUZF+pdyIMQ5K_=&=^HO^K9|)PIPB>dEmaME* zC>6~&;XP>ZaV?k4<#l)oyplBxIeXI3?LKKoELW?th(-npanYL>rH?74_P@U8?APTl zX}kTWd~lB=TlzW630Z(`Xl7wT=MAvH#7tE6CEf_5(;)U?T240%&CrWH0osUt+S_BR zN-L!|fAGHGLho9K4CG-H3Wyrcl)&Ll_F=zzY&#l}Lc9e;+T(Z-5=p~jsE~Oa1}C_( zT^rg&SeT5u99LjDp!J~dw14#P+n9tIRK!1;J%`z>DFu|+Eyb2VfTp7GW@4pOH#!jk ziXHaBU`G;x)~v>oxP=VP(54P}O9z}_uEg}QQlV(sYWPqCmWywwi@o;w@Mkgt)#~)T z@*O?85zRgnn?OMRajjrN>5IdL?&f^9z^uH+!mFGQ>P1UVEW&M<#R@$db)N z;O~qX1xrOHt8fw})hHBoQ#HqPdDY5iEmenmB9!V-!7|me1uI`Df=O4iXR-wYFOIqu z>zM`{)ZW&7$QHsaDj_YN&BqY6`2Q8ClbEm0`E>h)^mVucQ+a#1kGQ%J4V81~Ek*cM!GjmfW$pUY$KM_3Bc*{i^YaG4EPX1&-KDDvHt1MVrtX%(0r=*+jr+v zyQdrOhf{Zz_Ss{zgA2;m#jY*ar7zNVx_alkdT%M6i>Zwl2k$GL*MbYmwne3FcK5up z>Ed8D2AI_Z+0y-MxOA!A#2ck*E%4;8awhrY#{(9g2+!1Lb}ZfY1+^@1g&ct$42T%99r1W zcrj;{N`}d0)cLIQV?cY3ecDm9oc(=^ntB#d@q;5;q5GW>9k$-Xrbyd##%{Ka`?0{>Ve5rYg>=U1ZN8 z`j|v${4bSA;VZiqXyTz{|JK^}(nBdpBj}o}idnx(6V=yf7wuULMXDYcm%`Di7sjfO e_!=JhadwCjS(%==?MdFX-;Y&-K_aI_tp5SzW=ll? delta 2348 zcmZuyZ%kWN6u_1M%w%E)iW=6B>T)Mso6iSP?564Jr zG2sJbn4#~3&D4aC7))F;KWO}7{N$gQ0Gp1z#kfT?#$zH`p~ zoxk_?)6NHb^56S>9s=vzFR%4~R87dQ_)%U$10U-TC?W3?m8djHqR6Er9g(6E#l0xF{8a>Lcf&0nq>+(gK@yvtEX!ty7zz*xMFu8`j&wy1wM1S`BLT zWh6B;0Y;k$Xrnf3^%M5PTg9_2j9jLdX;}FKG0%jl=}z*o3-MTdPzy_@>v$}gj9pA> zCOe(T=uXBN;SSlw%x6!mJcd)eCVgnY@tHQXC5^8=dw}#dL2-(rT1qJsZsQ^;)F)4iT8si^_ayE?0S|kA=VVh|~cXcSJM*$Pz@+K5CAQ8c$Gi4)M z*G8Do0}?VWIeWs5u!9OZM`Gh5N4yA66vz$&QJ_0c7i~m!2J5F3gA)ND=`{X!ZEHg` z(;ZK%+GskF(w_iA5CQazdzQ-0@D+CPHekjNo=7E@lkX^#L&h%oLq(w3MFal7gm>l7 zsJsggIgqp)*L=;Lh|Dp;u)A23y|6bKW(T2RqeP+|Xx3@`?%NX-t@LFyz1T6KJ_zbp zZtSV>(Yy%51qBiZP1k5Tlh70CR2;J@FDGp9d;N@fg!HnUwk#{pdcX9pG+V()&JH>$=NKRZH0R7ZRSNTzCqrB3rv#jH>DU>uvi33%T*e+k zUIY6a%ek|Tta}11vUIo)l5NX6hqi`XKFtPb`8*{hr(1lUEZG6exw7t@V|JeahH=d~ zAP?7O9+b=;V*mm9dP@1$fR#s;hMdNcs=ax332H#$m-AeLA)a`(musT-SI8&vNZe*l8XZcO}hL zjq`ShnC}Aumjg%CbhO1rN41n{x=O~X$%bG~!*X#@4&i~rhQ}XzmgAtCo=q3xQknK- zBBf>cQ8esE3nm0IY|(FNali3_KbZdxq?6=N2T}Gfv2FJvXa2HDe#h$3lheWF+Kz>D zH*5E=xDHq-oQzlmnB^e;#>vQPvr>3z^2DmoKeun@+-+ZI*%z8T`CC)#eB@@+-ZkR1 zH_uc~yXU%Bk4hl-sb7Z9j|}x;E&#rRS960pR{-UBzF|l>E5fSW=_rZz4O9~+_A(u9<8-N zSdZ2e;_b{}mRG8KL+op*p?8NdT=RA}miRHvnshu&IZkP~!IU`Mv;MJETu-Ny8IBWY zI`qq<&^C_mk#WB^+}4Fs8#LCm!8;+IO>t+7FPeA<4jOHNaJP6A@dk?b=CSL@NLn3B zYCZgAkl{m=DFC%>l+wGz{WIDA3u!T?0=q6+QU$Fmv|0q%eCryrbsLeYh1}Xf4oB!i z;-htQT^6$W0}E#tPF(L=h%C467m{z{>!^6B5J{fvzC{}>$xXZGGZq21kXeKOia>qd zl7iH?V6zCY>$Wvy=q4!S)&Ye!6hH}V{b$O=`D+p=Zv1ZLAOj;BgY#33noDN AXaE2J diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/color.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/color.cpython-312.pyc index 0dd994994a3da02643e2a5216ff5cb8b823e757a..2e9ac1f00df369c29966505d182b887bd8d7375e 100644 GIT binary patch delta 48 zcmdmYo^juKM&8rByj%=G@VIwgn*K)K{xHUb&2z)<@iX4rT$5(W$Z5{NB2}aeQ~&^= CXAblL delta 48 zcmdmYo^juKM&8rByj%=GaB}yoG=q)2{b7uWo9Bkz<7a%fxhBn$k<*faMXE>{r~m+? C7Y`5s diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/color_triplet.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/color_triplet.cpython-312.pyc index a5d01ceb5f582fc49ca44c753fbb78ab80bcff43..d67230980fd5d76b00a8c727d9eb48027e154e73 100644 GIT binary patch delta 20 acmbQqJCm3DG%qg~0}wp!owt#@j|~7fss*J0 delta 20 acmbQqJCm3DG%qg~0}!0tJ!>O(9~%HS^aZs5 diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/columns.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/columns.cpython-312.pyc index 053ac7efc711864fc04b9c1982ab7e65f0b251bf..bfb34a2aad745fdc022db0489389413f96f990da 100644 GIT binary patch delta 20 acmezG^xuj5G%qg~0}wp!owt#@L=gZ^DF)mC delta 20 acmezG^xuj5G%qg~0}!0tJ!>O(i6Q__a|Y}H diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/console.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/console.cpython-312.pyc index b64e90bc6c5de09b60aeff6553ae124e64d48fea..2e59ec775bce34aed68e1ab196a66bf6880ed24f 100644 GIT binary patch delta 1074 zcmW-geN2^A9LLZ1dG4FUy>fZIz=aeraTf>_kT+R`ayNl-0mZF{U9mb_}Gk#LRDVa86UPO?z8i9K% z<@o#-jH!?>b;sbLO4)y68`dB#CSXm}zp7=d+9)t~ls!n29w#HH3Q=f~nM9@nqgXz0uRgNLlap2IghzRh?*%*SoD3GY0nh zb{b@(+j=u!bMMa1blJykeVJdN?B_;*W(t-A+-PDRhDU)eeDtD}HjI597?j?TU=hUI zEJeC<8QJix4n^1l=2E#*@*jr@*28*cvY|Rn`R0>xW}7dw8_c#aX1ADavF!U)y)9ki e@YUL$6dj>(X_(d)Ejps$(par6Rdl34(f! delta 1143 zcmZvcdr*{B7{<@@ecvt%vgmT%#f2b9Fa%2cz$1l-w8f8E;ZHZ#Cn#?qy@0YC&_S~YbfwE%K z1myDixKV86ruauFq{IY2pp?I`<_y-6xYj7Z!b6gNz%KqMX%c(*mE;zbQE|#10k!;6 z>Ljdm%rqmQnGU6I0BXpdaazDfWX=3VzzMQswF2j8VSPDpfxntPgMf}Sv3JzeN&ll8VhTbkr5ul=zMGt{6>V3IYKs-+< zc?mJpP~wQXj(3&*jC^``>ya>2ll#5{B4+9Ed+)%}LTa!Jj|D#6Fa(JYS_61@<8ipV z$lTNhFaBH8SMa7mYqW#_y59Uf5KlvgHO_H;@qV^|RC?SR0%TK2dq0pzW4s6`;)agf zDB(*T-{BQL_2CR&ql=w801L$)Z4&SnKXv>*>ZreK7}!sndrUwJ9qF|IM`^w*F#3<23Ne3E*2Q{M28C8?<9^T!5AmK6m8O^XG>zBb2;HRB*hcp1wgM|AYQUI!&Ld z5s*onWZXxBAI zu)8#3R|L#a|J0ZoYAXM+TLTlRZzXF`Md|l;N*JPnnMF6;r@n<;V1e!}Is#m!!hbeM z(35Q`SU_@zj5iP~KLKo&klR_S!U&$0;~dv4!=OB`Lj$lyuJyr~2BUJO5!WRw$bq4_ zCBh&th2xIoIR1MiMkJVJTO1xr_)>08#1cBMdLo7|-i_*f))U@5c&@lp(L(ETr&C}R zwUus+Rq6!B_Ol0R@&_gaT2LSl^`hBxpBbv~U%mYll@k;-^U^79F4Q>D-Gv@(h2EyJ zmGvdtc24ReCznSl%UlId<{fB@oz$&Xv@Y-E+$bHaSC+f%3Z^sIeA~Pfoy&SNU!!e( z+cS!f%la}ugA(NDVt=MzsRX!C&pfEAt77ujGaWbL>dD|J}!LuqDPd;Ey zRd&lX3O#bFv`lYCWxC_97++&F`>+WwqdAmKL>tZV?CUhGIYVvtaWe;t_8>Sl)Xf|t R+N0srcsFyJXg9&3{{g7Uj9CBx diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/constrain.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/constrain.cpython-312.pyc index f84dfba9f0de2d1e927927cfeb25b3c4a97f716e..8c01dea388c0673050b2d786d11648248b428958 100644 GIT binary patch delta 20 acmX>mcubJ{G%qg~0}wp!owt#DHwOSeLmcubJ{G%qg~0}!0tJ!>QPZVmuHjs`{m diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/containers.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/containers.cpython-312.pyc index 9e9337f50b45a14d6d390eaf2c84f83fdb549b5e..ae0154d5230d53a68a132201677a25ef0266a576 100644 GIT binary patch delta 174 zcmez8-t579nwOW00SF%V&P%JC$Q#1QJTb|Wkz?W-e;?kE$N<-PXAf6rZ%;q>TO6Jx zsYQuNIjK-qNq*5S7N5-Gl3N`91tppJd5Jl<*h4A{Qo|C9Zn1{u0Yz?cxu<>V)( zY<6dK=VavA+|T9B&$x8*ZOO@esW~~t3W;TjnK>XsHvo1byP86mPDPn#-of0(3-?6Numh61SK$^Gb@s WK`hqdoXq6ZA~ui|$7XxQBTN99qdg-4 diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/control.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/control.cpython-312.pyc index a463e18bd1f19d4d1f43432d28422675db127916..0c143d1fb0463964925a7d4b8e4655e9b7a11a8c 100644 GIT binary patch delta 20 acmZ1)x-^vgG%qg~0}wp!owt#DmKFd*&IWw| delta 20 acmZ1)x-^vgG%qg~0}!0tJ!>QPEG+;;7zT|1 diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/default_styles.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/default_styles.cpython-312.pyc index c8f9bb477b077de7f1817ae0ea1b977b9fa25f55..9c78215f2e8d7888868567e421f89a43102a1610 100644 GIT binary patch delta 20 acmewv@H2q>G%qg~0}wp!owt!YPXho?I0o$i delta 20 acmewv@H2q>G%qg~0}!0tJ!>O(o(2FQP4psm@I|eQQ diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/emoji.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/emoji.cpython-312.pyc index dc8fb140feb1d86f9f759fe95cb8ced752b29415..f4145ab352a29cb9e9ef85fa67f3d5f389493ddb 100644 GIT binary patch delta 20 acmaE=@Kk~OG%qg~0}wp!owt!YN&o;wKn6Jg delta 20 acmaE=@Kk~OG%qg~0}!0tJ!>O(lmGxliUvsl diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/errors.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/errors.cpython-312.pyc index e3898222d268cd4826b0f584749b74b49c7f6230..acb7e39f793c3e6635db3fc26578b77ba5f89d00 100644 GIT binary patch delta 20 acmZ3Pk96JCxnFVM7 diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/file_proxy.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/file_proxy.cpython-312.pyc index 9bf75519ec195f5d74c051d72d244b71b44437c1..86946eafa9d33c6e1bd300e75979f15490f3511f 100644 GIT binary patch delta 20 acmaDW{Z^X$G%qg~0}wp!owt$u5ibBn$p*v# delta 20 acmaDW{Z^X$G%qg~0}!0tJ!>QPBVGVU69&`( diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/filesize.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/filesize.cpython-312.pyc index b4dd8425b64e6de1a8c7fd0e0aa5b87eca890b04..b8418f4aee00f1461d8f92e17e91c96a892b3031 100644 GIT binary patch delta 20 acmew-{!g6yG%qg~0}wp!owt$uGdBQ8-v;df delta 20 acmew-{!g6yG%qg~0}!0tJ!>QPXKnyVDF*!j diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/highlighter.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/highlighter.cpython-312.pyc index e260bda0d9d058c4a9a94f9dde1549e21c2907e4..e6c3c61ef931f5b92034c9f26150adc258572275 100644 GIT binary patch delta 51 zcmbQ|JKvZ0G%qg~0}wp!otIX)k+)2Q(Rp%}Mg|tCA0KQc>xf4K00txt1ONa4 delta 41 wcmZqIZ`bEN&CAQh00bv@&q`adk=IF#@$uvUu`3+zj0`MNKR(z^))9{e00@W;ApigX diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/jupyter.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/jupyter.cpython-312.pyc index 09bb8401bcb8e17e23246e97eb64739344d400f1..c6eae059f49d1ca31d608f0c938033091aa69040 100644 GIT binary patch delta 20 acmX@BaaM!-G%qg~0}wp!owt$ONdy2wqy_~5 delta 20 acmX@BaaM!-G%qg~0}!0tJ!>PklL!Dp?gkYA diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/layout.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/layout.cpython-312.pyc index a3dcf14ae00c68ce3e9756637f08f3edad9f129a..6250e724290608f89d01ecc7dd1e01afbfd6e238 100644 GIT binary patch delta 218 zcmew`m+`|~M&8rByj%=G@VIwg+Ln#HvosiQY+j+Uk&*Go<|r*!Mqw^anHe4*7=Y9Y z(QhE?gT&@d+8oS`tebc1EoWj>ot$jg#wfS>m0=tZ4Fy zft6QvBJTvY8LXQpyKyn|tFVfEW@cdH`@jTbeF)mT##4_)JdlM^{sRMu1j;dSe_#R& KWK90(`yT)@qD0UD delta 218 zcmew`m+`|~M&8rByj%=GaB}yowCx*tXK64#*t|kxBO~L_%~4vejKbWUGBZ3rFaW6) zqTfK&2dT}Qv^kg=**5RiTh7F&HaXd_jZuE{E5k%aMxDtUOe8m_8hbG^ngE%b8ErPF zm>M%OI&7X{CeF<0xp{+S4KriZW?kDv7RLO|{f^lzj6IWoyEcg_>t0tjxu|S%S=sCp z11qoUME(h4GekE}cH?5^S7jCX%*?>X_kjt>`Vg{tji(-qcn}Mt{09aQ36x{v{=ftl K$eR4o_dft#T}3wl diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/live.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/live.cpython-312.pyc index ccdd5825efb27aa7541fc8cc18827e096c28a9e8..28190cfcb3e4c365ceba79855d10eaae925c8bd8 100644 GIT binary patch delta 56 zcmdlzm2vk}M&8rByj%=G@VIwg+Ww8ayk63#?$=FyFPi#ZHue9+z#%AhQN(bf--NIk MAq#vbn|ieY03x>&?f?J) delta 56 zcmdlzm2vk}M&8rByj%=GaB}yow1XRYdA+2~J+GVlUo`i>Y##WDfkRO2qKNUtxCv=9 MQWnHcHuY))04XIDQUCw| diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/live_render.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/live_render.cpython-312.pyc index e42e806361c0fc718fa04a4f85bdeec414834672..f7a29577c7807640360178fd1d9767dc951dbc37 100644 GIT binary patch delta 76 zcmbQFHc5^5G%qg~0}wp!otGB0k=Ko%k!^Dbe?F6>9IN~dak&r7AX?KLOh4ch{lY4@ W`HrAEBYzAdqx>fZ5Lu)M)D8d^trJNA delta 76 zcmbQFHc5^5G%qg~0}!0tJu5AEBd;4jBgf_t{(L4$c~QPZ4&@d8V7;^ diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/markup.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/markup.cpython-312.pyc index bbc1a8b451681fcb9138457142c056fa17bcb849..9d2d5db2614ddbd06693615765e9bce8e5de892d 100644 GIT binary patch delta 797 zcmXYuO-vI(6vt=i?zY{fA1P8xyM*aBRf-J?CqhX47LkfUgeYH4u}iwO>^8HD3ZVf{ zek3Lhg9&;tl9+h#f@$K_n+Lpz;XukkjPb&$5fb%a;>^k<^PB(szxQ@#c0OL-yW;)i z@rZzq?@wP&JEHHr>rS{rJ~(^p@;q7dH~6@>kfi~@!3FT&BRi5iVDbwf%gxio5Lloy zAyh=y9&Ev#)S9mwA5S>2i?y{;R9&i`HScLwZdp7oc2VaPo#p`P5R*}-=i%am#j>^K zlwXa!Nw1~XN4DZU+rGwC?s4g}OWv(ah&cz}PdoZ58=est+#%6mDQQ}B1+^Qs4(pns zkC_%uq9JBYB)ZX!oQmu`vJ5n9s$?aYx`PgfI%DLu^xX{BGP;FY?M|a;(XV6*wD;Pf zM0OoItV<%59$&>svDEvPf()wc0;L^YP^UAq1e zuDhP*8c)}n00j5Glc`QJ6YIKOg3xalF|jN8%ME3<9Nv`V8qXYBU+=FuZRr9> mL!#!kV-X1AzGTZY9N_97&3|z;{j4LuVwc=8z=biQNBjq4PTM#D delta 504 zcmaFmbV#-7cbQhba+8ziLl86zfpNXs&MO-_?mWel0zBb~))H~G7?JhwN{s3IQ_ z;X7GTM#3`@#7qJa`9R_pcVa<7YFtM}x6N?L5zAZEtocS^2epwK8v1`(hzxW$r`pPy4yGucyF znXztiuCfec{p2oXL&hnS_b6|Z7iJW?!NdQ78Aw0imHog9q(87RuyKB72eEV}PgJo8 zs$ygm04oA99&igx5T1}aLFyv6%m-GG2v9wbzz23PlY>D-W`@s2Va*SmU_KWE8`o!U gFtdu8frY1|>Jqc$Czi?5s&1UB3@lPb3P2|U053m-EdT%j diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/measure.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/measure.cpython-312.pyc index d568b23476e5f9314a55105f7ca6d7bc9f2a8e56..788208df6b0ac5c2f27419e0ed60cbd69194884d 100644 GIT binary patch delta 20 acmca(c*l_YG%qg~0}wp!owt$uq67d(LQPMF{{$jt1BO diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/padding.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/padding.cpython-312.pyc index 247ea6f97d2d9a22b88f3c2d454627497ffafd26..7ce66a8b8d74765601fe2144ed7c0afb0aebe178 100644 GIT binary patch delta 20 acmca)e#xBsG%qg~0}wp!owt$uxHJGpj|RB_ delta 20 acmca)e#xBsG%qg~0}!0tJ!>QPacKZX*#^k~ diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/pager.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/pager.cpython-312.pyc index 1e76a67bef29ab93d0dd28367ce3a4fdf3a501bb..d32e81f11899f0e3b4e4144deedf60ae214f0421 100644 GIT binary patch delta 20 acmbQhH-V4)G%qg~0}wp!owt#jl^p;zX9W!a delta 20 acmbQhH-V4)G%qg~0}!0tJ!>O3D?0!+u>~Cf diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/palette.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/palette.cpython-312.pyc index 6b040db094e3eb1a6acdcf2866e2f7e0ae1f9853..f3a06df40e0b7840b1c703db345fe93c95214e5d 100644 GIT binary patch delta 20 acmdm{xlNP%G%qg~0}wp!owt#DwFm$}Fa|;Z delta 20 acmdm{xlNP%G%qg~0}!0tJ!>QPY7qcHdInMe diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/panel.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/panel.cpython-312.pyc index eff84554c5ee06e0bfe362814f0ade7295d15136..84004d2602dba7746c67259a8dced06293a3c722 100644 GIT binary patch delta 483 zcmYk0yK59t6voe;G5eUAJCB{s?#%8cGqbzdxNKN0ECM!GsZzx%O(JBIBHE~pU_={1 zk$~YgD{49gHG*;z5G?!y#9|BKmVu;}lLr>5at~>8;BbH6x!-po6 zy*B#JKN#$hkjCetF~|+_gW5Y=92(a|)$EwC){r~quL85hKdUCLb5AsEx4L3dT$ioe z*G>AQFTOd6wc%{=0oyUYxZiy_av2J0^Q2&zkEw z=F8RY560%iWbgmeY|KInrn;)tQ`0@w>8sYXs%NTsRV6Kzw$)Tm)so{x`}WIi93y`Y z+yL_zNk1AEMqY+CNe3z!av~SP`fzqsYNJQehq#RaQHefoZ1piDRbB)?#&N<5R8y=H zMWC0OFP~scss=$k47WJeNj0F{DC`U+VVG34ooM}2SAs3)QvpFXJ%oGgw_7&EB OF@Fm5;yrQDUpNP1J#{_FpE$ROipSgi;?Na8)@V^k?aXI* zi9=Hq^#Lb1`=X~+sS6-n$gj#!c-YliTbNeJhOVkqZisa6F;n< zTK^u7o`tk3rzFS367Mr{vdB~s54_pmqhO6xGNQsWb~O1Kalhl-v4C*Xk{`}G6_@r2 zos;9vfku}lgx?w6lP~qtI^B@Hjq?U&@+fyhX^WW1|I(BgZBMN>o C;c1ru diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/pretty.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/pretty.cpython-312.pyc index 6e161a91ce5bbc9d18826bf58ad3641938930bc2..b8e3cb708ce299576c80a4eeff37480bd93f83b2 100644 GIT binary patch delta 1439 zcmZux4NOy46u#&E^p{ewEvYC_2II#e6B;J1&Zq8;9GREZMzOj7#?N@}2Md?mOq6 zbMxN2cS^W^S}=WUG8qWFe(X8esM~9r3SWMntrNh9vxIK&(KEtzkT)p>4M})gO2gCA zF&L)nWdUY1vJl@t;pWo|m^0l^kJSs1$Zb2ojLf*{i zO+23Fgb?0M%a1dzYw&xTHg)*d`&u#Gk<1Qut|P;sulBYyl&Y#v#np~7jgJ=y;h>`g z5Px&bOPD5?!wr+YdsSF?s3Uqe&QG6}|JRt4#MvGYkh8BPXYCPt%~6r@zuOX7`U%4V z7x~&{U6>%AGXp~!O0UpCJ6^~QfR4_ap-4=8oUcGO)xBsIVJX@RTbQ-8unrdCt-^~r z0p7({4jl|4T8~HZt(_b%iCbb*t6vS`6=x2N(Q)TEz)E~n^cWO;_|iwvgzwL8#tp@J zSTkFLMa4yUp7CLq77r9>qt%s%(c(;eo5lIA61>Ucuqz*Dy7N%)&ct4K0j_q>!e3cD z>wW?J_zqLk=9ED@t)Ej1&`D3ueOYE5KU^>q_R)-m_XQ>_rAuH48%xhIo?BJ`XXuKu zLn3^Sk1Lil>-9x-FoMI2j;H;1I(3lGd6mNh4xRXBWeNoGVC5>uc``V8bIzJ97VTyMK5wevoP> zhbV_2R@OB`gr2Iih>%JzuE>+w=#SQ{g)+LzD8>Pc6@47o?uZ8F`A>=7}pW2J*tm!14*1ZVA*Sm z8e=+cQk!Bro+Q`@#NAy{b4(|YL|Zg5#-|XC;djdfAA>dYN1 iRfFrQ=zioNVT#k4Epu~{$n_7FEx{~CL)@HQoEyj{8iR?OS!Ihx(ZqW@HEO(h`JC_f zyqtT^z3T#2rjQdm*zdH(ZVoZ{um{$1(99LD1Ur3K2 zSJh2gW!A8(q4U}14u5A;dmFJN+5tS+nA8t9@ph7%>e^%rcyVuXndqkVvv@h#3VjHc zEJfPoYTsGs^0?dS3oNoMgAS~;Jc9ieyS9U-+2%7s{$k{vO>EOkf-7~M8nL8em5Wavg+h8HBVFT<&!W+BT7sbu40Mgc0ZCbyNQ zrgN*I3?H^$GWb{@KSK}xVoiWvRP)l{9$A<78$b;fuUUe6EXY3&O*otHf);$IDe3wRR;c}D;Gx4Ru4Om6vVqq43L}P_*Ia+L)IA&Xo9kv|giyp-wjkQG% zTvZfFCW=Y{ddRQEYehO#!TMD&Od8kU<*BK(Z-Fy-+J2F0mm>$xlVgrI1h|GJ<&lwgO_Ap#y_=4d&!wrTRhF<)7;|}O2>ngtGV|rQUF2fwf zX>fPr>dh-)fz)gs1lsbuC#`UsJoMB>ftp)eee{y5o*w2Q7VlK~)BkUb-`Qp=LwJl3 zQ@wbw+66OYsoEq!A~9~y6rl@?>*~Qy-mKF^LjyVK9_MLpYgYh1Cf{^ffg07j1(vYc zI|V+H?(^{4Z9K<$+Q?fyqkP&~dCr_TR)4~JR({`n!8*C(L(^nNFvlKDb9|QM2%1ZO z6!>)YCyqSVrxWQH-o4)m+2qRpd=aXNG|;Qjd)R0UFOs35Sb(?jcp&j#|HgD66;5F& za5e5fCw*|uc>Q1+j87cmHE6;U@D)yCn%)m|SB6{oJtlykNW-rK?SJx>1F#1(M{>2{ zzCLu0q!?acBkW}GExhV6f@N!?s7`9PdbX+JpEMqvW{+@}+ r`?Y)nfOTN|eU2m?trhs6Wekj2pcKc)5{wlk+@%uf37v3R2FgDGh1Yme diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/progress.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/progress.cpython-312.pyc index 3a877f1347b56ce7e99e7083483ce5761de0b066..7031c2f062a37620ac9858511b44d7151cfa3abe 100644 GIT binary patch delta 794 zcmXw%3rJH@7{~Ab-d#7BdpI{A8CfPZEr}jlR8;hk5F|0I=w<3kd+QdGB!U&0QLH+} zR;%b?_Sh`yO9qirYO*wmm6d2vQA82hMVFR6?6tij*`)%c5EozvEAlK*06TFm7fLn#l9TNScW4_m+yO@47wfqc^E^6C7S-=MxtZYJ&S=7F^#7d&9QW%#sK~gKE;f!%oxI$Xalpu{zD1wW$ zNIHe|T=Z!7mY^j?GAP!_#U!}Pg3;rpNX42sOPmy?keSo!zgiTUMDbNV9s&jS4)D;? z-Te!IZ}g|SADGDcYjRuYYnR;q2W0wvVhngx`x&ej;3+V%|C!!&_BR8Vn1e!Gvn4>KVbJJ@~; zPIk59C>YItlqSl5lm_>RXr<8e%|IW^>vrHbJ?$>gKu_s!W(rtMJKn|e*hB~3`_$M) zX?+XB&_Ly(&nmp6qVFqt4AZ?I0RKm%mY*?@yXgIuD8SV48{2>c*H#_@g!|J3*nkxO zDHU2oO!lwSA_T1RFN?qjAkIHWk9xCyF<^F&3~`EvvRy-oaH7{$Jq}$OqnIj>g4X16 rCL!8Yo`mD6F-ne8wzc3?BZt=De`467Om=YIg1NaG;h9Fvja2^y{)-lm delta 777 zcmXw%dq`A46vpSfk6qo|b=BS0N2R6YE3=nj1r-)W5BsAq0!u5`qC(5v9!Of4q#}yS z6l-cwYF0j?I@m&?5n5;(C@5JN7FO8%qE=W@-Agooob&sJ8Rq*qGx}J%`&cse7>x#| zuI_tP`b+if5g~PBhPlshRmxSOO26u zu6L%V9nQ2nBlUdL5y8#QZP?81&N$uvx_JZUSZZ)K$ndAc?27^h>BGrb5$`DIbUXH2 zWy4FWzapz$(Xp^_MX!+uGY2T18X1^xurf^}FXm%aj2fBP^jVdM`mIrlwC} zfBIa-N0YwH8ld=TWMKx=SF1+zX?0$+0Es^3PY5v4tAYezio%M(1?ch1s4_eQ90gL`g!mP?E|lGTCokY%%ZZ)iMU+`9nh z$le<#t8Z2HpONv9WD^C2U^@Ev%ciA~e$Nr%=MD!lfDqSt0bMY-Q$*N-Xm^K%4jBvF zg$7Il$?hC4i~)h}bQ4-Ergea&GH{YND*maND)mHO_f2B zlTDRN5zE$KU?^IZ!jK}KBcH1frNGFLDx2jzIge4D(RuPTMnzYpRHYQA>=>XbHXutj zTMEcx%;RKYNL5IYTg?cuhmoO29V{ZBsx+HnE)znWlOa_cXx<;7Nyj~Ql7lVLXq+A4b{0RZWbL+$_o delta 353 zcmdm9ys?<~G%qg~0}!0tJu6LpBd-jjtAr$wyP6p!$iNUK#l+ywkRsB;kRqBYnktPV zCzC3hB9^Vez)-X*g&{>eM=n=BN}iD+RVK@Eavq~PqvPahjEb&`sfsB~*)c#>Y(SQ5 zwiJ-Xn8(S)kSd=dx0(@R4QPOEv&TEC$8^ diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/region.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/region.cpython-312.pyc index 6b215df005c5a09a4683df6f7d845afd5fbc597b..ba423248fdd93b410cc152a90e12450f7802261f 100644 GIT binary patch delta 20 acmZ3@vYLhaG%qg~0}wp!owt!&fe8ROG6h8d delta 20 acmZ3@vYLhaG%qg~0}!0tJ!>Pk0uul@d<9hi diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/repr.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/repr.cpython-312.pyc index 2c19439950bf819cf44d96bb942aafe95ab6c662..bca260ee3eeda75c2a1a9b91a1c4f88d29b04f68 100644 GIT binary patch delta 111 zcmca+e8rgiG%qg~0}wp!owt!YiHA{Zavo0|7K2%y3A+Q3*&LHez%UW;|@n=_0^<*oNPQoB0SgE0BFe NfZ0WOvzg!m4gi)hAJqT= delta 109 zcmca&e9f5qG%qg~0}!0tJ!>O(5)Y%!tkJp5;b@FH4c*d=p zgZbQ<7%xqpEs(1t!r0=(?QFtuNWf7UNF6q2bP-`ZY{Kax$b8tA--U delta 20 acmbPZJja;(G%qg~0}!0tJ!>QPL`eWW*9IK` diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/scope.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/scope.cpython-312.pyc index e453321e2c510178ad3b779cba23bcf65a963bf5..d194d9c0cfa1d362a4535f6d1db2d56264fa10f7 100644 GIT binary patch delta 20 acmaDQ`%0GkG%qg~0}wp!owt$uJ|6%^ng+lC delta 20 acmaDQ`%0GkG%qg~0}!0tJ!>QPeLet2yh51!G%qg~0}wp!owt#DE++sw-38$Q delta 20 acmZ1>yh51!G%qg~0}!0tJ!>QPTuuNxCk62U diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/segment.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/segment.cpython-312.pyc index 1c27887cc43e1690a3aee224bae4edf5ecb7eaf2..9f5e489bfe6d44d7793935e110eeefe0884211e8 100644 GIT binary patch delta 321 zcmex*oAK*yM&8rByj%=G@VIwg+P00nZ$%l|HvblV%FH-r@yWys8! zKiS))oiSzeWfL1F#+u0j=BB;r-dl)xtwoyoAV!XL|o)R-NYY4H`)hnzUOAo%=mY+oYw&+Mv2Y$eO@v$YHmL1=f%Wmwpk?b6bqxz=KG;3 z%=#*^Boi`HSEKw_Vn8Q7#igy07jAoqjM=AuY*cE;J8S0yAe zGR~jOlXQu3(&qa~>zEkVZ0<`fU}W4r`G492#?^}-q_ax;b27?xWPN4;(Lh6(ct0?K MnBP+-|IGOV08dkOHUIzs diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/spinner.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/spinner.cpython-312.pyc index cc9843ebaa35cf49aa94654cc9a838ffc9acc65f..1091352eb2d52ad592d5d6fcb458c595e2689b5c 100644 GIT binary patch delta 20 acmZ3YzeJz=G%qg~0}wp!owt#DrZ@mTI|ds7 delta 20 acmZ3YzeJz=G%qg~0}!0tJ!>QPOmP4{g$64C diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/status.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/status.cpython-312.pyc index 152cbb122cf5aa4abfa453be6b11cb59d9d94a89..1a8111077da17442242125e8e3662e73394525ba 100644 GIT binary patch delta 39 ucmZ3Xze1n)G%qg~0}wp!otNgZk@uJwva9)7>G%qg~0}wp!owt$Og#!RThy~98 delta 20 acmX>va9)7>G%qg~0}!0tJ!>Pk3kLu{(goiD diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/syntax.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/syntax.cpython-312.pyc index a6b34ccfebe428d565b09747a95729836c903c6d..0f88a952f0d855ade097c37896b9302ea864f771 100644 GIT binary patch delta 1863 zcmZ8ieNa?Y6yLkMZ($dAMOZ$T_}Ent7hG6CL1o6$QCJGaMI(U*guU;<(#pquivqz2 zMr8z!axzJqrfkY7%a3_ung2C?3=TDBI!Vi9n%QJd4U>#vY12KALhZiU-#z!-bAG>b zzh;l0)E+#gwTzj~CJk>_hhCFl;DiNIiCsCAdX$g?@GjhvEGAMxG)r2V)~`Q;fxJ~E z8#T0mnne>7ra5*9Vv1y-3;TsCJ53iIbdflpI{8naMk$64QCqJTVSGNoV6~JR_TPEHY~DeRMg^;XWtEZ>DZBgC}M3B67KN zu}U)IbBS3hg@NYrnQXd5Oi|0y)1`du#wDn77SSYW{}s#UGdZ0`=L+RS`YXxg9eAwh zB3xM$6T5^LvtJV=xCPiKp<1c~_uAMU@9B@|XPg@~PNA!Cm3>2J!&b35DBDZL4w2b| zE%tU^n>|VJzQ+XZo`;-Po~gEA?5veAYbDNF$?%aUlQ`hG&I-3ZwiK-Ee{ENo zL}*w)*K1n9wesNOr=ksg$y_=edP?GO2!~7Nff9%|uzB5@rcC8r$*7k6q8upwgOIZ@ zyncW$AgOF4xv8|3?Ih$9Ol??2%#iPWn8d<1Z=sf*fur8#FMy3ATtT>m z@HWEt2$vBqKxKKp;ZxknQrK5cBfgGwkI;+B?sLg*<#u_Yj{F2mE4;*}JYUhLCBK2O zQYPt2Pvs~UR8)PCx`mwYa&QXlakTHkvDyGxr6g|2)sd@E=8Gji zg5=946khhNA$MTHml<~#BMrO;cA8ruf%zL6gKP|v=q9pRVRV`pWgpJ}LWV|BCBZG=zD`t#hK9D45jNCOcP0vsw`K6cC)#WYcTm_| z+sayeqAb_?TByk0!lWBuVY|%yw(z>-)__0Arr}LiKm?dz3FJ$-#oQ71>c0j#avB+h zC*()STo{qpkn`}J9G9v?Q9Z&0k{XfDyq(pxwu-bi;BOXX76b9Y24aQYU>s>zMuLk4 zGOB#m`I45ew5odrnTCDcc~L)OI`kCEbVIYWj>5RU%!kMt(g5ctu@!{Hy>j4|#|MoV)A!(-_>H z9I=`QhIDeL%pO%v?j9rLF7)m3^1F3@Pbygl(|bN}{)t7EAy9-~b%=86Aq?RV5Z1!Q wy`rHOXDqOKcqRY;>l=>eItPZ6$cS=k_#3^&VBGM&UYU7+`FgF zTR%T%jT`m(JQn#}x%f_qA0COrT<{pDb3X+r$3}mf-ECpzIO@;elNoZdyg^4x7W4CL zmd|t80{L?=cgV$*L3_({tb!Hr`OLxRhU~0RDsy?dT*Zg1tZ2~w2^En~OCD3XU-F53 z4!t2;nq+0fLYX7qZJB=A5>_I)1*X1uJy&EOdtQ1<`rXP4#-;p|nV?{BR0Q!#*qA$8{|lWEhuQE>jD~Hl2bZ zL*0D924gtVR+03G@_Z~oafnyQp2W$v2visy!BSi5kCKVnBjIkYS*4ksE!LCfHjc1j zXu&a715eP;3+GG{ZIg|N3l!oI;f_vST*6Mi4(g4s_}}1+N$_IFN@z2zonen`CnC~R zuZ&V47JNwtD>gw?)Y-|+Bs2)g^;3leJS!@_DO87O5s&|ff_Yd<;4VO@;lA6iAal^8eg?(5dWm;> zS7W$S&x5;oT3-P(@s3`z>>Co#q|pR=d&1o^+#I8@P;)?VlR9!z4c~SV?Cs?&U`|pb zVS8UkTB7s}BsKSU>%koh107rsXr{f*xYJkUfV)P*>nE&oMj!5a5ytWMuCk<`DIv{4 zamCK+F6Qm7_x&Q7fsCh#u&Ox)9vW}&USo5OlGGut~#L{ry?y3<_jO?1T!*Y9uI@pe({)_kXszjMn!EN(qh;{4OEt z2t|5=x-c)<6JpIoGUyK zS*6n#i*fbvD)8co;VlrviQ!D|aw&}3w0=#zWMscN3NVQejy1~5R(U)Z>ahLzm&ycn z)j+@q_7be2a^|RqXo&>XSdHAdi9B9BgO#utA7E-$kccfL*hoPC;YruBt{&DG;g#Yo bWB!R7_PE_HC^)p~v4y^WRvR-;&a(Xr-g?V) diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/table.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/table.cpython-312.pyc index 790218adf4657eb5c8d929f5d48d99d65f7eb4eb..aeafb1abc5a0b84a75e91390f2f9726f1a7ebc87 100644 GIT binary patch delta 682 zcmX}mOGs2<6u|Lw?)B<8dapCrnYrVPGmbgxsHtPVlWa<~MG_iRSh;%x0JZMLSW={=gU~gi3i6v7^4UA6&W|^ z{Ee_}s#Pgj*9|j0DVtfA9u`V!A=1I&HEmW-p~&F0f$lRSma|A?a@zS+zII7uab<%m z-)x)PBUCO8G*A4*{NUW6r3OU~uN;u;H|yrAgp*4Ly-4J;T;MMdQ*NdQat&dyyx??; zJeChUKH+EOvjVIjxV)l(6#{pjC}iyb-7Sh(VQ}P$Vpa*b1Ll$BkQInpt{PFwy9gKs z=D6i46J?y`|FSRD72G@jA6If#fhTAVS?-9a=8S?jl+3h@a#6#%3%sSGmQ@G7GEvWJ z;I}ohn!v7YHM3&$5yqiMqf z$(0?8*hROSG{h!)*gT8alk7`8#$JlHv^(%PjqH6b;~X97Xhpn9clO66wCH80B;zM~ z)qN4&%Ls7lboyF<2R|o3IOycTkQ41R*?Y{6-O2S6AMp^q8FV1F(wCtQJC4!Lv#Nwc z)IR(i)oA=1$ckpUB2&8Qr1JA^h!5!8=+z8-M9zs7CHS!6E&<_ z{Akr(5(;Dz$9GCp3I()TSnKFmS2u NJMa{H2=7)&e*n!M-`oHI diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/terminal_theme.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/terminal_theme.cpython-312.pyc index d4ba984df617cbc1d336036119f479ce7dcdacae..c7c4de05fff4d2ac31cd655a3572d316ad7474c0 100644 GIT binary patch delta 20 acmeB>>X70-&CAQh00fVF=WXQv%L4#6+y)W= delta 20 acmeB>>X70-&CAQh00bv@&)UfSmj?hiCI%t^ diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/text.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/text.cpython-312.pyc index 0d1f114f2a3c82980aa352bd41092afc54bd9cae..99323b49a4c18b3788c089fb20bf2f4fab9dc033 100644 GIT binary patch delta 11353 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
    VmFR5#WUp8wg zueY`G?u(HpmcjI=2!^R-|G-lZXaRu9@5IkgJ(>PO4%`-Jy-?HH2unFFbTY0O+XLSc zKhNnn!0jx?yAYScGmB_k{N-AHqeVxJsHxl6Akon{Z5nhq(`5tfgbpax<%f#^MSqN# zMK3eFmBY6X1`^)o)Wfpc0Ruds%)OoG#>n~P>?|kK7jSkn{M<^S{_3A*CL1| zC@jZ7kwbB^0_Bn42>Jck<)QxO!|eT^oh3=(V`o&$aQ&dT%hAWdVCH zyy@2kit4|k99TV5ZnC-&E{4_`(bcS|u3J>SsJ2p0t8uUj1u+DQ=SDHd3@!Q@d;7N@ z@+q70yHClwaN!#tsyeX@lDQwoc?xLO(OyJxH8>&e0&9>8t7-6rkio+}(3J`(5g zZ*BI%Q*CUsJl1e`LV@7N8}GKQeo+>Yza-;<(A&97y@u$+$Uad%peJw*%-ekVh|z_W zu@ByZ;ddE++l?5aJ?MrJ9lVRlZMvIX{zJNfpBS5;gxJ6J*1{yN3BuLpTt*in?IHwK2o?i?y3iG9@&^Mh zmu!p)IFgCLj9>`@9u|#=b@Eid5z$QuCL?G-P>w*0fC7NuF*j|NJVDxmJ=+nqBDfdF zw9Vj#@FPH*TopZteFhI)zyt8&-w3KtL(-!NoS z*uxKqpE*Ce-(ufS5WIz80Kt0*t^$Z8ERcfB@o{;cyNSC#y@q2v6$p5y_)tf=XQD^Y z4F2A0L)4Ch*@zuR3{66IYwp5W8dI!9d7(#n$%hw2%4)OM%)wKO{FBiHq~SJz02Lib)Un2kB_u!m@I^Q29Iei{Vzvyb;Tv9f6Oy}^ z_vUr4?T>d1>aa^MBv=Oxh#3W&1=NFik?tD(DlwNCxbhQqWii71%eIAgUK~^TREdw1gD19TEGAVzm{Xr$>qqhh5s? zm2}wD$5t|6+la%tJ(+_hY?*Q0c*H=WltD`|`z(?&3fr-wzD|~3!>_@y;fwE%A*qGxf+Gu0EKuw)!TR^aB%COfcPo(HU9ni9c=&Q?A4{}^_& zU7g!`3GK;&APYe@f*b@qqtzf*fZzl$rfLMW(2VfAR$Uu7^iQ#m2MBJJ3vtxe>}@V} z!QZ=zep*Vsp2kv--xu&h0OlbKy)2@lElpCSNZkx~!Qf2>{*87z1Y;PVNiP5`{4WH4 z$R7EiYwCb7?n+X6@ABTtBa=@q>d%>U-ae^6>9+Gi!gWmrA-1lm*9H8(UaJTtLUa0c O0lx=#7(Nuv#UpZ6qf~ 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 K9CqVY-~RwglB9D0 diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/theme.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/theme.cpython-312.pyc index d63c718a2ac302a9dfc93baf4467b5fbc563584b..fddf14fa38ecfb2c027bc1f8ef78a9f74f53103a 100644 GIT binary patch delta 20 acmdmCxWkb9G%qg~0}wp!owt#Dtpor;qy}67 delta 20 acmdmCxWkb9G%qg~0}!0tJ!>QPS_uF_?gnfC diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/themes.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/themes.cpython-312.pyc index c4a1eae5410568f68400684c4c105988112b340c..55a34e0bdcc01f4cb1ab944f4e79d33e625e62bb 100644 GIT binary patch delta 20 acmZ3-w2q1UG%qg~0}wp!owt!&nGpauVFgJ5 delta 20 acmZ3-w2q1UG%qg~0}!0tJ!>PkG9v&us|8sA diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/traceback.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/traceback.cpython-312.pyc index 378813b5e70d468597fe2a2bad61e983aaeec063..15a910e7d6be68f6459f12076abbfe6b9bab0b90 100644 GIT binary patch delta 177 zcmdn+jd8;_M&8rByj%=G@VIwg+QN;zS27v)%}AbBLj<6Q2;q4#`}?}X!3;O35+)outNRC6Mg|tCq5z;y04Y^CtN;K2 diff --git a/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/tree.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/rich/__pycache__/tree.cpython-312.pyc index 487c3f19c264ed0ff49a97d4c2a2f666d03826cb..a77cb1d0703c54f6103df70b0804d4f9cf66c96e 100644 GIT binary patch delta 130 zcmZ1+xj2&dG%qg~0}wp!otJigBkxvm#@Nk=#SIx5+ctldn8U=#wt15DCpN|vn_HE- zm=xm}S*34?D|}!EGqkNCj0c?JpIJd79~?FtsBUJJC}m>Q?Xda60HQw>urjdlbW~kt Wmb|<9x7IvHu53mI7O5gtprruYm?!A~ delta 130 zcmZ1+xj2&dG%qg~0}!0tJuB_vM&7OBjB%R}iyJaBwr~C_F^7qfWAh~GPi%}UH@7Nv zF)79~vP$0&SNOmTW@uYO7!NqbKeK{FJ~(YQP~FTbQO3lm+hOyC0YrZ&Vr5|A>8QHQ WEctZvZ>@QZT)B)4EK)_PKuZDW0Vosz diff --git a/venv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py b/venv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py index 36286df..608ae3a 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/_export_format.py b/venv/Lib/site-packages/pip/_vendor/rich/_export_format.py index 094d2dc..e7527e5 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/_export_format.py +++ b/venv/Lib/site-packages/pip/_vendor/rich/_export_format.py @@ -1,5 +1,6 @@ CONSOLE_HTML_FORMAT = """\ + - -
    {code}
    +
    {code}
    """ diff --git a/venv/Lib/site-packages/pip/_vendor/rich/_ratio.py b/venv/Lib/site-packages/pip/_vendor/rich/_ratio.py index e8a3a67..95267b0 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/_ratio.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/_windows.py b/venv/Lib/site-packages/pip/_vendor/rich/_windows.py index 10fc0d7..7520a9f 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/_windows.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/_wrap.py b/venv/Lib/site-packages/pip/_vendor/rich/_wrap.py index c45f193..2e94ff6 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/_wrap.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/align.py b/venv/Lib/site-packages/pip/_vendor/rich/align.py index c310b66..f7b734f 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/align.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/bar.py b/venv/Lib/site-packages/pip/_vendor/rich/bar.py index ed86a55..022284b 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/bar.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/box.py b/venv/Lib/site-packages/pip/_vendor/rich/box.py index 97d2a94..0511a9e 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/box.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/cells.py b/venv/Lib/site-packages/pip/_vendor/rich/cells.py index 9354f9e..f85f928 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/cells.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/color.py b/venv/Lib/site-packages/pip/_vendor/rich/color.py index dfe4559..4270a27 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/color.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/console.py b/venv/Lib/site-packages/pip/_vendor/rich/console.py index e559cbb..a11c7c1 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/console.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/containers.py b/venv/Lib/site-packages/pip/_vendor/rich/containers.py index e29cf36..901ff8b 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/containers.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/highlighter.py b/venv/Lib/site-packages/pip/_vendor/rich/highlighter.py index c264679..27714b2 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/highlighter.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/json.py b/venv/Lib/site-packages/pip/_vendor/rich/json.py index ea94493..4087c79 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/json.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/layout.py b/venv/Lib/site-packages/pip/_vendor/rich/layout.py index 849356e..a6f1a31 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/layout.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/live.py b/venv/Lib/site-packages/pip/_vendor/rich/live.py index 3ebbbc4..f0529a7 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/live.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/live_render.py b/venv/Lib/site-packages/pip/_vendor/rich/live_render.py index b90fbf7..e20745d 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/live_render.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/markup.py b/venv/Lib/site-packages/pip/_vendor/rich/markup.py index fd80d8c..f617187 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/markup.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/panel.py b/venv/Lib/site-packages/pip/_vendor/rich/panel.py index d522d80..95f4c84 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/panel.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/pretty.py b/venv/Lib/site-packages/pip/_vendor/rich/pretty.py index 2bd9eb0..9b9e3ba 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/pretty.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/progress.py b/venv/Lib/site-packages/pip/_vendor/rich/progress.py index 8b0a315..2420c24 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/progress.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/progress_bar.py b/venv/Lib/site-packages/pip/_vendor/rich/progress_bar.py index 67361df..a2bf326 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/progress_bar.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/prompt.py b/venv/Lib/site-packages/pip/_vendor/rich/prompt.py index 2bd0a77..75ff048 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/prompt.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/repr.py b/venv/Lib/site-packages/pip/_vendor/rich/repr.py index f284bca..10efc42 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/repr.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/segment.py b/venv/Lib/site-packages/pip/_vendor/rich/segment.py index e125798..93edbbd 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/segment.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/status.py b/venv/Lib/site-packages/pip/_vendor/rich/status.py index 09eff40..6574483 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/status.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/syntax.py b/venv/Lib/site-packages/pip/_vendor/rich/syntax.py index 5703376..c26fd87 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/syntax.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/table.py b/venv/Lib/site-packages/pip/_vendor/rich/table.py index 17409f2..43c718e 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/table.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/text.py b/venv/Lib/site-packages/pip/_vendor/rich/text.py index 998cb87..209aa94 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/text.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/traceback.py b/venv/Lib/site-packages/pip/_vendor/rich/traceback.py index c4ffe1f..f223ad4 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/traceback.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/rich/tree.py b/venv/Lib/site-packages/pip/_vendor/rich/tree.py index afe8da1..64bc75d 100644 --- a/venv/Lib/site-packages/pip/_vendor/rich/tree.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/six.py b/venv/Lib/site-packages/pip/_vendor/six.py deleted file mode 100644 index 4e15675..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/tenacity/__init__.py b/venv/Lib/site-packages/pip/_vendor/tenacity/__init__.py index 4f1603a..c1b0310 100644 --- a/venv/Lib/site-packages/pip/_vendor/tenacity/__init__.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-312.pyc index e6db93aff08d55e9c668143a0c452bf9bd727941..dbf7e5141ff0e0bf7718b055ddb562361457247d 100644 GIT binary patch delta 200 zcmX?fnQ`(JM&8rByj%=G@VIwgn%YEONydbY>gB8~sjOK$CO_m6mS@e{1(HSuDU6ap z0T7riK*UfyW3x$`A`_Ee@Z|6ed&$7{ iQ7fZ%Fz)Bx$$h}(qJ`&0U9SsbUKhE&H_y#bWds1EnK^s_ delta 132 zcmbPyh4Ij3M&8rByj%=GaB}yoG~S84l8ibV)yr9#QWz&+VV%t$n-ZPMnzd(g8QW+1 z_}ql31V)Bb>ms%khLoh7#N4E)Bu0jGhLq$*j8Vy(JJQPdLaNnhz3*u diff --git a/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-312.pyc index 72f94798350755aa24d62e8410efb54904af51ee..e3785a1cb404bfd444fcdbcef5451ff64c79dc74 100644 GIT binary patch delta 20 acmew__+OCwG%qg~0}wp!owt$u3kLv5EC%5K delta 20 acmew__+OCwG%qg~0}!0tJ!>QP7Y+bOb_VeP diff --git a/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-312.pyc index 5377705937a799f50d081fa18332339f4a2cd5c0..7b0d879795a4073fd61b65680007aa6ebeb8d59b 100644 GIT binary patch delta 20 acmX@ZbB2feG%qg~0}wp!owt$OkqrPoeg(V$ delta 20 acmX@ZbB2feG%qg~0}!0tJ!>PkBO3rd$OX&* diff --git a/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before.cpython-312.pyc index d4939bf129edd03b5125503bc2fb50c9818f5260..ffbda37945c5447c3d7f479700e1c3c3f3f59fea 100644 GIT binary patch delta 20 acmZ3(y@s3nG%qg~0}wp!owt#DAu9knSq0eu delta 20 acmZ3(y@s3nG%qg~0}!0tJ!>QPLRJ7eqXp>z diff --git a/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before_sleep.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before_sleep.cpython-312.pyc index b1ad3534f7f6b90681c3b93cb20efaba3d7f9266..1b858c1db090970eab4bcaf417a8fcafeefa1ea9 100644 GIT binary patch delta 20 acmew)_(_oaG%qg~0}wp!owt$uIR^knBnG+w delta 20 acmew)_(_oaG%qg~0}!0tJ!>QPa}EGTZU)K# diff --git a/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-312.pyc index 250fbaab60191df32300f8423ec85a75130458a0..eadb3c521ab32cac6581a4a050b94e7765c3074d 100644 GIT binary patch delta 20 acmeyt^@EH1G%qg~0}wp!owt!YmlXg-6$U#1 delta 20 acmeyt^@EH1G%qg~0}!0tJ!>O(E-L^QPCUXEwjRzJ0 diff --git a/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/stop.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/stop.cpython-312.pyc index 85540eb8bdc33775a7bae4747e9ddcbc3c2fe3ae..db35b4c080fe94af034361a7f8b207c64ba1847b 100644 GIT binary patch delta 20 acmdm@y+xb*G%qg~0}wp!owt#Dr6>SEDF#6R delta 20 acmdm@y+xb*G%qg~0}!0tJ!>QPN>Knna|TfW diff --git a/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-312.pyc index bef6924dbc7479dbd836e8701ad852d371582b00..5759b78768d9bd5e8d671d5b855fbfaad5369390 100644 GIT binary patch delta 20 acmeAZ=@a2T&CAQh00fVF=WXO><^ljU@&y(E delta 20 acmeAZ=@a2T&CAQh00bv@&)Ue%%mn~8JOw5I diff --git a/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-312.pyc index 5904d71491db2e5d4a44437e3400c27a3e46c0df..d5a2b07dcad2f20f35158d6957bae616ac7984f7 100644 GIT binary patch delta 20 acmeyE@G*h=G%qg~0}wp!owt!Y%>V#UKnDE) delta 20 acmeyE@G*h=G%qg~0}!0tJ!>O(ngIY%iU$n< diff --git a/venv/Lib/site-packages/pip/_vendor/tomli/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tomli/__pycache__/__init__.cpython-312.pyc index 55107e412e14e4c236de2cd93ff501ea1f1b97b2..74970addf171b31517c17ffbdefc926b93a4aa90 100644 GIT binary patch delta 20 acmeyu^o5E0G%qg~0}wp!owt!YlMw(zQ3e|T delta 20 acmeyu^o5E0G%qg~0}!0tJ!>O(CL;htn+7WY diff --git a/venv/Lib/site-packages/pip/_vendor/tomli/__pycache__/_parser.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tomli/__pycache__/_parser.cpython-312.pyc index 07decb20a81d5c9f61ed3a09aa7debc481bd2d68..61581ee7522993871f1f5c2684d56089ccba0da9 100644 GIT binary patch delta 22 ccmZ2{iE;5IM()$Ryj%=G@VIy0MsA5r09e-tG5`Po delta 22 ccmZ2{iE;5IM()$Ryj%=GaB}yojocEM09hdiLI3~& diff --git a/venv/Lib/site-packages/pip/_vendor/tomli/__pycache__/_re.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/tomli/__pycache__/_re.cpython-312.pyc index 2ac9839b6b7f9bdd06e0664424927bda7632cffd..59e33b1a1d9ce51945dc35f04dbea3aa4a1ae37e 100644 GIT binary patch delta 20 acmdlXw?mHmG%qg~0}wp!owt!&mmdHPkEO(I3oZ+%LVlS diff --git a/venv/Lib/site-packages/pip/_vendor/truststore/__init__.py b/venv/Lib/site-packages/pip/_vendor/truststore/__init__.py index 59930f4..8636814 100644 --- a/venv/Lib/site-packages/pip/_vendor/truststore/__init__.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/truststore/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/truststore/__pycache__/__init__.cpython-312.pyc index 20509a765b935f76ab8471b13b473dbb0298ec2f..b997cea7c38fad1593df928619e1e356b259c06c 100644 GIT binary patch delta 29 jcmcb|a*u`kG%qg~0}wp!owt$Ofsxr#&v3IJqW~iSeM1L$ delta 29 jcmcb|a*u`kG%qg~0}!0tJ!>Pk10%DAp2226Mgc|ueh&wR diff --git a/venv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_api.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_api.cpython-312.pyc index 682ec6853b847dbb5f632db342efa6aef4ec0965..d506a0b1146ac9f600ab5126599b56de05b59f39 100644 GIT binary patch delta 2721 zcmai04NP0t6~6bq=f4Lw2HX4@Yz%h5p(Jts1cXKdGBQP>Q35Hgo61dij|j(@=)Kn@ z5SWuSTa&g6b?>UCnL=5Xrl7P6nQ5)K-s@iJ9WGlpJSEg;1(rTNVplQvfY3IHN z1RAnl$>*MX&Uel|_q#vOBZuQhvE?JPnMct6{L{gX&nn`Ue0(}yUhP8yj_8AWff3k< zq01OFcA0{vE2eqRMbk_qzY zBGv^kqiV^%Z4q^0Z~VUn*|siw(2kMl5OaGC2#JWSGC9b@*u-dREVlrvrLJH;#H^;Z zFK%L?V5|evdBf)$O2^KNq z0;^3Dbc%soK#1@8QaY%$2m{nO^G(!76!K@&N}{qad+aGyhkuTnz)%?i1CxeQuq~qmfR}*3qDOg zcYcn~khhCI!$agu@$2}P4_&jmAU%?~fUH1v=%TT!tMWG`otw%*}va93~Ue>9G zsn#|a?y~%bVrET^O{CHj#jldno*!X_6qma2>!hwU;*tS0!bo1|qysd70Z~#S6;Xo* ze2e_G^b9^sD!rBX9dfZu%yQA_KWUGI$hI;>B+Pg)6 zNy?U=#{=ZUwjBm;XA-A{?`Ny@NI<5Nyk! zj-IB-?!B@^>rU~SrMX)WrBmc;ph#Z}X8Fs+zXQ)OF-GT}a(Z6a`25CUU(&fM&4OXt zWIo<85Izx3nhI{{z;KgAdPkZ8Ep0^l%*R7VLsz-BVf{tRh-FksR@9AiZI_h~zCU(& zf@@R3Q(W7$E<*!04RhmM)98U$dw8wuP8;_{56Q@P#+3o?JHo|a|p`}hVMo{?!%kV0MpLwMeWSPYY^&Z6dI$p zK1Si@^b7QELX((2ChF>A!ZiE0nqr(Ygn5{$xOg20S^Jq5kXY3Y!hOF_iU7>7Cx5KT zwWRn?xicy&yQA%*bdLCHeTETMdJO<1Qk!p;X)PtQPeRHWBGWbYSZGg=BFfTx;3|am z%59(=L9ii{&h<&>`YX=r3FpR34dcdqc%BOU|J1Qoe%flEVUfdqN;$Xl_x8#Yn?~)E zfrezD;k~t!jjhSX)+>RX$;_QMSiq(cYvRATfk0KCu;;7m?c8lbp?uq0|Cx^W;L{Y$HLdo4D`um{Hvs47q&K0H-lF1dDlSto24WFMDl4ie zqtt8w|I*Y<)o=eKYsV$~)7+%hleBuyc_)iX*Cb2V{K2|*B5TLEamP2%Y3pBB&v1mR zF3q41y1ML3hyNDJ#swRo^K1VefVW&?yHMY4_k(AA1yDE zSd1P-Ppv$N4zUlSgV@iJ-8KDYZOQjQw)^0?;M%fgy5|!850o;rYi}eF^FB3JQ9;j5 ziieY=XlF#`zyQZ*_LH)TVyLK~+z4c}c6H_qk8-Mp@4u40_Q)3E*^sx*gfa_nAgnWA zHD;z+=x@o{5OU00Z$@KgQ+)wDmXAS7^zV#+ne-xbDdYagZl$AJ>XHUwDA}lum3w6A zC314Z$&4XtJV(WOQeM~KPGug@9;Z-e6ryUVXOs$ceP_x3x>8pP#*|WdJ4h%5<4=+4 z8p^tc%-0Z4Ua5N{_5h3d@$5A-h$`tmJ>m?LtS!mfo<2Ciy3(9Z#}7ANY#wP&BTz31 zm)E_vZ-%Pr97flI=X_MxoHr5G(|k78PucUHYmPS$HNMpRi{_*~kY=fI)8-GnV_Q@m OUMka!4vf+=sPcb*HIOv` delta 2077 zcmah~drVVT7(d^=?d^j;przDOEc6935DDrgf{!56McGUyF0r~)tZKTA1#Q zPZm;nh$A%*H5{Kp)a=cWYYczI$XLh>UzG0yClOZy9;KCGLy8K5&9w4?*{;-JNZhtjXW9^7dC4F>SWj9=hgTr&G77{V6Y zDL9DxGmZFn+Xx&c=mZSoWm!GR$4IXs(j4kUF(p!I@Oai{^(}eaab1~2mYcYb$x7Uc zx6Lu(FYKG(Q*3p-1`T-7VS~@`=MKM3B7_k}bWvUtF(HPStSm8uIugV)xW>63+VF8# z9-PO8F2USNgUt`K6O0RZ+|>`A*yqlKZ*Z?$Fn7$zPB1Rv?CgH%#yvTi-1n5%MS9)g z?j|s*@Ondn$!cqyH!Sxa>dip{I^OA6}E^gb5tX z6U@7)(j!NhVBEp_{6Y8!e~`b&y@&Q=d7z(=P~9NbNzGor&?xxtQJKc69h{$QgT466 zf(&4G7Yy3>KB3(NmBZHx2Fb6kb)FS8`0aUv_JJqlCAi69u`mRs4TK!!$W2LtD7Mke zPU=xtR;+tT5JTkfM0%Yfy^^S6ZQ?k^_(}F*dy&aSw-`+#+`5|PmHw*QkVyNEsuP~) zgS;RPU{6s7S4`ZYyWzH?-Ao57*Nj{3LrVvi4!a}P!Wc^&*Hzj#YIga0d=ZspLQWjF zSj3rP3_&q9;xs$FUEZ4v$Th>p-cKPY#!X9+#hE7? zKWX`>WdiA^QEzhL-i0?9{AP&*zq(k(qgb zm6XcS1%0kDgEL}q9x5MmEsVGp{$P0eQc7j#YGSU*(#Mr)V@g{@X*-}EU3-UR>2DpY) zSCRfI(&CC`r&BhvpuUtc|2Co^*2bA})$-H~GjQYOt1h_Cu8y$;Uze+H%gHQe6QzFv DV9ol) diff --git a/venv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_macos.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_macos.cpython-312.pyc index f50165bafea4a355bd532417843cbb7f3c5612ee..7a83d85c3377cd5d2f248d2b30c8b21273055d11 100644 GIT binary patch delta 1288 zcmZ`(TWl0%6#ma#c4lXtEp2DJz3ipirQK^=mQ87)6&7rYh8hD=z_!{Y&UDQN6}A&Xfz?FK_yBfrZJL;A^K!Y8;wSN&@+qM)(7X|`_Fg2 z^PO}4NoHOghj+%n`MIhpjGjBEW(KZxo^e*f+m}PbJfFw_&hY_A61uTjD1#GtgY%+W zsKYU#0-q2x{9AC+>BBd84aPCe2k?Etk8v@k?$FD6?lZy}Fud7G@_BGn6k!raB`+7w z;FwrRW(7i+7Tx%rsKH4p^7G#8NvlL`G-@*(E{Oq<39a!89<$v8r>zx4iJG3KI-g?5 zhCjm-ohk_NLPQPtIBmaVBct7kzu0z&Dk;-sX@OU*N@&8oRHqnzV?)7yc1jMwS!*p*$c#c zT=pVfum{wKtv7Bx95Yl*+co^rUILHcZ}taZ7E_A5YWA+a7IlXqWM}b^QpN8#_G4Ob zJ030S#AlWN@)Nv!WQ}fkvg5_-)w6%4f@3?GUOmC|nm4(-dQXq;F?wlgd_d5>6GBhl zzr2pPkN9J{-)JPgT8HN)#wc4$*~j&O(QoutQIiyj&6KXAblPCqtE+>HksdVo>?cLG zdKNA_j}wkiP`5KZqSyaVU4u0Yzi?DZ#!(0|W3TzM zDot1QXB;$`w>`%MxYz6pC1r=1N6#bvTdTn@Xyh6fs4 z*cmB5GbdwfM1@v75KH24qyi*-IpQw09ao>O94c9{wc)#wR%plNs8@96S+)ZcAunvj z=4cJ1@Nl$t-C%j%Ih0y4bmGTRw}aO?Y7`(t7rst>RllF~1ni=Qes~Z|V$U~JH5-cC#deS^;>{lDJmoCa17vzm|E$`LelvC!n z$$6;pFs=5MR=23d7qs}LzOS_{OFX6iT268JVapX5Fb{9)1~`r%wT{ydV|&}4id>$C zqn)s@hgU}kr3uc1>`J+oTacy;^O^!`M@50Oblb0O~iwu zYE3>aO85=KY!VvqOHp$~sf`BG0`+Fj;F74p8B5`|Xv3uB0~@wT)=p;=cm+&h!4qbSg=Hz8Djx05kGBV zB6sBgPZR90RO|`rO!JJhh-J(ii^MB5rvaC2ZtD_$hBSLK+i$WiTbfP_nXgi|=RLe< z&dH5wV4W-0HLtLpe)s@;?ON$U^H(t+o}Y&o6&XDD0H=F$oL=)GpYIMlrPtCy-9h7{ zMEB;%z|dA6WVtU#S_hui{j`Y@JUYB2a~vxN7;RYB=wUio%~V(~!Ky)49id$2Tk}dn zhzi*2s1(f$t+I-WqmBwYwR3t@uiNU?n+o`rqgo!Fgb+vjj4vEN+2Drps(OkCyHW0z z0aU|NwF=-d{-|E#A!2+~`!a!)5!1$a7&0z}J|;NWpx~iM3;Q%i;(q)r?%gaqK8aNS%SYsYOyZb4iXMU-P`18=h3QcY2h_xcAC!dLNp8=IM-N#>roeU z;y?9X=)%9FH4VG}V|Eu%@q9kQapM(JuIz5Cjs?v$vTC9NAJt;=oK!?#LO z#*O56P~+p&z^`g>Q;lz^@vDPBtDScRR=W4s4B&Fxr;s-2&PRa#m3-1Z4|CYIYd^k` z2nWj!&}W|QP1P%Z=)&<1? diff --git a/venv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_ssl_constants.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_ssl_constants.cpython-312.pyc index 794def9ac38a44262fe7ee7506fe9223a75c403c..2b2e181e63ca3052793e753845ed49ef684471ef 100644 GIT binary patch delta 20 acmdnbv7dwcG%qg~0}wp!owt$OgarUQPk2@3!`E(Mza diff --git a/venv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_windows.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/truststore/__pycache__/_windows.cpython-312.pyc index 3e5c9332c7904992cf85d2e122d808a1db8fbc62..c97ce6d32fd401a64c1aac01b73aa904bea25f70 100644 GIT binary patch delta 1680 zcma)+`%hbC7{}lDoc8oeOQFyky{rW$g_Ut>b)qDjT$T_bC`-h|bfo8?Fb2!%8LZ?~ zltd*9Q`pO#MlvxmF|)*7s?O^VCXOYVC`2Qb@WYb*0~N_az(n7N_8?i7=$o9+`97ET zdCqfguP3(0O+OYC=n-A_E?nuq*LuUW;F$P7lH^S)sjxhmQ|7-P2?@fsJO>92+3;6tk|+z zX)F~gKH4JR6r<@H6*OTTG??V1VkL(b&#wn+bNgy@&nd-I^gh6%la=HYLaDq+YIv2b zi5e8Y1if|_uNtSbN>0UAs>vF%<#bnQWsR(j?p?MN*vrd{q)yh7$6US^Sr@e`L8)3% zvQ8ON()@B$L7O$GC zSIpHL$VPrT;P1&YMoZV>`atrMdGR2(9eSeTuD2F^$fn6?yT9wq$A|u2!!Uy$xt_UV>gT33LW-d z1(_=V>Lb7u;5;BjxY|?rep;-xF_oW#Ck=1|rU9Q)RI%c3pmT9@t*%0yp>~k`UN?`Y z$!Pse{4=R)7{}MhhYd4FW+C??;4Q!$#ai)+XOFhGMmvx8Jas(U)7#Y=efk;kZ3w>y zco%Z&$jPvqoNpZCZh=`v78)JI7yh>7CZv1`_!{sH;4`uj4sXRybt&eumD&Ad_{za-vF=Q8aps7iSy)QB;bWv z#UKEFMI!unwzW^39^uap3C-eP>0cuW)#JSwhcg!IWzVc9%Yt#Y&^mKs){s?$LEoKH a$2*O)&u2BerWSGfKXtqE9C@SZ?|%R{;$o8k delta 1477 zcmaKqUrbw79LIm>-u}DoEiLqx!uZp!Wo%Fph6RjZlnt0KW~h)1qiIMllQBiTJ!XQp zVtiN@g9*Ia{(=Idwn=mJVzu&OKJ@5@*wzE_R|SOckxXMKP7Y^eq-_B2{u< z%0@jR@jr{({#M*3il_O9;o=`wT2KJ#qDa|w*|f(MfcAog`bCH?Px9}f<>D;L@o-hx zXchBT1@0=@JO_o^Y@nD9Q;BrrY^Dm>KzSaf<%CB^(>A|#Nl2CMw9@1tvWDhJ+t`&Db-XBAMF&8CYb8KcO56s z!w^g#I08@0LvRH9{qr7m?D9^PJzLYseyC~6G}d~EMNTFkWw!@kVcyzp>`HKmxY^Fo zF~2AARFXdaSUfQtPmCBenRN3DuuGw+_6`?&_+XRYaXbfk6|@Rgy}g3$V{O~lNs#Rh zhofDf1g-{}mY)39vHN>h;D%biXkJ%ic^TA-KUSN->s#?euX&<3!N;b;;i((mrmPms zYLTqgnAJjAtrm4C`n$(bT9((KwER~;DxXg&UtewfpXzH#9P)gRz0VC_2FrR?xS)3S zIpvFXiCZoz1hrE}?XK=?kaOzj-qB1Va<`StW!~BqBIGo?(6Gm~%&Qo0AkwU?@uu?> zO2mmwNwifWOPTJbRT7*=^NWa=5HBNU5VMHmY@qo*+xsX_v2=4wa0z9hDyp{;#}F?d zmf2eKVe(7nU`s%%{}3(b5H*N7M24e5Hm;*C_}QDSJFF}G9AZ~mPm?(|cH24fHLHnD zl6TocY$mpKqm5f0=b<^@-~-+JdgJ$Y5A3}sJ}}hZ8{dDwaRQ5;L@cm}+FrGNgpmzw zxUG_D?VtP4qURIDXNdEN57^J`k^XPE%sGaQN9e>8Bgvdr-0BZ 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/venv/Lib/site-packages/pip/_vendor/truststore/_macos.py b/venv/Lib/site-packages/pip/_vendor/truststore/_macos.py index 7dc440b..b234ffe 100644 --- a/venv/Lib/site-packages/pip/_vendor/truststore/_macos.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/truststore/_windows.py b/venv/Lib/site-packages/pip/_vendor/truststore/_windows.py index 3de4960..3d00d46 100644 --- a/venv/Lib/site-packages/pip/_vendor/truststore/_windows.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/typing_extensions.py b/venv/Lib/site-packages/pip/_vendor/typing_extensions.py index 4f93acf..d60315a 100644 --- a/venv/Lib/site-packages/pip/_vendor/typing_extensions.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-312.pyc index 46790e1fcbce55674e7f9674878c57a3a2c39c0b..04191ec4d6a68dc9fa6c68535b5a582af95ce216 100644 GIT binary patch delta 20 acmX>obx?}?G%qg~0}wp!owt$Oj28et#Ra|q delta 20 acmX>obx?}?G%qg~0}!0tJ!>Pk87}}o4+YKu diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-312.pyc index 6132a1dc27c7b616c67d3e55ba0870a55aa89315..9225e81c230b57d4da43750a40304735a89fb84b 100644 GIT binary patch delta 752 zcmZXSO=uHA6vyW!+K)6}G^I(~9Hv?;fwVTZR$>}anx+vVNE;Luby;^O$wIpucej!* zjV)3%ieh2J>ZONLym$~<=t&T~dMSz^#e-t+EiK|f4^Gmg3O;!A@#ek%oB1)X=DsX| z`@PHMK+L{BTFFj@U%U5O+dBcFduSOE#DRo3n*^L)3Q)gqy-o5iBCdl3xK8F>%!4FA zzxgnh+S$QT(j)m7(aVY+GwxU!6@lxWM4=9=t1TPsKE$GS=6h$^u#9p@f>kKN93;>+ zA3`M??LOkC+aAyS9AZ^A^Qi;ZY=TUyw+I$h#UP5&rx%DQXJrxRi69XTXJs-a>G%f8 zsv6763rbE_a@fcdtdW~DL^lqUriqbPC2Xj8d@O@i4X4J=C$J!jswP!yR6H@C9L3Q{ zWFU+uiD<~Gf+MH;hx!jRLXD<(w04y-MN}(=eblJnC5NNXuSjet9*|Zs`LE!5U_>_CHE+;=by^quP)6d#JIq{C2g}!=x&!M{j=jiR>El678=`DcgG!?br0{tC*2gm8#GYdBDAsvYgw=A*NTDmekp`{px wHM$ZTgbn&3cBgSS;62>7(@QUpY{LthjE7;J>hUYhMLPtSuKz$q`Z0d>4^hzRNdN!< delta 239 zcmcc9z_`AK?=&wj7XuKS+&wGJT5BWUXCW~WMh1p9L2~ewfU$CBO{~I=HsS8jEw4=rOewH8TBSFw0Od3vboLj2_xf_ z$=TMM8O^-)A?_MjA*1<3+lc^Hkp~+9 diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-312.pyc index 04f26f1ee3f1ec19df84ad1327bcec075f432524..8d9514085ec540e4735f87763022cbcd11773d5c 100644 GIT binary patch delta 22 ccmZ2IpKy0N&o-= delta 22 ccmZ2IpKS^xk5 diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-312.pyc index 2949d8f46da5310f3e1e96178584306c11d9ae83..1e008a960011331f7f27d41fb9ff9ce111e8e187 100644 GIT binary patch delta 4895 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 UykTCmSvqTuZ%#3uO(uZ<139jyQvd(} delta 4810 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 diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-312.pyc index 0611a1189456bc3b224360354d78bfd68243d892..7982eea3a4a79f53b21fd17ab676eb7587a899ba 100644 GIT binary patch delta 20 acmZ3PxiXXcG%qg~0}wp!owt#Do(TX)NCvwA delta 20 acmZ3PxiXXcG%qg~0}!0tJ!>QPJQDy%k_O8F diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-312.pyc index c056817ef4b60cd13006dedc2f4b056b8216edb3..b35f4b0734636ad171c7db8f41e5b0af5f36b294 100644 GIT binary patch delta 20 acmbOmI5&{{G%qg~0}wp!owt#Dk_G@l{03V9 delta 20 acmbOmI5&{{G%qg~0}!0tJ!>QPBn<#UMh0sD diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-312.pyc index 5b2f8b06ba0e14399164b6b2da1338ea9d82536a..656055e12e3a07f4750d34f00d0ccf179a5b5c7b 100644 GIT binary patch delta 20 acmZ1`zf7L{G%qg~0}wp!owt#DHa`G7Lk0N& delta 20 acmZ1`zf7L{G%qg~0}!0tJ!>QPY<>VdjRpw- diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-312.pyc index 543c7d9cd8e312d303a99f242615cdc90002e1f3..e13a9bfcba507237575032f539b7dba9ef874481 100644 GIT binary patch delta 3497 zcma)8eN0@(5r2E%A8_V4jstUmu`vN-Ab{~lYz&SKCN^L@rU728KF;?RxZ~Z2_r0@$ zoic8f?9A-!%=!bZR+1`}OH%+ZA{h3HG(hEqN!TBmPj*8l3My5BG=g@>PYU#_#Xb~rW?eP z$PH>h-mGqrw}7oJIrOj{j?^-`<%Vt5daD|goBpR|Ic>5mmn2DkObsndax)m)lTZJ* zTiQ&w7Tx|oHfqHyHhCNMQlH>jZPH;$4KGV-C5_y$uZFi>NF&Q(Nv)#W*TijVHH6a6 z|3cE3p#lOF=s<7-l>>?9|U-@ql5-xnB^iw+t z^5=q^iHmUz;+b@s#*IWKtxU5_N`bLK=MAvODv8`JFPMty7qQQs zi?JD9WTU%4EaJvm4n*IDaGkYxNFAC(sWD?H7_P-sBx30R|DGKWv+QqH>Q0%ti{VKW>WrhvQXpd}w?gq6L?P`lG zfnc$bPer4J?`_^;9})!<%YFsDI#~re%p>VXvZjYPFn-gXV;VzSljJ_ve!Qvaykio? z{IavMaI5JKnON_aBWUh9N*4wg%P?3(c=BY; z7G=pM-q{%ndGq$y{YCwGZ{C}1=AGL^&bhoR*$Ni*;kM!oqoc?rAIG_TzO#vRLtHg> zoOP?Sf%Kp};#WOIk3{X667^xCc{^|pk@DIVkUSvF z9wKUK-j??i!IDUMce0ni>D8ed+YCBy@(GbmaLtNzhe@Ci>3)W|tiI&> zj)twcPNIY0{v93|8#NuLGwOl~=fhwLs<#mKG8pi}j%}?CR(HP$V{6y*$n_%;{?LX*Vn$A9*oNjtCCezZ7FDJ*Oi58=Hlr%>*;smpinD3@5_%#HGtzO& zLVTiU_qGvqD%#7FFesa&3%Ugl$IziSk&ZKHs3uxA^M21ge`uxeV&6;g-})Qwg*RRpyjNX&;mHeUFCO_rblbJAYl-Wj9wO_i z6(u{vUpiQC-4s*&*1?VBH-(Q5`Ut?-{X=$g`V?40Rsy@->^+<-78JD<4*F4MofhD} z_?i>**=^9TUvJM_)y?yv!6x!go*B%+ntvJWCjEFrn65N6py^CkE~~~2x{B#m!(v9J zXI4CWbcMZ-em@7|d}3%f`8U5jbl8Qv7Acm5aro=@ATnN z+^E9xmpFV6iAWl|qxcYc1EpVZe5`VdR6SrK?v+iOR+A-H`A?2ilK}tSk;Ns94br*^ zztPdrK~_MI3X&h7#>?J9{)b3@gyhFarjUr@i`XzCXfSyE#B@DQHBC`qx5VlMRQ*mVnyNE#0w;tc0BR!<)2xS>c*6>?5cL+- z8AOkw$m78M%d;<)QF9vI&;HDJkJj4%D)sS+(c8_F4$^z6{egu42lF0yK8%w~dml)G M`E=S&NSpBTA4*9bNB{r; delta 3361 zcma)8eQaA-6@S-u{29CPS3a7gPC}Z-^^%gL$=Y;jQ)rr$CRs|LA8%4#T)&&t&U?0d zpUs-oY5GS8gFm*lSCh6u$A<(`$;6i_LTWdlLa+%<2>zO0VFM=qm^9F|6fqD;oO7R@ ztYt`8^6%Yu&hMUk?z!ij``-O3x$`0k{L1h5O7MH_)(Z>WQ&$6xdZW z)8%i6->@kMan>OK(~-}y0+V4FuVH6VJdc1bv1tIac6N4BIX-sg)T5t1G8=b`McC$i zmPg_VB)ZXQB?W%Z@;}x`VZp!G-+~3p4MEbJL|O)65uoa%5c0Pg_W~`_bklYO{Se0A z!DFG{kBvXsm{X(auE#4C7WLV0m=gv=^DikZY3Shq8{GU|r=u>TYY9MRCpNl3I}(H82*AS($pF{C>CH)*M7eZJy;WEGwy8 zb|JkeHWaskg}Ouoq)K<UR-4uI+p&)Nt7jZFD=?+0Yirn**1$&qQT61JYIyV|u@ zJ%w0RUh)*$cwb-G*It!mI{5iWIN>STU-DF2%&Mp4$#hm3TTixBa%OfRpMR~dHX5&L z3W@3{^AP`8-+r=(|E7Pt1C8*e{&v!bQ|vy~%TM%&$pF6fk&>BtyeaPi?{O~{|qSnGRcePg$spQJ+hqcBNd#kigiFJV7lNqW?ww^3l;kR&Q zAWZyaW8frlS}DhWy|+C!3f%M_Xh5cYeC#u(i_rp0QzK5;bD){#(ZSt`n3a;xg1|c7 z2a*$QSlM=!X9oLX+u+@F8iiz`XoxZ~y=fzz1wl4NS%}{q+_!rY=ZG|Mrwf!V(PhIb zRMEgZ>1>KYa%2n4%SVPjz9zE9snf!_oXVcSx#%7<5IzrJIv_{0?8`U|GODH-O%)WV z(_|r?%d!`cH;PKu+Tedvpao=g4K*ZxLy`;$k@zI}U0=P!Dq6E5jhSNBA}{nb7K7`MHHSN}Ad z1H56MW-_1K|M0vh6j2!p$k{oBECRL@tL2IiFXQVagfAdmK)8w^jsl$(*9gO^u{IFF zQH1|(|D5kIsTr{}5k5DZCDHQh!`IwvXOQtY030#qf$3C4k+Z}2;x<3Zr=~35Se3H2qfhs6^Zh;wyjilYtYM=Atv0HAXQ{8H=I-V-fdR z4Z>qh#ZE_2H;Qlz;Wokngn0xJ$~+%A5^J~aSrD#7XRvKmk5Ez4*>pisUN5g6@e*iR zPmbBi*~fqgArL*+#a>2R!V3|2Vf7HotWrVlN8V0iKKlviw{E4&)=^yKe>vJk-sh3= zBCPqP@c}}@{FRCNIOejI!=o@V-Ie$#?B{6aL*1DFdtx8?7auw{4hAkAJ4@DZg2;S` zlei|ZOItAz=_IZZamxwjFHyU-HB6Z5*T6ceKBADUNQ({OC0(hG%9hA=K7YK4`1s24 zl{HK{xKF+dkLl^@qwITV5%ZjVA2lBK100tTeu!`r0ngaF+k|iE5#$_vfg}whMKw)P z;7r8oP;b(x6-jX}2;amad>95FT#>jjIp`FLALZYf92s~8#G)F&0CM4~5!=HSv3bWJ zr@jh}e8wbe>b&rR5U|qtLNdSEwDPIc#DO!)+;ic;Q>|z*m{>)NEi_e%>FPx zJl(h^LU{u;>^!P{3iL~5Ax$;aFumENPSrv&uTh3qhZ(uAhAT8CYVH*3UHK#{q?4NU zO(eb_McWWz7SS2Ql{TBoKi#_@(Q|51qX*fWpuv+d{sHiwoe=VSsq1YibXTgoD+T^6 n?cugZ?{uGZkdbG4?@9Q)$K3FNaEd&0;GQG~8w)V4N0|Q)Pu1#p diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-312.pyc index c3c350c791ae4e76c706bf3a8503d48a1a5a8a62..bdc098390ccdc068234dffc5bc00d54a197841d9 100644 GIT binary patch delta 20 acmexl@yUYwG%qg~0}wp!owt!YT?PP3v<932 delta 20 acmexl@yUYwG%qg~0}!0tJ!>O(x(onH{syc7 diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-312.pyc index be991b2eda03781af319c1aa89e1d6cb04e725c8..dff749e78e11de8f546d39cd537ccec650a1541e 100644 GIT binary patch delta 22 ccmZ3|$+V=CiTgA!FBbz4Jno&hk$Ywf08b+aKmY&$ delta 22 ccmZ3|$+V=CiTgA!FBbz4oZLNYBlpY}08ecPPyhe` diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/_collections.py b/venv/Lib/site-packages/pip/_vendor/urllib3/_collections.py index da9857e..bceb845 100644 --- a/venv/Lib/site-packages/pip/_vendor/urllib3/_collections.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/urllib3/_version.py b/venv/Lib/site-packages/pip/_vendor/urllib3/_version.py index cad75fb..85e725e 100644 --- a/venv/Lib/site-packages/pip/_vendor/urllib3/_version.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py b/venv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py index 96844d9..5a6adcb 100644 --- a/venv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-312.pyc index 56ee31768cc289604bb8dfc1b0227a872c426b24..5eaef7a18ccc046a2efd1f8747f76e7e40ebf0d2 100644 GIT binary patch delta 19 ZcmdnRxQmhdG%qg~0}wp!oi~wtJpeS)1NOdH^*H1=;`r diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-312.pyc index 65a83be4878d61b03911804331058ba4fe4ec153..c2e4f1eea35ebd10bc3f4e500782039c7f7b4c13 100644 GIT binary patch delta 20 acmZ3(w}y}VG%qg~0}wp!owt!&ksSaz#|2>k delta 20 acmZ3(w}y}VG%qg~0}!0tJ!>PkB0B&&5e0Do diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-312.pyc index 917961b126b49026e17fdc4d3972a5bdfc9536d2..05ff23009dba4c82a3a666a9ed314a281f6d2963 100644 GIT binary patch delta 20 acmZ1wwIGW7G%qg~0}wp!owt!&R2Kk3y#@OK delta 20 acmZ1wwIGW7G%qg~0}!0tJ!>Pks4f6Q2L=lO diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-312.pyc index 1fd356094b6917fe8925684d4887ea60c7e345fa..8f3eeb0065eaf2fc85e9499b49f60349573b842d 100644 GIT binary patch delta 20 acmX@Db6SV{G%qg~0}wp!owt$OK@0#w<^~A> delta 20 acmX@Db6SV{G%qg~0}!0tJ!>PkgBSoqFa{X_ diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-312.pyc index 1f7d6a8bd203ff716d6f0c2825cafd1ac7662ac9..bd6151dd5f12ea0516db7e556fad188a906c5035 100644 GIT binary patch delta 22 ccmeyikMY|+M()$Ryj%=G@VIy0M(*r*0AsQT`2YX_ delta 22 ccmeyikMY|+M()$Ryj%=GaB}yojojJs0Au_J2><{9 diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-312.pyc index aadc1fd402b76049304158a6019d8ef104177e64..79480351430bf8d47c0071c498a16d61217253e8 100644 GIT binary patch delta 473 zcmWlVPe@cz6vp3o@4L?$o8AmFYFZL$3kN1rgGZDL%QCT)oQf%vYI1TMeG@u=nkK9? z7q*!Zy}8Imw9$>V)hEmNtD5)Jt*ef?3kLgD6EEH@0@==aSTD$s7 zV1_=1asof7D{>q7BbR&E@Rt^&yMWX5rmq9gq|1HGVi}5X5pqSzS delta 476 zcmWlVO-Pe*0LJ&cU!&>Lmrc`5g4sc1eHpBvU6!P!CAknk`m$Q-EAQ5N-TcDJ^dKG9 zvVR`hsY|;kLO#$%>Xe6JK`?|G9fTOwIRc?W{d-Q&!vjBfo~<)PREhwpD*5pq`Ql;0@Da+b?WG5drMKl5cdY%D$)!bIiz5Y7mqdT$Z{&=GqA=?_^$^gW;&uOPH?;P z0C0->`J+IDp$jDy9W;Ah0*+XV&Pzz>(k%s(%=K;nk2%!W1<6|JKdC~neEGYMJU`xe zqGOv^h7-VVu{l!44qsc9Ks(=!_5cvo_B!1BV5d~nF_P>90^-HJc^njtP6n-F*;znX z93R_3LsLxU5;=;!kZIsPhZrow>5=yUPkgDe0=F9tjS diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-312.pyc index dca8c97351976c565f0c8bddfe34366a9df99ad1..f21e62747f56aec4e035f856b8974c11b2740ecd 100644 GIT binary patch delta 19 ZcmX@jc$$&>G%qg~0}wp!oi~yD001{f1^oa3 delta 19 ZcmX@jc$$&>G%qg~0}!0tJ!>NO0RT6F1`PlJ diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-312.pyc index d0abd4cdf69ba9464acde1c8815ab99848b7e786..11b1ca8febd1f60b9e66068fff82f7193ae1fd83 100644 GIT binary patch delta 22 ccmZqgU~KPTQPE=vGSUk5k< diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py b/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py index 4a06bc6..722ee4e 100644 --- a/venv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-312.pyc index 32d9bc68f40201e8524144cd9df870f6ff8b9b17..4541ce1e98291c7681063bd810255768387f6d7d 100644 GIT binary patch delta 19 ZcmdnZxSNstG%qg~0}wp!oi~wt0{}Gl1NO1^_iN1>FDu diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-312.pyc index 649842db501a4617f10b1095bd312077c4128e80..f3b1a2d1c2ed4a29b18129dc63a10c9ee5bb935b 100644 GIT binary patch delta 22 ccmcb8i0SqrChpU`yj%=G@VIy0M(%)x0AMT!^Z)<= delta 22 ccmcb8i0SqrChpU`yj%=GaB}yojobkX0bq6r1ONa4 diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-312.pyc index 5bf005d75e657a4c2fe247ee4401aa98e59b0f80..902e9f6e9c8c19f4a6024250b3d475cec0bfe7a4 100644 GIT binary patch delta 19 ZcmX@gc$AU*G%qg~0}wp!oi~wt7XUVC1?vC+ delta 19 ZcmX@gc$AU*G%qg~0}!0tJ!>NOE&w*81^WO1 diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-312.pyc index 0ec50eb9f612467abb4bdd8b379c16b7ae9f4601..6f7fcc35c45831e29436229efcf67ce6ae94857c 100644 GIT binary patch delta 20 acmbQrHO37drqpc?B#0 diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/weakref_finalize.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/weakref_finalize.cpython-312.pyc index 6d2a1e4702dff055b5c3324bb2254577b3682456..612dce379c90170b926cafe8d924cf3ae1827d2b 100644 GIT binary patch delta 20 acmbPkIo*=`G%qg~0}wp!owt#@M+N{rpau;9 delta 20 acmbPkIo*=`G%qg~0}!0tJ!>O(j|>1k>INME diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py b/venv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py index 14b10da..fb51bf7 100644 --- a/venv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-312.pyc index f8f2c4cfc92ccf1cce706f73d47beb86316540a6..b9b34a9eff8feca9d464c87da62704f681d8115b 100644 GIT binary patch delta 20 acmaFI@s5N0G%qg~0}wp!owt!YnFRntJO&s5 delta 20 acmaFI@s5N0G%qg~0}!0tJ!>O(G7A7hh6X4A diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-312.pyc index bcb6f798197ad8bbfabfddfe7642f7a180b08c17..6c8a4f6038a346270a230ff695b3eeae14bcafaa 100644 GIT binary patch delta 20 acmeBB?NH@D&CAQh00fVF=WXP!6#@V_ZUwFY delta 20 acmeBB?NH@D&CAQh00bv@&)UdcD+B;IxCOod diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-312.pyc index 1b4b5de8a9e5aeaf0e0d5fabd683730e27e12460..b85c256d6aec3a039633de62477f8213ec3bbbe0 100644 GIT binary patch delta 20 acmZqSY2o2M&CAQh00fVF=WXQv$qE29Jq6PkAu9ko{{@!- diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-312.pyc index 80178be3273633e31b566704e92a667b80ee7e8a..f2501a989203dc20793585a20e25efa735611ee9 100644 GIT binary patch delta 20 acmX@Da9V-;G%qg~0}wp!owt$OK>z?jFa_%X delta 20 acmX@Da9V-;G%qg~0}!0tJ!>Pkg8%?QdIkFc diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-312.pyc index 33fb56016f4713361dbb608a6f186edd52f4d2de..afdd70b8a27c07e94d7f16075d99a06761411f29 100644 GIT binary patch delta 20 acmZ1|zEGU|G%qg~0}wp!owt#D8aDtsR|VDp delta 20 acmZ1|zEGU|G%qg~0}!0tJ!>QPG;RPop#|mu diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-312.pyc index 8b52df308972d1dc57fcff5863dc3ccfd1fddce8..709bd2312757f1030c246a99364e5aba2d5fc32b 100644 GIT binary patch delta 22 ccmdnGl5y)wM()$Ryj%=G@VIy0M($N109J_yfdBvi delta 22 ccmdnGl5y)wM()$Ryj%=GaB}yojohn309MlnkpKVy diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-312.pyc index f92a201ca539a3435e6d4e08a443a525f99b393f..7b9ab26fcc887797572ffd3c39aa06ed4d606f74 100644 GIT binary patch delta 20 acmexd`ni<*G%qg~0}wp!owt$ug%to)jt92@ delta 20 acmexd`ni<*G%qg~0}!0tJ!>QP3o8Ir*ayb| diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_match_hostname.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_match_hostname.cpython-312.pyc index cb321c9b2465df08a2b1e6e8f8392e0f8279ff7f..031cd5997a83d83d9b9b4d9a99782344391e4390 100644 GIT binary patch delta 20 acmX@CepsFRG%qg~0}wp!owt#DhcEy^?*?Q5 delta 20 acmX@CepsFRG%qg~0}!0tJ!>QP4q*U7IRO(jy3>L4F?7Q diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-312.pyc index 8f47668795421b7ee008ffc6ef2c8338b8b88217..6ddff5d588ca2274247644a2acf7db36b670cbb9 100644 GIT binary patch delta 20 acmZ2py}X+HG%qg~0}wp!owt#Djx7L5i3Z{T delta 20 acmZ2py}X+HG%qg~0}!0tJ!>QP99sZM(+2VY diff --git a/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-312.pyc index 3f444fb429a6e4152cc51e9c010ba6cbe1fe2d7c..5ee4d83a432e10a725a62c4b5c58ddf76935f274 100644 GIT binary patch delta 20 acmZ3kv|Ne%G%qg~0}wp!owt!&Mi2ly*#(3E delta 20 acmZ3kv|Ne%G%qg~0}!0tJ!>Pkj359!BL$QI diff --git a/venv/Lib/site-packages/pip/_vendor/vendor.txt b/venv/Lib/site-packages/pip/_vendor/vendor.txt index 5554c38..e50d946 100644 --- a/venv/Lib/site-packages/pip/_vendor/vendor.txt +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/webencodings/__init__.py b/venv/Lib/site-packages/pip/_vendor/webencodings/__init__.py deleted file mode 100644 index d21d697..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 9f636201a2c216f681d2a5fd655d8057c00668dd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11989 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 diff --git a/venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-312.pyc deleted file mode 100644 index 42448c08883ca91f9fca14d5b350e23898e23abd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2687 zcmcImUu+ab7@ygl`?Gs(vD8XS0}fpRoX8asJ<|XpZ9%j)#v*~{@Up#~UiY}WJ!iL+ z)}Et zzHjFD{hRx)zFtMpzWw^Wq1FIGzln+8VD7a!2gock&;T;9A!YFZR>VloN;!Ez#>gP2 z(Lm4$Kp$dZBY1oZLVT5km;ztO2z`ocihPREm^3D7h>?wmD!B1X_S(V9Y&}qO-P2^ z3XJoP4EXzk_SBh^u9{_D-Le%g;G&D7buP)+R$df(-LScEhD$ip4L4{ocomtL6}VT6Ay&jIP;h0q zwi{$89Vq8+P%ps4V}KsZ%tu463{R08DCpd=-EaybGHvlOH|$4T4SfTg!`BKFqQDAc zQM%Uy?}mN9^R2)Vh0CskYz9A9q{aqPL5=l+$)5QKQ0ux6)pylT;ujzOc-IYWXGz;x z)*ii~?JjA%FQ?1e{&LHKze0hAXa$Kbi0Yefw$KZ0rIu|~MXZFyO7pt&!=>iU)reS8 zQT^(91*r|w+4GN-8#a`c_8UsHq(m=jWhM5bQa?33bE4F+zO3ATL)lbPHeImG%GRok zm2DMSD3Ja;n%rL%=g-%nRjVN~KM!7SjF%hYlLu}R<+a{ddgp}ierek<9{@U!q<{uj z4XA=O({!CQ-;C6sjh~6nJo3h#tEBbs`8A--Guk)giMFnX!frU3%;{!6nH-M|J5Hgq zqr*3K%r3B0Y;;(6M$<8ir@6p71U;kf({vHgrp diff --git a/venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-312.pyc deleted file mode 100644 index 3a5ea1ca2e508f5b03144690dbf60dfb6dc6b6e0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9239 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 diff --git a/venv/Lib/site-packages/pip/_vendor/webencodings/labels.py b/venv/Lib/site-packages/pip/_vendor/webencodings/labels.py deleted file mode 100644 index 29cbf91..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/webencodings/mklabels.py b/venv/Lib/site-packages/pip/_vendor/webencodings/mklabels.py deleted file mode 100644 index 295dc92..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/webencodings/tests.py b/venv/Lib/site-packages/pip/_vendor/webencodings/tests.py deleted file mode 100644 index e12c10d..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/webencodings/x_user_defined.py b/venv/Lib/site-packages/pip/_vendor/webencodings/x_user_defined.py deleted file mode 100644 index d16e326..0000000 --- a/venv/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/venv/Scripts/pip.exe b/venv/Scripts/pip.exe index 99bd657f1c5fd85806231c1484659fb52f1d64cf..58ebf3fc7d60fe00be25d91667a060b241099c83 100644 GIT binary patch delta 29 icmex;j_vn3wuUW?&dZo1^1e-XTgLba%&=b0=l}rNqYY~S delta 29 icmex;j_vn3wuUW?&dZpMnm$i=TgLba%&=b0=l}rLdJRDU diff --git a/venv/Scripts/pip3.12.exe b/venv/Scripts/pip3.12.exe index 99bd657f1c5fd85806231c1484659fb52f1d64cf..58ebf3fc7d60fe00be25d91667a060b241099c83 100644 GIT binary patch delta 29 icmex;j_vn3wuUW?&dZo1^1e-XTgLba%&=b0=l}rNqYY~S delta 29 icmex;j_vn3wuUW?&dZpMnm$i=TgLba%&=b0=l}rLdJRDU diff --git a/venv/Scripts/pip3.exe b/venv/Scripts/pip3.exe index 99bd657f1c5fd85806231c1484659fb52f1d64cf..58ebf3fc7d60fe00be25d91667a060b241099c83 100644 GIT binary patch delta 29 icmex;j_vn3wuUW?&dZo1^1e-XTgLba%&=b0=l}rNqYY~S delta 29 icmex;j_vn3wuUW?&dZpMnm$i=TgLba%&=b0=l}rLdJRDU

;1f4eN4$ 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 XdP%W+S;Jztce8Kj^r$V&&B^&cE(O8n diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-312.pyc deleted file mode 100644 index 54edaa884844c8ecd3884f4c7ffa3dba526da4c7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 76975 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 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-312.pyc deleted file mode 100644 index b441588c7d3744da01d5e7baf34673eea89e498a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 77486 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 M%Ntl%n4g#Tf6}{#5&!@I diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-312.pyc deleted file mode 100644 index 6c1ec5aa51559b2e1a837fde8f6d6c6883273cbe..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 105238 zcmeI52Y?;bb%uAr!464Cj7bQ= zB#wKxDW*4L%o9}-z1fxdK^f z(gL=nY%AH;vTbDB%C?hjFWW)3qiiSH17r_Os&JlymaAnu)8aY@iMq%hEZbG~5ZOaz z50mXCd${ZodUZ$2c9%U$>yMW0A=^{e>_z(-Ua7aZk8G8W>8t(v$sVIM$7=aF?bAQ$ zf!91h%L8RwXrJS?JV(RShZl`^sce$pc)?~fQvqkT6pVYggE;=H5mun8unnPs|lkFyZxa<+~Le{%HDtecn zWl!zdi#B+dd-TzfRq|Y4?a@#67RnPcc6ruv-sPTI?{ZCdy|<%ev)<*_ zUi4=0E;+_7<1%`e?=s_vi-lYcyD&pTs?3%CX z>FC|o&bz!$%nV#^Eg!eh>yLSt>$91GuPAz#TMyK$E1wy-Z{yzO)|hvBrag;YMpX1J z{FuoMJPUFoY+wDR$GpomCv zpfBF5@h-0#s~VS&(Pt6!E?+@5GjJdL&cnvcz%|+NF19K&FjB3W#rUOXkGF$34MRn)}T<(dv!ll3mw$Jpg^wf5;utJvi$&U%-7WxdNa+3_ydG@co_HRfF` zm#J#JYVZ6<<_j4;F{=Np7ZUs8jpzMU7maI^R6E=;0$HF%U6>1F4tte%Qexvd>!RRWZY-h z@owtXIA%y=x6>}(<@=3!m&?(+yk?ADE|-g4u0K$5kj)G@&n~gcedCyc*NIw<>$9=T zHQBt&HF3=DLG1t<^=3Q!w7`q3^yF7RHJ_Fxx z9Pe^#HZyQdGD@aXQF z#xBp5t!msSdY4-VD--W-%wSrLK91f!aJR9`v&PuvtBd1Zey&;Xa%Rs+1W0%X>%)qN=^DfR%CUzOO-n#{Pm*>mIF3;Cmqmt-d zu8H2|a`qk>{oVLIGHl%g@A6ed@A3+bj~TdU%naPKr(UVQ&%oCcM`YZ)uOct2CU|7L zN5=hQ?9%u6jfc(NXW%|D@8Vc^*X}Xkw}bn;pBTH<@-D9vs~XSRcva)pJ*#RwXRKp)`@7s4??7^& z?ux*pWMk~|ok#CtpGLs=n3%?vn$GJ}s;yVpw}2k-JdyXfUv z%IOKNe=qAA-(B_&FR$=U{mZlUl*heV;~8Ua;3tsH4c@<8E~h8BKARhO&J&~#)9AHK z8^;V5ziD0T;=IdGEqa&B?{3tzdiR#&fq<{>#=i?w`#KToW@dmic?4 z^EIy4c8oUs41J}mb<#J!`(N8ws$Km?M?~+;Ua-TsuDyxO@ zT2l*himl?P|=3RQO+&xI|UG9G(e`9v3Yw7)*=-oqi@h*?v zo7m+m>ZIS&s3&-aZ0usqF5cyFd*)s4*|>MPbx%eOd{vEmms_)Wmuq6|ayiB>m&sN0z(8%Y9<(a-Zm3E|<>?=3npKBjjBk5w$SS+De~RtZH17t!mu=?M7tWCuRnm zLEhz=8Xu8yYt+JAj$L7%sqxt5))>23E|VF!N7lPs6JwXl<-E)Fje8ec%T%@K-fP?nyL_GH zyvz0PZ|w34Z&%g0Pxmrajh^1U66TRn33EC2ewabCcgeUW&c@-M+0GiT6qPWRgPLHx zTK0{Rn~oWdl6QGrypO}P#t|9Ux6wN)=Uwg@dp}&xRyD4Pc^BtVX5hMVnStx0cX`b? zX5ezUd3xMG=3OpF?_xQl)p$I{_ps%>%k^2U#{J8Am+P}iSXV0JSMzYp3`aK-yF6dx zd6!$Wcggrl8}}}@%DX(SoOii?Z@kO>vzdWwdf6BsSL&_0(ML9Vm#?tg9bO(8?=x`u zop_geIE~yic6;pNUA~GKyId|8yL=VVyWA%`X5iL1-sRRb?~>jht;SJkFW$cju}kiw z`&n@oB-ixQnqy>-l|4>2&N1aa1GOfO$hc;Z*2LL3TyrAVAT!|HZ~d5eZB2~bp6|%J z^iuRLeVO$xxBlh4%XiyTcLn@CGQO&K7l(VqyEt4Qz021b^Dg&^GkCci@9=W}taoj^ zi+wa^usb;Psr|=04L#nv&(P~#dzY{Aug|;mK{j^jr)=z+cj?O*yH?e_ce$MPF4x4^ zr7!tI-_r6PBtDnuUHd)SPdrTj?Ha%I2HrVr9P{pN{PI(X9;W|ecMazZ;|6-!GB3Sr zSvY2gKKqGx`ObarwfLot-sN(<$4h@lMZx99MH>mrHgJ{jK;- zs`h#B^8NQze0uNF6WQ#*H8DHzn76BJ-2Zr;x14uzhO(6{n|u52^WLQwdWOn|-}^9b zp#QSo<(fDu<1sOIxjuU*hg;z#*sP-9niDkAOLH&Pgxxi_CCd#lGxXa}yi1SlK6cH! zwApb3kBpgt%W+i3<#?}w%h~P^)@a-ieadb-a|FGcW`<+rUFQ0DCx?0b?Z&*^CyvUv zoEh&69G-d`a$1#J&E{`df z8MrmZE|;^JfuBjNYB+=PuI1S{YG5RDP4w<@`@DDgo}+iMT;^T__lSzZyvsFN?{ZCc zz7yAEGXvK|?_yaavN&F#TBB#}CwjO4e&Stv&5w8KiL74Zns+)PW2{Ft%qzvJX1=w2 z%Q+1kkpRHstJ16JWM?iN4}|d z2kxidr6*$EHSf}MjmIvxmdgzMGzMvO7GsxZ^RdfVH4pC^yDj#4@6s=Ot0w57_iD^w zql6yeE@XDhaQr^+U3w~3HH;2JRpU4@&d0IX<(fFB!Mw{g+52RS)N+}D`86=0`WK*v7{U z-1>H72JRER%X9jw#%Q&lSl`mvJ#nA+F5m6mRy7_IpT+jx<#LQ&?$h`^GW-sQdt?@^ zzN)>Y)l>uG_qQ-ETk5y|-Q8#S|Hur?SbjbZdC#gE_l$X$%LApVQJb)wRl@Xl9PeUT z-i;cK|5|=vU6Y#F=i`D;Z;yzKr+GW5(V8JgeVP{1*0B zl$20QgM#v<-(#M|{^5>e%m6WJ>FfQ;v;3{~_j1X5=2`9;=R8`>(wp!X zY&K@O=LyOQ>3m)KGyRFNyMK6=@3&{DU|24b4d|&@!MJyvk;moZbY%1_*9_DeL>`u- zXSp2nESFE@R>W-T({$;ryX5-y2bxccdX7Ay0O}r1r<+r<2V=>DtQBIFxt2`SO zSd3PBIE-oc6VK9Der&L-XX&ZfH#5)jGl_G>xSUnG+$Y|@<*`{UW-)6cSn7r7S&S+0 z^WJ9zzJddlp|bZ7upXaaeACPCE5+~7$+fIrc*b`MuEYdK*azyGx&IT>ebAzLNeL-rWifwCva4wmgN zJ4m)ya*AFj&oDr1`e@CGT0UO(R9al;1ESMpd&~Bd?J4^~*<)q<%APL!A=wYho*_F# zcBt%uvIix@aQ&9F8Y2|M)v_IBo5>y^J6yJlY-`!}vPa7{m+dUuO18Ufn`8v8(Mk3& zT3xA~_+Z(tvLj^=k!>s6P4-ZovPa4uA$z#&DB01;7+h&=G7ffpG9g@PVloLl zIhg`GHJJuGJ(&SJGnoZDJDCGJH<<@JKUn~~FqsQ`W>N!tRx%&9HdzF_I7wjZk|nT9 zlVz~WlNGRMCo991Rwb*!Ym&9F=Op#8>yif8^~nay`eG>}O^FSN3zVpHG@$pD!fMVZWHPg#A*|3iiuMYuK+OZD7Be zw1xdz(k@)->q&d?H2X7Oqs291dQTOodI7BVd;#N5U>ky2GwWj)Gm8 z91Xi#cf-~uJ+WM$^nz_jdc$r=`oL~fe!4m7i{)FAez3PD$H3l}92>6m-Q+m%?MZ*w zOOgSwmnH*YFH`=%A~_z*S0;DBUX|Pldv$Ub>@~^Vu-7K{z+RW!3wwQXAM6du{jfJC z55V4(JP7-}%^TTC{?KAJoRdq?s(?48LIuy-X-!rq-c1$$4j1@_)# zE9`yAHrV@!yf1Z30_7}-cXA{MQoywfaQm=UacSwS5cuJodQrdXv|iyxvqMvXh z<y<+rltVWthi+63y;(W*7Uj@el|yf14%L;ut2}zU^5`YZqo_B`p_eI# zUZEU%rSjWV%4}CFvt6UicC9kob;@klE3@68%yy$P;Z4kMs5i)Ny3+TR-+q8R#r#&p zzszrsYQ%Pj#sGI}3~-mm0C#H)aF50S_i7AqpT+?9YYgxJ#{j4~?O`8M{eM{X{}I-I zU2U_*0FP-5@VLeRPiPGAq{aYGX$-JMV}Pw118mb6;AxEkp3xZKS&adn;}`%n=Wy5; zRR3R8{eOw|UsrlrV}MsQ26$CtfFEiM@FR@@eylOTc8vjkqA|cvH3s;Z#sELp7~mHg z1H8sD0BR2F{|?pvovQz@v;ON!ztkAu4UGYQrMmWO)wSQKuKiYZ?M>CS->I(sUUlsc zs%w8#UHcR38b1M6Hhu!CZ6j3MhOxGx-k`3j-khp>(=ybXHrTs)UCZ6n8-9y@UT^Yx zlh>QQt2Z1qennO1tExI*W7W~```0yk|Awm0H&u1MrKWop<8Ku2Ge{R#omg<+kgUsc%r`yis-FCRM-hvHIys-&Y0vfhu58x%E+1iaS&d?^HFs zOV#jhDT;ek3GY=Uyib+ze&yl^R9PNWReVTQ@nKcPM_3hgrOm30kEt>~uFCj?D&v#N z;!jDFZc#4Zs;ab2itcIEre~DXpH+o=PMQ6A)zcSLPhV6$eTkJ+S9)1B>=mhwS6Nx1 zZ>Tzdq-yYE)wb=b2|rPV`>86!&s67ruKMr`RlCfdiwx!zPA{+(*e?^P-Ppepi5)x@;gpn9s>P+^TwU2RO?v<~&A zt?Etd-P9ZY<%zuBDhJD#zcf9Dj@Q`mM_Aw=u6Pk9}9U z{dVQ{OO)F$Rc^mb`TPpy^DC9luae5STDklhMA+g0~}qKf}h>9n7z!v9>g{THg$uc=CxRD*Y@rtVZ_e4RBh)EwTi zeM7bISE_WsR(1Q0>e_Er(cV-o`<<%T?^VD4pvv_})vG_THnCcN-4Cfq|mOGLc2x^ z?OG|c>!i@GmqNQi_XTg1I=e~g?0Zyay3+Thn0_F|RFqk&|ATL0gTo$Uw|X^M>SHvLnHM&HAcTnWAwWSe2R(l+U*r=_2ww&C20=cJsTmvVYR_wruU9l4jNnslX?rJP=oa(Y$DX@8q9&@t4T z4yrdDcT;aVeWG$x$G)8^D=M~g20_2dZC$1>U%hl?-LOp!b;Fm{)=#f%n7AgXTe-a# zHg7+U20K@5KZ<4mO+T9BX-=g%f#w*R(`kCr45H~xb0keOnxkoY(DbM2PScm>M4FRm zPN6xCW-!eMXwIPdFwKW(2GV?x=2)8MGzZb}54LZwrs+u2m8LUI3z~yz+S9b5=|Izx z<^YPpQl+&lhAyDrjBL_%@=8w(k!F-63ud&6*OO_Ih*DyG%IOV(X6KV zD$N?2wKV6@e2u1_W*tof&DUwx(|m(w1I@WK-=x_{^DUZ9G~cEm+)HyG&HXeF(A-S(Ak8f_-=n#e<{_HfXuePLU7Ck!en9gGO_63Z z&7(Ar(L7G`1kIB)Ptk0l*-EpG=4qN|Xr85cj^=rq7ieCjd5Pv_npbFErTHPvk7#~O zvz_KAG(V;J8O_gWenImZO^Id)%}$!vX?{ub2FEd<8e=q(=@%rL_7H=s2SMkQ;XNor!|GW4<#m^T1xA?i@=Zjw`ezEwa;+KnG zDSoy1wc^){-za{w_^sl%i{B~UT)d@tYw@bJ_Hvi4$zukQ4=D*wg_nR-< zeEH^&ZoXpk$2Na_^Oc+bVe?g+KiRMKwhoJt?AO&b)U2*uRky9pO1#eXwM*-^RdIby z!{@-^EEXV=xO zt*KqNc=__0m30jbb@l7EwW(dXc3JJBx`y*QoV$E=vgX`%{Ra&`X^=VTq?68THGcBg zQ~OWb)_!8`;^CX>m#b@lbl>H5O7nbW6_9XhFI!q7>hYbH(}F>=DTZuW81#7)D;44qap zV{*;pX(L8X+t&Hdw%RdA&mKEz#N^r2Yxr6lIr7l5`?zbKbW$Tn>Y8qAIEJ36nbz1b zf40?*Icnn2;lt-n8#`gb*x`*Fcu2Wj?C9=ra}C{G)7UHRT4oO&``HTqN>sc#cf@H6 zMlWv|vwl(cDfMes)HSSGw_x4+wQK4d>K5Pw+pu85@CHB$V{!e;x)0YMSy@qm|5vPAe^6ybsd;5(<+Bx|N}Yxb zsqE5hON&;eiXoM4TWx96?((6f=3IP1i!HfWYE{v;J=V7tv@vKaXlKw~(7~Xipp(G? zf&&ez1O%-ezhHpDK*8|_g9L*OP7s`EaFXC;gHr^j8hk)-n!yJJryG1o@L_{9 z1Vbt-+P1rVP-$qTa2Svu#BjqAhC4?ZjtW~x8;%J$)^Hq^9&SPKEmB+r^u>Z&Y$YvJ&qgv#_KeUu5 zewLIbllVusu;3rlDi8iV_-#DZWP*QeD+~T{ZSvsHgTILd|M)f*{1e*c!Jh|z6AS){ z?JW2wb;yH15B??={F6Ia@K5QK2Y(*?O)U7Q+CBc#v;*_t&x5~-1^@H|E%VPPNC^vr`l5B??={7ZXU@Gt9~2Y(*?O)U7A_qO0)(KiqN zJouYf@Sok+f`8>PdGP1K-^7A{)iD6dGI%} z;NNtz1^;=c=E0u_e-jJ-^G~(lzu>ey`19azV!?mmX%_q!ot_7O9{f!#_%A-)f`7;v z6)p7*7{kfb<*60qM6i1JZ9O2c+Ln4oJVD z9FTrPIUxOpazOeG<$&}X$^q#&lmpUlCO+*?IQQv%d@fw%M^i&`?;571Bf0s1LFKtJUNxEE7?u=m{AA^hjf&9i@={ayGsiR?drZV3Mc^Yie}!@sG8 z|HAnp{LfsN4}S8&j|+bc4g8Hy;C?vxsaY7p|E!uk`{&u;g@2P6{M6Qj@LyD$hkqXa zO)dNv*M{&<7U$ughksKG|GLE?{Fl__WB+{Y@4~++jQw{ktqbA5Y-#0?%C_lKzHQT| zeBp>z_7Gfa?&6;E1*A{;0@9~^0qIk|fb=O}K>Cy~AbrXgkUr%LNT2crq)+(*(x-d@ z=~KRd^eJCJ`jjsqeaaV*KIIEYpYjEybDaU{Q@()oDPKVPlrJEC$`_D6{wZJJ{;zt6HOu22 zA9Nn?%4vDL^C{0fzYi@9R6OMQo$-K40WA3YWJ@>C@A~ZW{GR9ceEiNVmXF_umN3bY zuGk-@?Bw}9&+izb;GqphbUuF1$M1HJDj&b+`F&`qy|O}nKQg}`xvxw?&c`$PcqSju zlv*kZ@_tjUS2>`~^=jT<&HJnQ{dY?Id_F-wpMY`j*ZBzH&WkU!nKZ?ULTTENWgH%a5!pHRs|BT5QQhOr~ks3hP@7+8DGIv@>Wg=wQ%M(8=Hc!GQ)^2?i-4i4vx&FPv$JWG|d;i05a8a}5#v!uf`Hepa~95YNvFYYg%H ztgzM)&(8`M8zuqk4DtLdx9(hOi05au^K!!#0navE8E}>1>VRtu*9JVtus+~A!-jzC z4L1Zl*KlLNO@`+MJm2twfEOBG6!2ohAe6__3Btn8iH4KH*2#ubY-?$%;k2-Iy5Wqlb*AC0uywZKoPcu;=Y^f;8!iaA(D2N# zbB*CyVQa17qJWDHldyB0;gYa*so}DK%MDkAozFI08E}>1YTJ3|8pE|=>p6z?0oNHe z1YB>pA>g@&8v|}KJTKt+h8G09(D0&w7aI;~VIRuS7M7odh0<`t5dlXUjtV&1a7@6l zhT{T`H=Gb~qT!@~lMSaB?wo2kEo_}`I3wUp!&w1m8_o$h*Kl6I`GyMuE;KwdV2$Bf z0c#Bx1zc>H1gtY$5^$;EvVhACR|GuUaAm+%hN}avFqd zxG~@+!}9{3Z+Jn#3k@#{c(LJ-mi&ARrJ*(s8YZkN4L2MSwvIF$6>zlSn1Evq#|0d3 zI6+udnrJvFY@KX4CE!%UX<_H-hBIvI&Y6a@!p^e|=Y*Z-8qNz_=Nm2vTNfIh8L-Ci ztgv&f;UZymX|Z7vu+DHvz@>)E0xmaP5%6rol>t{7t`4}yaBaYI4C@1~Gi(UB-f)BA z&T|bnhOL_n&kK0I;ROLNG`uL_#fC#LvSm^o+RA=^0}eMF5pbm8sDPsl#{?W}I4Fn0sfN=6PB)wpaHip`fU^zf819^FI4^9SZ@3`fLc=oy))<}@u-0%< zz{Q41z&gVv0hbys3%J~HMZmKSR|Z^VxH{k(!?gj=F{}@`&affidczF?&o$f_aFgMA zhC9zUydZ47(D0&w7aI;~9X?-^F2jWQ{WTmBaHQd=fTIn^2n(gLhT{T`H=Gb~qT!@~ zlMSZ?oN72N;B>jSPcYzVksxMM@Wa}75J++;hSNBn4Y z>3qWr0$yl%k?p+WV#6U2qxk*ZF|-YTe~T5}c8qFM(RIMqszbJR?6RfH;4Rg?wjS1F z>%rZ2G^^+|quCn=wCReyI+r>RZP7awyS-Df+uMs>Kq__tsn`XiVi%B#T|g>!0jbyp zq+%D4id{e|b^)o_1*BpZkcwSEDs}-!YoJN73+QR1&R&Av27Lsn*u`$C*af6w7m$iw zKq__tsn`XiVi%B#T|g>!0jbypq+%D4id}#gyFf2?fnMwaz1RhMu?zHK7wE+<(2HH5 z7rQ_&c7a~(0=?J;da(=iVi)MeF3^izpclJ9FLr@m>;k>m1$way^kNt2#V*i`U7#1c zKreQIUhD$B*adpA3-n?a=*2G3i(Q}>yFf2?fnMwaz1RhMu?zHK7wE+<(2HH57rQ_& zc7a~(0=?J;da(=iVi)MeF3^izpclJ9FLr@m>;k>m1$way^kNt2#V*i`U7#1cKreQI zUhD$B*adpA3-n?a=*2G3i(Q}>yFf2?fnMwaz1RhMu?zHK7wE+<(2HH57rQ_&c7a~( z0=?J;da(=iVi)MeF3^izpclJ9FLr@m>;k>m1$way^kNt2#V*i`U7#1cKreQIUhD$B z*adpA3-n?a=*2G3i(Q}>yTD{gd3cCppOZgq)b7ieO)T4EPyVz;_Pu?sY@TV0~q1)A8cE>Y|PP3%^eD0YD+cB@Mi zyFe4W)g_8upo!h;62&gi#BOzoVi#y)7lSE76T8(Vid}3qv0GiD*ae!{tu9gQ0!{2z zmne3DCU&b!6uUqZyVWI%U7(5G>Jr5+(8O-F#4gapZgq)b7ieO)x*v02-Xkr(iuc3)ue7=SzcJcWd zn%KqXYiME@pRb{b-Rcs>F0N~07oV@8iQQ_6U2HY6i_h1#n%KqXYiME@pRb{bU3|WV zCU)`p8k*R}=WFQ2E-vK7F3^izpclJ9FLr@m>;k>m1$wayG_hMKQS1V}*adpA3-n?a zD6z}IvK=e23#8b^RxfseUhD#gNh;xH6{Hf-#BQNPu?sY@TPRWN0!{2f3>li(EtDvB zvDL(Gp+vC@G_hMKQS1Uu>=sHCyFe4Wg%ZUs(8O+`M6nArv0Ern>;g^f79@6oCUy%Y zid~?I-9m|C7ieO)P@>ocn%FIrD0YD+b_*qnU7(5GLWyD*XkxceqSytR*e#SOc7Y~# z3nhwOpo!f=iDDOMVz*GD*ae!{EtDvBfhKnG`5KzoEtDvBvDL(Gp+vC@G_hMKQS1Uu z>=q<;fhKkfC5m03iQPhpVi#y)7dNY*jeuV40!{4V^R=xecJcWdda;Y0z1Rhs*u~8% z+u4gVi)MeF3`koRf%F3=*2G3#BPe0#dOHNX0H76}x~`>;h7;3rNK-z>8g= z7rQ_&c7a~(0=?J;da(=iVi)MeF3^izpclJ9FLr@m>;k>m1$way^kNt2#V*i`U7#1c zKreQIUhD$B*adpA3-n?a=*2G3i(Q}>yFf2?fnMwaz1RhMu?zHK7wE+<(2HH57rQ_& zc7a~(0=?J;da(=iVi)MeF3^izpclJ9FLr@m>;k>m1$way^kNt2#V*i`U7#1cKreQI zUhD$B*adpA3-n?a=*2G3i(Q}>yFf2?fnMwaz1RhMu?zHK7wE+<(2HH57rQ_&c7a~( z0=?J;da(=iVi)MeF3^izpclJ9FLr@m>;k>m1$way^kNt2#V*i`U7#1cKreQIUhD$B z*adpA3-n?a=*2G3i(Q}>yFf2?fnMwaz1RhMu?zHK7wE+<(2HH57rQ_&c7a~(0=?J; zmhJ4C*u_>ac7a~(0=?J;da(=iVi)MeF3^izpclJ9FLr@m>;k>m1$way^kNt2#V*i` zU7#1cKreQIUhD$B*adpA3-n?a=*2GZud1^PF$58YSM{EEb_)`_ICI&~F2s;s*Na{3 z?8Pq7i(Q}>yFf2?fnMwaz1Rhs*u`Mku4`f!gJnY#yH%x3XV=6oj`d;}=*2G3i(O#Z z&MpSab|DkH5JQGu?BZAxySSMFsRVq_JG&-!ab_=ef&agqU5Fujzh3O(Re7-s^kNri zVz)|S7wE+<(8O+)#4gZ_U7#1cz<1x-HL;6Rd9e#D+u6m<3@9gTE!){Ov5T!HcB^*V z*)_3?oxRuvda(=q3wL&Lv&!C}#4hgi?5?wmn;EvV7rS`PUhD$B*adpA3-n?a=*2G3 zi{0+cGGZ6##V&UCVi)+nb#`;Hn~PnWUYm;kQ`i_V|vD&N_~R^QnL`pz!UcXolkvkUZ{U7+vm0)1x}=sUYW-`NHJg~cv9_vQ`X z*~QE7on7F&p2i$HyEv8a>;ipf7g$#8T4xtqP3%^wvkUZ{U7+vm0)1x}Xq{b%A=8n* zvx}`|#jbUBvDG@eRqE^leP{h9>3-p~`pmlc9`LmZ{o!u&RcCpoWc7bKZ zE;@g9tcl$!b#}4yo`_xR>|*CV5xdse#m>I73-p~`pzrJgePu=xLIXN@vlnkqI2)WF505|y4Ve!UAWzMc7eXLyO-0Ld!^Hu zd!^Hud--Y1fOHx&Af3hxNT)Fa(rL_qbQ&|D@YXZCfOHx&Af3hxNT)Fa(rL_qbQ&`t zoyH7Er!fQ4Y0Q9h8Z#iB#tcZOF$2dK`pz!UcXolkvkUZ{U7+vm0)1x}=sUYWFLr^xvkUZ{U7+vm0)1x} z=sUYW-`NHF&Mwe*c7eXL3-p~`pzrJgeP;ipf7w9{?K;PK~`pz!UcXolkvkUZ{U7#1c zK;PK~`pz!UcXolkvkUZ{U7+vm0)1x}=sUYW-`NHF&Mwe*c7eXL3-p~`pzrJgeP;ipf z7w9{?K;PK~`pz!Ui(R1a>;ipf7w9{?K;PK~`pz!UcXolkvkUZ{U7+vm0)1x}=sUYW z-`NHF&Mwe*c7eXL3-p~`pzrJgeP|z?Ep>=lA`7^Z6E~Y^mT4xuX zKSS&6Vj85Ob#^hBGPKSv22+OC*~K(SL+k9Kb6{wlT}+cRw9YQ3$r)N_7o9&t>+E8% zY-pWbOp`OT&Tc`|nDO>a>|(HNTdlK;X>x|v*~K(DL*LoOu_kuW8M3V=cG3AWG_h;X z>|$pxc7a~(0=?J;`f1ESFLr@m>;k>m1$way^kNt2#V*i`U7#1cKreQIUhD$B*aiB| zF3@*&fxfc~^qpOx@9YA7XBX(FF$2BW1$way^kNt2JG(&N*#-K}F3@*&ffBoTDwmyI zpclJ9FLr^xvkUZ{U7(3wOjC#W1De>yG<8E0ySQ0pXkr&LGYn1aVw$?4iCs)nH}sud zoY}-K9z(FLCU!AR-O$8twWcv+XA`@arfyqJ>|&a_p^05gQ#UlRi_V{+iCuL53{C9f zF$6>F?BX#5Lle7r48hREE*?WLw9YPWW*Ay$7mpzrn%Ko-2!__#t=2SVyanIc1)A8! zV+gjh#4he$a2hkVO6-2LTGN<;CU)`p+Ey=ivDHsw2Ks5tKtGKc=*2G3i(Q}>yFfpU z8R*3>(06u$ei}2-Ph$r9Y0N-BjTz{tF$4WHW}u(O4D{2Ofqoh@&`)Cq`f1ES-`NHF z&Mwe*c7eXL3-p~`pzrJgeP_2`qV?JfqY0QUXuR}PExo0YNd!}Nyrx&|`RO|v$u?tAWE+7@VfK==PQn3q2#V#Nf zyMR>e0#dOHNX0H76}x~`>;h7;3rNK-AQiiSRO|v$u?tAWE+7@VfK==PQn3q2#V#Nf zyMR>e0#dOHNX0H76}td0c7a~(0=?J;da(=iVi)MeF3^izpclJ9FLr@m>;k>m1$way z^kNt2#V*i`U7#1cKreQIUhD$B*adpA3-n?a=*2G3i(Q}>yFf2?fnMwaz1RhMu?zHK z7wE+<(2HH57rQ_&c7a~(0=?J;da(=iVi)MeF3^izpclJ9FLr@m>;k>m1$way^kNt2 z#V*i`U7#1cKreQIUhD$B*adpA3-n?a=*2G3i(Q}>yFf2?fnMwaz1RhMu?zHK7wE+< z(2HH57rQ_&c7a~(0=?J;da(=iVi)MeF3^izpclJ9FLr@m>;k>m1$way^kNt2#V*i` zU7#1cKreQIUhD$B*adpA3-n?a=*2G3i(Q}>yFf2?fnMwaz1RhMu?zHK7wE+<(2HH5 z7rQ_&c7c8xGthT-fqoh@&`)Cqn%K3@F3@*&fxfc~^wXGuei}2-#I8NF3-r^Nfqoh@ z&`)Cq`f1ESKaCmar!fQlG-jZQU3+F1=%+CQ{WNBvpT-O{v1`xl0!{4NGrK@PjTz{t zF#~;P7wD%k1N}5+pov}U>;ipf7w9{?K;PK~da(=iVi)MeF3^izpclJ9FLr@m>;k>m z1$way^kNt2#V*i`U7#1cKreQIUhD$B*ae!{#mx*TMWBgY+{`dEv5T7-h9-7#GsDot zE^cNRn%K2z%s7>aU7N-XG_i}D8Md>DU7N;?ttNJHGsCu;*e&P_s<73>E^cPnRuj8; z=FiZ?u1#ac&L(zk8Z*$uE^cN(DgjOGT4xt%V%MJ81^Uh|(06u$zOxH7v1`xl0)1x} z=sUYW6T8;g1)A8kXLf;kQ`TP3jz z^qpOxiQOuRU7(5GDm}9c^kNt2#V*iKV+NYotui<=pSCU)_i3c?_EaWliv#4c`T*v=BW zoS9+hr!nI#nAok>GrK@9c6&m`cBk0wHh62*;S#$i?<#h?HG8z8YyIJs6&3#nnwc%D diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-312.pyc deleted file mode 100644 index c3097e10343c3c0f6a29c0c3e853d356759aeedf..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 77664 zcmeI52YejIb;bdbAOUs)>`iQ9@1%NT@4a^rY|Em$+9g=a<}9v_ja%y z+i@Jnu^q>;6Gvj=WD}<`iJc?e<&u2gd-J@r)SU>BwET;1Me*bOXLe_2-+lLXc5Z?D zMyF2gi}2sqKKIm)Lyr{~{eWQq_4S1x-@mD-=!qg%1eW~|h-7ab=$UUY)!L^<{(*>bYz6xnww%g+|O)~-GNP&>txYUl2?M8}PblEyaT9eUb{dlRLAjg;}F`gv*P8OXa zty8IpE+g6AD_(71j-y*5(Pgg|UHaI(%la#eE_-{q=+ggvWW;@C^p}b*`?KhBUyClw zp?5j*WOP|GN@6xzj+gW<`%QY6HRfIRK3O6?MS7UZu}XA1OKcfqb#KzUZ6&(g+cE>o z7F`~pRL;6gdQD~qjyJz|*=m^q{fKwzwq7#I-qI^Zgql9mw`B$%(=r3g=3VZa%nWR` z=&~GompojKF+z?pQZyM|j&Q7OW0`?9<7G4xq~4;-V<)|far?~B8kvDHwyY3lhISHN zj-`$CS0b;gMVIG(x!w(N%nHoBj3}e5&W$resYI7!vCP17TRGEqqE{AO z_SS>_NOVcPq*seBYx;<^I!tjQl;wsw-STq-kgTo*@|ds}oFKg$f6}O{1!L*CK4u?eGWo zF2`zDHJYgJ(d9cc*Hw+% zw=B9{gUrCa^JfOO{=U4+_fD=k1CN>Os>b?c-epbbU1kuQk+IG4F6(o7mk~AZa{CG5 zRJ*FNra9harr;mTyWLXnB67*hz}NcnqHA|<7TxkcaCGUJ{F#AHOL~_s%5_y^edt|s zF7L8Fmv>oj-sMp*FS?d}ExHv~H8U_)wnoPBc9-|p#q(XZwEU{Zz6VKv7F|ZcW@PL$ z-+Y(b<+`e|N6Wh`C!l1Iz60?D&z-Wr)k zmuD8Q;*gRnkgQ40$XH`*WGtI^S+;csjt+O8P>U|h;W`74Zr){^tw6Guq<7gDRuQ4& zMD1>Z^%G?VXY*aw*qt!8M|8RN$U9*E;r)cg*}U5$h%S$8E07#ras`sDEx)R9uO1vD zj?+^{-%Cbp-sM>}FS^_^|2hL(^Ldw1v8x)(qh$oiH8R#GqstyGx;zWJS7W`ck?|ga zf4IuPH8Pv?`snhUCBEF>X1pxhN(0NK@_sB6ZFzk8I>qrNCF9E@ zGGBbzX7Ob?>0ZVwc|XA#o0Bo_=3drMkyVj6zTrBKUDe`QL$4sZJaUQbeKpq484X*5 zM9<>hFuELft~E%G!g2%8CmCI~4wf;(FDMTYCk_=2a|7FK4U+pn+jcS(|rRw&=2aHN1;{g6OhW%MBcB{#gUJOh%VAc3oq1 zEc3GdN@fl0%dTsTYx1)n_HLj3ux!y~T*E)+Udz0lCA#b{xqi;G&UIa5eXi>o>yw|X zaTMLfU-2hvJO^7p=P~V*HP$EB&$;&ian3;TW%83XZg1B$9(ky28Gbs!+FaK)9yNdF zWoz=f#+pfT7Rk(udbzIAvCO!+z1!y{(dEd^yBwo^I>BSb`^~#yba}MqtwD0H2Jg_p;$s~XSRKAm8FGP$h($jHKs4Us$KJv=&}#Hsy>8) zjwX4p#(wj!lBst!x;96!e=XYP-9Zvv?qTy?mhFiKmMywGW=m#d+}`fh(2sbRb@?*` zk7jcQzODl#Z&-A>udU;-Z1Y|2W%FH>{Z)-y*u5I#XU~hUJX*5M7|B{TXJEZ~m*wP~ zfi*TGV>y13jPo#NTxNwh^ICKVOLVzM8#!A3RWhE1Wd@cz$r!tcb`{MvBjc7A&v#ju zd>V(xw`ZLgmt1)_j4oqu(Peq4j6Iz1YINC_e@4b}zRR&&bQzyybXjw;cUfomYV0X_uf|rpn_z3Mdo^w|SnfD%ok63^ zv4_zm50~vMx~#G1^w|3td1vH`E{|c+9S2f1Pu4=4*`Mk^6jF4lD6m8z;mh3lw-eqg9`L5+&{%e_G zs6>~eXd|zs&B*u)C1+$jFUt%(!j)zQ_JP+PYBMs9BAIu&O)~FlbU8X?IjBXK<(J;8 zaewnJw=nPWNV&YrdYh5)7`8^nvaRBzw?rZ*K zeRxN~V_5EGIe&IwFUeUMYb-nPl}p~QvDLBzBgzE?t8TU%wQLx6= z8d$dbHH)hKYxfiu-4PO99w!-H)+BQ;do}N}+&u4c)bScGDfyf!Ym(W4ecP;zWy`%B zk!1%)I+-0<6MC0>+TAeA_Sq$mH(IW8xjtQEYyRBJR{Qh^qrtp^&egxRQl@dX=#G@= za=&DBIokXyIXu(mMVI}=(dBvOiZ1JI&dahzmwQ`uS#Qzh@srWz8N7USxxZc6Sk8Y( z!K3E#F6-?{Nc14lHP`B_>|*bZ3Zl!slXG6ySY}}Pa=nXa;5a=ci`cA;{b5W{TR~?{ z{wo_>ExOz*8C}LZj4rn}@3O6V-sP6Ig3e>um5pV)U*judS2n$_+4aq08_&u{OLVzM z(z~q5?_IVw&%506>O3>To(9Q#+OBG>v8$R!7d1K7c)4Bvs~TJJ{)Q&=E^92hEGP3W zY7*Wx4<|Fjm^|L)YoDBz@%6i0?_%G;yX?vCh8Y#}F3U;pvc@t)=v~$)?}k|udYADq z@A7!I*1+vX%X`Q&1Gj8>bkQfGOV@I(AsO4)yJLgs@;J#m3XUsRW?+5NyBxL68Q5AO z@A->Ax#STnGq9X1GqB$BE_=1;vObv^Sd;XwoHNeoTA9Nnqsy&-pZ9CbycT74vsG4FCqTPI`LJ{RUF^50Qh z99?dm>*uQ2qusA@v{&j~&K$x&7Ts|YU7nY%lW|103dvDebUBLrnSom-qs#3t{(OR4 z<+@*Ez0Da|Ht(`*-euY5yX-qxX23Q%@-FwZ%)s(!KOy<^9a|ZJ**LW=hTXZJ`(d8&Cx{OWoZh|AS=(6=vnL(q=J}b^0PJecxBN=pZ=<55zdu&CkD~wG41(& zzV=sRM#i(enlm!?mup7Gu@9pgb7Tg#jTEQ8(pR-f5?vnuQuAG&SIfP7sp!&IHY4LG zF7>H9x4)9;(lu8j@5<|#xRT}a?&QF`9C>oi!1J}d%d$n6TjtLUjOfeF8Mt?HzRQ|i z&yumH5n=`PSoHJ;2d1U)N0<5t)1Ix)d z18b7eMUD3^d$Fq;x3f6|%U8p@IA2`VE}n@Q`{>G8T1n*ENaSqJz;jRD3A4sB17n## zGqANnt|I1LoD*I}d%mA%XmbXZE$=cS{bVdQBV)}#8CP=7!1`onU_arUfn&%OU7p1& z6kYKxM{0KxEVq@oSXSU@a{Xo;j@~{KW;y9w)|hY6r$m-@x$c5_guW8fWL99k`Icq7 zlgJlY^qEF19H=2@0)p1^HvZGrX8%LY8Fi|-&< zXOU%3_R~JBPkNTE$!x%FY!=3{MV6xrpJU*jmJQfuYr3p|B_qq@U21;IZCajZx!2Xa zdtiSSS(YubEa&qq+phK;0exQTDi&k|zP5G+dDOJCze$BWwMzigc(HOZB7jNo^X z#oibFk@-QM$nuPH%?)@?x$-RQb6vq$A4isCS1^`s=EZXIu7Nel-|fb8w3!!2mz*2W z3Hh=C+w87^ds;T&G3*M)di&Ww9_dn%#rBA-t&(3H+p8H_j;3Xi#2;$%W&>_*vo4m$$a~x(%N|>j4dTd# z_hS~}*t6_6y@ItQvWVF4@~p*^|LSMIX=LMU&{EIli!2@7SwC}-D_H8;s})&#)_t-|b~~Uu-7aX2+YR00_Coi${r*U`t`2;_)k7OxBlMs<1l{WnLyx$l z&|@;vEaZY^|)y9>I;t@lT|+uZ}c*WCxb-`x#;!0m)C zaA%;4+=I|9?g(_NyBE66RY9Grf!4W`(0ca}^e%S{dXL)8$chQ8JvhrZ4|3VlpQ`g+mFMc*L$M$tF9C$P<%-ILI#+|$svxVJ*z=H3o{hdT&; zr+XLl-R>EGq-WiG!0&bMgTCK=0Qy1q9P~r(!_beohoK*JAA^3}eFFMP_bKS7-DjW~ zcPF&T)j~h(_CP=9J`epP_XX$|-It($?7r-e^e65s;6HU=h5niQ8uZWI*P-8V--P~! z`xf*s-M68C<-P;`u4@JTYu5()H|~4TzjYIOsqQ)adQ<%XdA z-)<=Mhwewv|8c{hS$8e;j2jMp$c=zL>PGq_op+nT7u+c5kKKIePuytePu&>k6K*W@ zNtx3s5@fIs1W z3H_9N5&9W775aI1GxQ5?8uUx<7U-AVZP2f{UqQd>W=w-EYm zR|)-&y94??cfud(1@~+4kKAvdKXZ$rKX)^szi_jlzjSk^Ka!})Sz}cYw+)___rAU-o%WCS<&_G)*Ae~p>?aGYVOqve_L0# zuI9gO@V5ki+df+ST)Pjp)89hA0kuaA6`f}9bVbfI*ljHZmIlv8?8+EDJG^rY~2w4WPB z=|$;88A<6!8AKUM=>Qqk@mznFM^Oe)22&==OIb+y9Ayz@FJ&=hA7u$;KV>PUma>fUdCGFiA5m6N zzCc+?Sx;F-sidr?)KS(@4p7!ozDQX|`4Z)iDH|wXrfj5aqHLyYrBqS2QMOa+DLW_) zl%14D$}UO`<zC*d2@?FY3 zl)t9jOZgkheU$qt-=jQ0`CG~v%JY;5DKAhSqMW5XO!+&?Bb2|VyoT~x%J(U+qx=Kq zQOZA39-~B**Ha#+yn*sY%0E%wMEPgR6ODDe@6Kl<(rhhpnQw+my~Z)vXt|b3zQ#I zenR;vWgdw#uZc3RjWVx`GLJ@?$D+*Z zqs-$`<_%HijZx-JQRay#^X4e?WR!U-$~+xq-V$Zr8fD%VW!@fT-VtTq8D-uTW!@cS zo{2KgMw$0SnfFGS_eGiaN0|>qnGZ&p=c3GqqRfY*%txZkN2AQgqRhvm%qODEC!@@# zqRgkG%x9uZCdxELna@U;Dqo${#rl&`> zJKJ$Pt~CwSjg|YW_En!P-CMPP=fSF-)n~i0zOu2lvbNq;*H`YVsyo}+8Y}nl!gRK0 zuMWn8fy+!SJqcG*3_OY-&0*(S6S7ty{4veZ*^m1b$!Fx(yG06yQ;QT zH!c}fa&~B4P2Kp)L)H6TZT)y2$5l6uZ`kHXQdeKQt-8LxHD1EAT~^JTKEHC&^d)mE z7cZSPd(qjxcugzunpR4~%z4vSRIXZDxpc*>*(=VLC)#BD_ZQJIMK7+Ib@QgVHI4HQ zZX2|$zIJzYV{OBxhJ$sr^^Mh=Fpfi;7S(Lqgp;TqS68)t56-_~6UI2fk8y$@;{*nv z5nht>A76L$#nM|*Jh->|_WE*o3jY^1d>82~+q$^8`1?h3vYn?*E3Rnue4CPN(X`^y zw$GQAotczv&0=1j35(gbMP(fT?F34T%GzV2GJ*Em(m|l3LMMUF3S9)cDs&Sl zSEvx^uFylEr$R4*-U@vL`YQAj=&vw9V4%V^0)rF=3k(rBKU83twp=SPTw#R3NQF@X zqxIy*2#nR1aRTENCJ0Pam?SV+VT!<1h3f>aSGYmoMunRMZr0=6B50YntNE97OwFH~zrf7Dw4<7TS?ARJ zsrd`c{L6KXKf9u9YW~#x1!n%0T{ZKsDo@Ryn!muzzq(w_zovU?{?z;hX8yI^)%@#v zrshx0Uts26-&4)Mp?7Nj)cgfz{*ArW{G0lw=1m2Gh)Vc8KQMfr9~eH*4-B8@ z2Zqn{1Hr~VE8;gFnpdL7(UMrY{B#V*m}=MHUHkxY35Hee}QHGeWTU< z`^To{Pt9Lo=C2*A=C2!{nm;vvftmlncr}0h#MJz$`3uba4HMP;jgwRJr{*s(^BNscQZs*Qe%B&0k>VKYG2I|JaS`I=`47%fIP5e}Sy?AHPw}f8ype z^QW1=z%u{Io7McMZcQ_Pn)ze%;{y2V|AhDSt!n;hcchs=&HS@j8-U^C z4Z!g624MJj12BBN0T@2s01O{*0EUk@0K>-{fZ^i}!0_<~U<)2^z}D06Q1j22UYxo= zb$@}me_2aAYX8*!g=YWx_zEYn|AP6c{ZsoFn*A5zE6c?Gix#H#Pwii5_Fs&z=o9-d zSq%H9-%*r)Go#J@3u4iKDZY|Y?7wVjn*G!4UufBXIlh8b?7w1pYX8*!g=YVi_{w3i z|EiU#{ZsoFn*CSfE4Ib{YgVUof3<)5sAu7PEBjh}rM%dG-P$z!r`f;Ivj6(E-u@fb zr}j_nUugE9BNfsg^s=Yj3gHL6 zvNKxo#ZUdNZ{{)bP8h52gmD7n6($HwRG1_%Sz(I6RE6sVu2;B0;6{a;1a8*j+#+zR zw%jIgySCgRFbxTqnFc?E%DgkfBYr54I7{&Yen^Qp$G75#Hi+{);vsh80*`p8m$=9y z9&#iu0j7RW^E=I!`u$b-TO88-E_p8gWo<}$X@18;j?Dh4-zR0$`TO*2I-lXY;s51t z=}Gf@n%}WhfgjqSgob6OeFhM(&j8}}89=-~1BlmW0P*?^AYPvV#OpJFczp&C&u0Mfd(9~`&D3gzX}ZRSApUEDloiX1%~&l z!0>(*7~Zb}L%##V`3x}pEo{IrzXQYH!Uha~3mY)}Eo{K>x3B@j-@*nAe+wHh{4H$2 z@VBr5Tku=hur>30>i5*|$nS7NVfZ~=j|}{t-mhY5D!pF~=QFTGJf8u?^BF)qp8>@4 z89+Rr0mSneKs=uT#Pb@489+Rr0mSneKs=uT#Pb@489+Rr0mSneKs=uT#Pb z>-2s#y6X7NSemxD~76E)+2jMn>+ZFB*z}!ZfrWXrh zZX-BT5px?No-L48%x$D~t|I0(g7XzIw-H>Zh`Ej6Vnxht1eYpeZX>u{5px^Cm5P|# z2(DJd+(vM%BIY)N>lHD#5!|SVxsBjvMa*pkD-|)f5v)?g+(vM_BIY)N)ry$g5HIXh z#N0+&YZP~T+@rYH<37dx9%~irJRVT2_t>D==<%T9A&-X@k9a()c+BH*#S&FSak=6Ok1G{d z3AW0vR$Sv-*D9{_xL$FC$Bl}cJZ@Ip;;~Y3tH&zEZ63EPI*-+gJ3Q`G+$Gp5TcfyJ z@xmU(y?*0;iu*m*D%N>Cpjhv*L9x-}LB&HJ4=Wz=cvSJ2$K#48Jf2iM_Wvwg5?($D=zV^OBI)ST&}pn<4VO< zx^H&1;u_z&R&kxj^@H5>-XKKxL@%?tzwAu;+ibp&iRXpbLxZ(+qClyb5Jgqpb zjlL+;+h~6FI8$+!$JvT=JkC{|=W)K`0*?z77YUYU7b`CDtxFY`DPCBvxWc!tR9xk8 zwc;9&YZcddT(7vn<3`0z9ycp)@mQ(2)nk?7HjmpCoyTg$9fIZAor=3W)+p}wxJPlX z-*=zlevh?^bsi5W)+=6UP;B(A2Ne%_Jgj)c<59(99*--Y@OV=3l*iMG(@Om7tMi~4 z9%m}f66}_ptvE-pJUdr$p5J)B;sW2gP;rrOU97mow=Pv&CfF^zTyceOU8%TA@xp4w zHNJJN;yRD(6*mZ0WH%~q@~xW{w|J~n-0HDPahu2Oiq2!T;tr2H6?b{8QQYlukK$gB z`xN(ktW~V@ctEk zuJO25ah>9Y^@qf;*g59#46}R}-O2w@ns}#3++^*<6Rx9oh?3UfBxXZWJDDL*S zM{%#meTw@%)+*L{JfK+bu|cuX<3Ytk9uF%X5v<4_RXnD6;ke=n-+EH zuim=M5G>EmRGj5;w&EO*a~0=#oUgdR<3hznf)&}tic5U!QpIH+mn*Ii?3P`rxXR;d z#WjB8wTkOJu2m~i2P?A26;F6Psd!2^K7U$q z8g520DLOyBl<(hf7xg_qr?jZ&*cZC>eW6pu^F1d%Uoqr`enVgA)&G2}qRy+^{IpAH P&sN_lDzEQaTvYUb`$d*4 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-312.pyc deleted file mode 100644 index eecafca06efbcddfa1698bbb7baba3a70f1e6751..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 77503 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 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-312.pyc deleted file mode 100644 index edd94729e3b5b9658e947400dd4372b66c32183c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6989 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 YdjCx>SmeS>d!KOb(Y03uKAg?}0TZJ^t^fc4 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-312.pyc deleted file mode 100644 index c5aa28cc151bd896b4e2990546b9076ccd848f6f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1575 zcmZWpO>Y}T7@qNZ{jnc$lhmo<6iS7#fJO~iYEgwsOq&o=H>y*C7E2@BJ9h2P+GcjQ z5R^j?kw_FOPN)(G)GG@AfIm=)ODiE2jgk{wxCNz!swd{1T{|Hjt=@UwXTG2J(f(@N z29oX3FF&-Z8HE0TWZ3i=9R4W51LPtXGvr|hW55ZP@H9tLSYt^~cXWl5Eaj!0w8A>e zcv&Z_aEck8>6i+qndRAzt#F1-csVDhaF(6&CY?!z4L0RXJJSlA?6jA6@)#x1B66)w zBLIC z*ADA#dac6(wamPFtGv8AngHo1H~*KeeL705#fABIFU*f}bNR;7hYO?Bs4jn8J<4va zUAq`%%~)R5jkLZZ({H5O6gk*MPJ(J(S(lTogvzm7g<7@tnT}S_^@nt_TJ0SK6<~l*a?=x#;mkQmj->mCNI$E0j=Goy}PxQ zPNU{`0{YIN-n=8t>emLH!5ooeZlBLJrO#a&%z2Hb-v+Zs$Dbdp^V9N#uL~#qaDMoz zx8Pp4eK%x)EkeEs>ns}KDLGXnD>o`v)s2N6 zYt*ES5hBY{kQ00`-xUsJy`kdSeRTF&Y69mU&%F5@ I$zE;yAN>h;%>V!Z diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-312.pyc deleted file mode 100644 index da512193f6a8f2232750ec1bff4648b67b73f1b4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 38632 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 F_;=;4KhFRF diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-312.pyc deleted file mode 100644 index e80bcb81b7a3eaa36dd62807e39829888a523e33..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2344 zcmaJ>O-vg{6rNfCur|9Gs38W?%4tZ5D>Z3;On?RwAQY_dQ`tmGS5zZoPt1m0+nrt0 zQaMr%NCl};PgSJ$)>}mnz4wx1rCx}P)My0Cp{L%cAWD=|XJ*$wkjQhGdGo%R_ujns zz4=R3gMf`c|M=;CtQ~-V_@+91u5kDZ6P|!9$U*~{P=k=mk|CKM%_C%w;Wd4l&-814 zvG*D+rmV?kKnsYy&j^~WTC0%#hGMFkYPM-@W=IQ}?OMCpp>>#@TBpEUjQ7m278bH> zbeY{+w~zzIDKnx)AdtW`$Obn+wiUx|j}xQTv#!L{e<9n&Anlx7Ns|<|r%9ny{G1e) zF=1L|1}_u*wY!&SZz8pThKAz9D2^uX%ubId6XWw}ZsFF{EbY6Sn7_4fH-#=;j$b;7 z#w6NZyL$~yC#R-vyZ0gu_pUS|%zsY<7DqEv6UnK&&b64Ih7%KWL-9CD-btnEVF>Nu z;0bM{=KQVmw-*vaD0$+1&)oRr}+E41k~FQ)1~7W&*Neug$6Hwf);1S6K<%G z*4+=I#XHH{iPTIDJC)M&IRj6u+t{svlkSX5C9$|Q1BX$z{f;pU0}W<@CS|2fa35yj zhN5{k!8cIzra;U?L#c_$R6{K@yv)@RVgfgKcuoS~NB9KTRRnB#%iu91@wTghz^+od zrh5qOmg)stu1Z;0hQCQway^vZdB$_>4BI_ut=_M%WvT4hW|8s1{MUUcj*dm=zNP_d zYl5*Rb;djHbvD7mO|b4JSfmNo+XU-tf_=~gi#EYNJc*Sd&u=bN2B`M-GI%ghJy&1r z99Rc2@BC-1hg)?E5xjQsEyA6U0Gnus zg>7UOvetXXVdw3ahg zj{mMs+!u=Lq=)(VHgcj>FI4k)g`w6Sn_fQxd$PLK@=T8G%DsD${-4`6)xGGoJ>~50 z@u%jIM>-wck>5WG0!MfC>6c6wWxBotKL~XHEe|}C2X@Yn?%YW2%8N$|Q2TfL$12K= zJ>|@9|4>C47Q*$4GAe}8iZXT_s+}3BD4!lbT(fhtqKvZ`xb4A;!lGlgxyk2B&vWJU zb0vB(5RL>lz27SbAAx}SLvSnjSUF_x1B_XIg6$H?&$BWz0tsdz8bq8gB?BWw6@zrq~;fr?U zdHEGM&*zDHBVT8CSf0lSCmqkAHN>U^4}|dL2!L1i!MPXU-U~3h4+dY!El_#|*z~d; Yzza;X53U~h&%v&p?(;7JTZQHS0mMTnJOBUy diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-312.pyc deleted file mode 100644 index 1bce67744aa210a3722aee2ebfd44c21c0bd2fd1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4482 zcmbUkZA=^4@$K4c)?iozCgvjn6G9Rv7bsu3E0=`ifD1_jG}v4#i)v-O3o-EreY-vd z5`6_rLOQz{V7B*L*dC8_{t zRew^7CZ+>wSe1vvkxS8p>}PdX4mE~#*Y|01(qe)+)hMq&nNZ~`YJsRd!>O1WeQ!>c z`!9uQKvr>@OkqMfP7njb;_&Fe;Dv~(vDw;lo$YIY`~-|9lMo}35Gy$s$P^>7H(ViG z4z~ermpO@%9aF4izhS?hn;a_1k8%a0yyTFba;aQ4#nu5Q%yUiIrIH)=P&wcgAcF^7 zSRhxJkUK#9rFtnUYO1X}sH~=FB7#P=0F90R?O#Fjb7q;S7KJP_Y4R~RfTa^dRLdQR z>af`E=cJ{HXziS+WqE220cw7R3QlH%B^ju^HI^nb)fWEhYjHAUj@)BLU}Kz;nw6=} zi()hpRYj4ae2NR}&WPawq7tX5uwEk-c#0TCSDBY7bt26jF;6`|taDUWWc41a+Z8!B zr8`A25(_JeC@L&W@Lm5pFwi@3HmVM#CVgPo8Cgv#6QE3zs`A8#a^k~@3(?65C92BD zX2X%o;b~c!n2pZ1i$If-v^@f@B*|*KG80v14S#BzougGCd){zE^RU{ieH{XV@?B`Y zx=uFu^2HL3uYJnbZ`2+A&G33%?}Ghi#YXGN_13-x`%`}ZhOcYg*MsQ3EbqEix>)+L zYa1q$Hy`>3K>4OahXctUEJ`wACU;A%K7I=iiMnCHZ=;p)p?k2Y!NvaL1!)kh+laP7}$BDdWYud=tW>??k$kIw}=6{JEbNzcgREs zECQ6NFgO3Oi>;fB*r97(*sENcl~_ZkNE**-|LeSx?F0-0?ZE4_84OZIu!|IXnwy7{ zlt?{EbN6%J$e`Rp&&TSTWe`bg`HZ`cS-^s zZ`(tkzyJl#z|h-#RkV-=ePWTcEX(Y-RVI6&g<060~p;4 zH2MZ#1}SgY5mYNBBlFFziVuEfUi4jxsy;~6N$Lx$J`7<%qv$6TFXkp8g%VINO+Zlxu@7*H@kZwc$Hqp-bVn>XJq;BEC&`nkX^Iz$wqU~} zlVfBwC=L(m4s)jNI2R0HpMQUJd}Kg87u2~x@XT0Hubzf15lK-hC*TWNBPJ*GQV~i9 zvuoxP`;;t8P_v*Gx^rMKIM^RNH*!`Nrjx2DCz7e@OQIB3!+M1wE}58$N^&A1>s5iF z(Xn9vcu))ujSWKQ!hqjlq$7$KQD>sM9W4VHD_8UwOYo?P2&yPp7WoV?GglAv=Y@jI zg_`xkpt1$|?K;T{)wixKURx9VYrG#?=w}4K23?_Njqic>ORsOGcHMhqo76jhz$~6! zIJ2N;8=5{pb@x=Jp<8R{eh^%5=v}yw6&gNGXPP>+rj92GYdE>y(6_{At37v^pB~Tpk1Y)>kKP_#Iiq!h2+P$9(cZF4Eb?BaJwPLOI?T585Y;4V*EeENoGkG$eF3r>RVBoi-UyMHb;a@x> z&v65VGJGqQD;IxRvs$Y)cRV=rkojWp;gHrnuvR6rCJ zw@*_nAUlSknsFb=X4uXbp^o-H>GnJ5ft5tpD?B2IU}Y~ zy!tvf6-$OyYFMf~_qK`1v6v|O8H&lss5DQTRw;)*#pWOq;?R6`gS=!puI6P0%N^X} ziKAkRWw_2ek$)2SY}>2>xH%@N{!R;$>hq-fEyrQ5{?7PH&#Hf|rAyn_y+vT);ofch zYy}yPYhU61Mc`xD$XI{G@75ja+$_A=sj)>j2Drj^o%z(OGNYgoXXEDM-*_1693}+C zNC3G2KQkLis8`Hapb($T74T-}p^&&C2f(NTkH|9U7+TQ%h~cBdFwfWg3G<*%(EyC$ x^FTQY&6bT}n3wMmrtTl)_%qV^H*)M5IrNNlJtNI89Q_Q_zE*kYB|*dx_8)GDq*wp| diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-312.pyc deleted file mode 100644 index 3222b38816b83d6d232e7aab66c4543ef2a1a75b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12256 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 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf1632prober.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf1632prober.cpython-312.pyc deleted file mode 100644 index 8a427ce409e9767ede6c4fa21a7f9a9a5488721b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9966 zcmeHNU2GfKb)F%I6h#e1Qa{$OrID<)#I^qADDlecU9BbAN^Cj1)@}mT#(?4srLibd zo*CIDSG(|oi%5pImWu?I(*jlZNyY++AM&6eFN>f>i}b~_mP=x~MO73*pf(5?D~kkq z>N$5f!yi$yHcf#P=rw)k-h0kH_wStV-g~b8$>VWT5dQHe-w&T^p{W1Bj2Rr6#O_;= zct{D9Ku4%~dWxR6P1$HlunG2veV&jjKn8{>z ztDx?8pl2dAMGMrFO`xajf^CWs>{AY*c9{y(g7XeL<;l~I?vb269))(Wk2S#2v`pQi zrm)K1(i2#4E+Wl|Tn9&ye}5K@MX@JWxxfih zb2fNGJ@V#*ajZDAC@P95WX1Fi zzBOtN{00nMgt@|5g2vQ{Xb$a0P?khh5|wV!xt%IlLV~aQ!&A?poF)X3<5nv3$_GsKq<-~A+OXl4oW44 zjSSaVgD*FR`Xy$5h7#-_V>>RhL|`CSnwPVr5n5Ru&5}=Oo;+H)nOmZ+HJj<|H#^ce z6>v<*IMf{+!()b|3!<@rPj@Jb3!<#McwUN1D$nb#g_t6#fF(MMnxgPQm7k9Zx;LXb zW`T?&)=Ni5Cr8gtj!&G^ojfR@D(cMj#UQXt(Hp^tB=C!BxNmS;EGUTN7Yy_la18VV zM|)V36_uY2M#8)T#uS?Y`TRmql6gS{7*j=oC$bO62ofE#sEF!g08P-quwKgZ#CmyN z!KvbI|Ngy^*RGtC)boqe92omGQH?2AV1{C{DqguEMsHlXAWdI^`4PJof}y$KjHp~$ zkQRD)pb0U#Cj_tyUF#u(9_UAl66NlNxau*20iMhtlkF+L_bZSRBfw4@l;^0%7 zYHlO6eZOBljr5Z#^Xp>oyI0&FvAfU%s<>_a5-5KPwk6o}> z3UiiSfxR-sUM<_o+K!A|V=__#UfByD`6xzyj4Cjy#0V`xMy!&nF{;6+79-qr^Ve2FT3R4TVZ zyLlRcRzlGB9wZ(DZeGj9VkpC4qL56-0SB*H$ZAjvIBdXS9*wdLxiVn2u36}sWyxuU zi8}($iG&NRt_zXGOhqy�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 -# -# 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/venv/Lib/site-packages/pip/_vendor/chardet/big5prober.py b/venv/Lib/site-packages/pip/_vendor/chardet/big5prober.py deleted file mode 100644 index ef09c60..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/chardistribution.py b/venv/Lib/site-packages/pip/_vendor/chardet/chardistribution.py deleted file mode 100644 index 176cb99..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py deleted file mode 100644 index 6def56b..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/charsetprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/charsetprober.py deleted file mode 100644 index a103ca1..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py b/venv/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 3d729e19eed032515855027328b1b318772916ec..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 182 zcmX@j%ge<81SfXSN(0f4K?FMZ%mNgd&QQsq$>_I|p@<2{`wUX^E7Zj*#yzvdqclk& zpeR2pwIshdrns~qzo;ZNrYtqDEXF4@DW*8HBvrQ{F*!RiJ+(NdAhSR}9w?WRU!%p diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-312.pyc deleted file mode 100644 index 6518ab8f966cde5d025fba392d246d4628b4daea..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3999 zcma)9O>7&-6`mz`m*nzCqWmk_ut$dDnu#dKMq{|NVb_f!+kjykmfWVS3~I$4N-HgQ z+1aHO5;W=nDJmldY+ow1L4XuJ^hY}67@$3*rxxf%N(z|Xx~PGmhur8$=^>}SHzY+$ zv4M`joxeA4X5RbedryCl$29`wZ-4rA;g2ywzQ9hqKwp%NRj8JTL9)btR3V+nddV{#TerRp zfJ932qq*EX<1UQla?nlQvQ6yk)`&2W!+pgvZRYy2trwXeDw?)g)GdFvJL8lsBgYwz z=PWj@=PSO-nOEj^UT(PzD;0i0_-*_bK1;*{=QT?$xGJr*dUxa+86mfa2)UzpC@o4& z*_u~s@~qMx@6;U$iGT#|wWGMw{UM3il8p0_9h1=QpbO^3d)Y2?N38|8Qd5lpqI8V3 zTfDa>eL#$0yAN#{+6qd2Kt5DJ66e(q17jo=(mzJbBC2i*3sD_>#Q}BzL>G`eg-t*e z`gjWcMccTfP631k^c*fUSl~z;Z7OiV-KaNH(z#xw!dV$Q4yr_xdJdgt02dhOQaRjQ z<5fy6xeRS11yxT~Jmz+*MJH$IHTdFm>okCF%Ys(~;K5O`UzgtI8aQRQq8Gs?L+O}6 z6J22NQgIz^0&45XF5E+?!K=Q!z%Aiz3j!!Q2IDqmKP{W{y2WhIz0h^GmmGsmPEI+F zH909nQxZp-^uuk#RRbAXO@8aK`da6iSECtxw4AwR%S)*|j0z%XPn~nU;>!ib3|}^Y zt9&JIIWEITBZNa7;mHw$Jc=K&xm5OLv@G8PLv9E@t?PgDqmj(SCDXfHo}xFnGs`^3 zop8&@b8KRs+4B=u&8Z33^jNy2=jZfk=1!E%(g}F)z*77~i`-7+EwkMQUk;Zlexiv< z!4x^Cz!B2>arY(o+$EbwNn~K{#GC&JkKDaj@7?niQIx(#`DxGo<=yZ9Y*DUY{f)_ADBEaQgkzPh!bN6oeWvqNu;P^zNniuGHg+2XEhd`|jwIP@>+m=i%&n&)`~k zupWvp&VCl^ulMbJxc4DnKK9YT`oPdye|jx_{*(Dnt@R6IYv;$;dTy z7cq{p#af2yq5nmB5x2~uhj)}|X*IOcVmjco7oQ<)L=0^;y3%6Gm&(PAxRDT&Ek=H+ zWDmsdq?c$P1{f@`+P6)AvOU+SYh=q>fm&d;uQStb0jKAI(}T6(EaG=ZX>%_>;O%Qq z8N0e{hN#<7R(G$oJSUOPD(^sBtcH6XZ1*}fobOPl*KWZmZMQr1>YkOBz1sJa$bBZ0 z%HGtz>KB3=E<;vfLC%qPibYH?@QG4DU%7}>BXSO)U7)QQ%q@Vcb$FJ>cCJRSW+=vG zq|dFzLy!|t6ZpNv@@BzgMk{M+@0G^AngqU$2_ap$2DCB+B<5D!VbuPUlbPF-lhkx+ z*#$kO?E(+MDR5mzkbmG`=gkcEzAJ% zZOJ0-FJLwSR-9uPu}~d{RD%uE;|43}z@?dHa+C4{e9D(zP07AI!>p1o<28K6hKsm< zs3lyDq|>cTrTXd(h_hf}+p27jg0K&`#WoW(GM-0YK2D3p$t!Z99aA=srL?jl&waR>l+n4!#wquBDQG z7<>R(2!yo6#nwx>fnDy$bi>HOtau%M7%?!8ZVLiXeMMxgzB*Md6d30i;(Sf$!6h!o zXX~q`t9xF>S4!wjUxhUwD?(EzV)|;+Jt>(ZANZ=!!bMnceW~E$t48c|Bo<#T>ZZ-l zKr;hBmjd%cbn7FDy^rHZ*W*W@#jbBEazed3+R%s+eJt-=m-p4fJ@xqYr|~_HJc zhnBt1<45a>V7`MCejXFo}=ow(cx3XuSas3g|+IC^kBdT@FC^XQSg zBhTW=2ibesuSi_c7Nt5w;WPKn+|N9PI2;Hj4{V0X-u|WRqwLpFHJ;c^kVxWbY@pto ze0Xx{^rO=sefM|gesk_q33_(5&1EZrU z2>}qw11#9ZzVM4U$W@|*BENchSYJI~()A&lYfFX7V&N|N+E5R>GMLqzKRC(-^* zURx)x{f7+vi<|`GC->KP_tyuHJ&zogXg#{?;am4EG=k86ro|fy)L`61Un7LAFgb9z zfpV};O)Tc$y}c2I-t!UZl%y@bvn(%<{VKBFbEH9_|9fKttH!KE 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/venv/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py b/venv/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py deleted file mode 100644 index 8ed4a87..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/codingstatemachinedict.py b/venv/Lib/site-packages/pip/_vendor/chardet/codingstatemachinedict.py deleted file mode 100644 index 7a3c4c7..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/cp949prober.py b/venv/Lib/site-packages/pip/_vendor/chardet/cp949prober.py deleted file mode 100644 index fa7307e..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/enums.py b/venv/Lib/site-packages/pip/_vendor/chardet/enums.py deleted file mode 100644 index 5e3e198..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/escprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/escprober.py deleted file mode 100644 index fd71383..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/escsm.py b/venv/Lib/site-packages/pip/_vendor/chardet/escsm.py deleted file mode 100644 index 11d4adf..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py deleted file mode 100644 index 39487f4..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py b/venv/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py deleted file mode 100644 index 7dc3b10..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/euckrprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/euckrprober.py deleted file mode 100644 index 1fc5de0..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py b/venv/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py deleted file mode 100644 index 4900ccc..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/euctwprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/euctwprober.py deleted file mode 100644 index a37ab18..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py b/venv/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py deleted file mode 100644 index b32bfc7..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py b/venv/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py deleted file mode 100644 index d423e73..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py deleted file mode 100644 index 785d005..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/jisfreq.py b/venv/Lib/site-packages/pip/_vendor/chardet/jisfreq.py deleted file mode 100644 index 3293576..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/johabfreq.py b/venv/Lib/site-packages/pip/_vendor/chardet/johabfreq.py deleted file mode 100644 index c129699..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/johabprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/johabprober.py deleted file mode 100644 index d7364ba..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/jpcntx.py b/venv/Lib/site-packages/pip/_vendor/chardet/jpcntx.py deleted file mode 100644 index 2f53bdd..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py b/venv/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py deleted file mode 100644 index 9946682..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py b/venv/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py deleted file mode 100644 index cfb8639..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py b/venv/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py deleted file mode 100644 index 56d2975..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py b/venv/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py deleted file mode 100644 index 09a0d32..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py b/venv/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py deleted file mode 100644 index 39a5388..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py b/venv/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py deleted file mode 100644 index 489cad9..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py b/venv/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py deleted file mode 100644 index 291857c..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/latin1prober.py b/venv/Lib/site-packages/pip/_vendor/chardet/latin1prober.py deleted file mode 100644 index 59a01d9..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/macromanprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/macromanprober.py deleted file mode 100644 index 1425d10..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py deleted file mode 100644 index 666307e..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py deleted file mode 100644 index 6cb9cc7..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/mbcssm.py b/venv/Lib/site-packages/pip/_vendor/chardet/mbcssm.py deleted file mode 100644 index 7bbe97e..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/metadata/__init__.py b/venv/Lib/site-packages/pip/_vendor/chardet/metadata/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 6209f7ca169db4ebc555790f15e6db3f954c0677..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 187 zcmX@j%ge<81SfXSN(0f4K?FMZ%mNgd&QQsq$>_I|p@<2{`wUX^E6T+x#yzvdqclk& zpeR2pwIshdrns~qzo;ZNrYtqDEXF4@DW*8HBvrQ{F*!RiJ+(NdAhSR}9w?WRU!^9Yy%giQx zpX5%ev6NYAtYuacWu{h8$kI$9>ov2nvdre9kj+f7He^G|$X-dIl(Qz3ibhnLu8+KC zGpIUED2>php>#qs3TQ^7jA1mHgeDV>Av9xw<}EaC7|nP>GahB3Y?Om0RGQJR(A&dk zCK8&7=pB>|`q02<5_)$S&16C|8T~p=GX?!-7|nZx<~=kO*-Ji0@9BHx{sl*#97pRBK?A? zEV-^H_jvt}scTt*L5#rAOu1JSXgA}j6q!nvr$wGcba@@^6*;=bi&!@;aE#02@>J4J zc%&=59G*)pfj4e;Nu9thtzx(mR#?w@%UO=kr|G3$(G5IUgBMvKRIwZ_RKXgac6s0q z7>R<&vH7W~rByE8;0@Pu2Fv#vBr&b%nwYi~oVSLo7M&m!u>$SmyjxkPke~WLIL~uU zS{lPUT`q^46$DTx*Q{CAxOhRcuk#5muZM9vje1~=qoNN#H^WT}6ke7pGePk+BU4#Y z3N`qLMxrFv!dkO|4q4)NR$Ol3DcP7Iv&r#U`>>f5WUfeWr7EB-H>Z`^Q3`9VFryL8 zma>#q>RVG;Y6+E_rrFm-gTb^WQPi+NG4W7g?^cLz5|DU^NW}QmR2qJTu3CnpJxmQ- zNSA`ctHc_{L!ON_@G9ouX*ej$A)qe4D&JTv)cM%xVqV}97`k|`10$i3o|R`fnJy|> zN6(wRAa5q^s-S&do_CeI*=h9b#CZZ9FUG+(7tc;346&ApKY$h(MKc~kM>_$ZZf_;c z@H94?7if;&6a#k1=#5ghjW7!sq^n2jTC}}=jR6&0o z*ZphS#lO+uuS+?R{dyW*=M^C_-F38w1uuc>41!CQ7b1rJ8cl1%y7p_C` zJi#tbRPc30hP$~~v*1+H>@mb?DRI|n_E>l{d(2dA^l+Ya4C4eT{wq@aoBrW>L$i5vdcNn%W0OaUYAF+ z;VQ!-EeT-EVLdo-43%rwEIjM3cq6Acm6qagIH6ea4hN4#MuE8F)fdYOx2$jpE5&je zw#u!n;N`b~j#$!`TGms$WsR$R3-1!xJRjq%#@VpN=kiT=z#Q^&(=ozezndQ03a7_1 zn$P#uahV{gJ|nhql4_x5iOD_%4ZwPz6#rUvtI^U0*6 zreh`()&8!9sx#k6+Gfg4(oBw5rjLrDk4YtUk>BPLs^GObe}-nN)=afL_8owV!@b6< zln*Oe5Bsf;TU7t+gy?guk8?QkKXiMYkPwUV<5VBQB0e96|HhE`i84=2?SFex*QaMp z|2XNNr~T8k=lma+l(c@+>O7cnaOS}&?Q32n0m=UoBsXPGHJuna)%40V^_3|%*UF6r zJ~+XU%LxglSpmB>JeL)Hi>sx>k!$A0;}|QwqXU3VxhY_!4XQGi81&wKZkHMvWPNEWaZ^l9?OM z%vCbpzdY%3(dC7=8D&&~VlUuwfL*SwxVW^qxHxwNHx(YWREGoFCeaPrY9k$vZ$!pz z=&mJ$ZC)p+h%pD%K!5^)H+T*Mf#e+bKAuU7ro5ANyTN1=@d1xv{V@p>hpRjp(&2_b z0K;FKsTbxo%9< z&73uNo@QOTe*UZ(_);)$j#v&xslDo1^_+TMy`WxHFR7Q+E9zDCntENmq25$)skhZT z>Rt7odS88@K2*O`CDpG!QXi{N)Tin*_51!E{f+%i{X6@c`*-#4?r-UD?QiSf)4#XB zy?PIZ=N<{E#q8T$GO~Yms4y46_kTYhjK{iR1Paglt$&K za!lE+bSpi|api<^QaPoZR?aBB%30-{vR^r`Tu?45mz2xOHRZZ;L%FHkQf@1El)K73 z<-YPD+@U;Fz6&2!{K_NcvGPQDsytJ^5AO&!hMU4W!>7W{;a%a~;g)b~cyG8pyf3^z zeBfW6h?B4yoxtd^@+^D`7TpdXaNsp?vjaFh1#Y*slqI6OlHm+vD|3^$`LK*DfWa_s z?p*QP;r3u_x_-f$L0hgUSHYTLwqQ#X=@%>+w4*J&2P^?Q#CNdplb~`7u>`CjHh=}U z!2&6~8*H#Ht!JH8n%P-jngGXHL*O_=#HCH{4eSdXkgo)e%Qu3p^1Wbpus3)?eiXbV zKMg*U8w2fu{c>BNN8T4~kvoH3!85`0a!>H4d@}e{#JRcB&D4728@Ns}9!9e*V?6Ll zq?r*j1Sd1=N5s=&=1|bg((C}14PN-x5^+-?Uz8>Jg1lSql6PszpLjXmg;>qDg5`h$ z7_%a7pXBrML-~n(`cIEe$<6Xn`9%HLc;{NUk`a9Z&q8_CtSdN{t=7z}JHZq4hj?PP zxC0o5?u71!?uG7$9)uo-z6(hqf9O%@ap+0tY3Nz#`@S80jeR@&n);gicJ=MI@wY9SI!`9Se1ZxWHEWC4t=~`* zJW;waczshD(SK9)L&RGcXk{yWOyHzfOD^$6F~RcUuRxl7NA8uc$T#GB@*@aghukQ) z$@}C^xd)<{F&M@5(CNXEi)LTW3tkUNNLI*AO3;4Js{~Zd9#V?ti}OI#;w8(LuUJ{M zDyD4d#!d1O120TDVk@g$TVs|AVy*nZKoz*0ce&Xr0pREI7XNfv57obkoikj^cj`iRatl-3HurAmspOMeXm*mS}`Azwj?3W+QSA&P-9deW0 zBDaDE_R9z4Zuz*phd7D2LB0atbcKtZPLXxF9X<}exLrQzy>a3#33iGV^i*(d4dc$$ zY%AGvj@_o2tJnmf7YqUVT$1vUgOQHNp-5-saO6njXyjO=E7Be5i5!odh@6a^ikyy| ziS$O!M$SdfM=nGzMlMAzN3KM!Ms7#$MDCK*gUM5{w9^4I2Vt&TvoGbmj6fn(#fcw- zb{J9n0xc-e0jNswav zDSBdcxk?n*8$vK>6WC+sad15hc3^-7?|?82-2^dMNE~)Yg9kD6g11Hdv9p@3N5Kv^ zgeq|kgkRfQ9r(^2cv9mD?k1H2Ye3|S_;ax&&{!?j zfMiBXh4Rj#Xa?6*=UN80RIU(6xsPBF8(>Ii5_UqHfVb6Mu(7t1Hld9)3VRY-g?4Bb zV%zHhXcpovLby|TKw5+&upxHgCL!F7+k|jWLZfg3T7}pKdpg`o8YO5C9s`@ZxH)*k zwz^Cda87&N+K822Zv}$W76`d!Tkpl^fSTFoP6+949MUN2f{ozPo$KUITrhh|H*WsC zEa(qDHbUBhLmGu~unGLx?3M4~+Iw6Ox7F1L9|fO?_}gW$GL{G&9Lzc@gH7_iZJ$*q4xDadYqNd0eCL~c(0Nwd>;zmqv2I& zz1%w#&zha=(F8%9msG>RPT+O(dH3_(O${TMuR2q3-|+1 zaf>A%4jwj|EYf0)2H{4F)r(7^-0P`kU`GW>@D&T9+#>EwNwpnT3WrqMVdXDgWk)7f zS>VfZI7ybI0KSzZB5~g&iQJ0!@X{RnV>(VY=+O111y40#mZMw8a zm-gyXyDsh1rTw~eK$i~cQim=b(xpyaI;=}abm^!r9n+;QUFz1Q9$h-FODA;cq%NJ( zrPI1}MwfbZ>8viD)1~vebU~Lc>e3}$x~xlAbm^)tUDKuOx^zRAZtBu4UAnDHcXa8l zF5T0m`?~Z%mmccUce?aQmn2>C>(ckSe~0dG)csAmf2Zzm*8RJ5|8CviqWfEQf1B># zqx<*j{&wBJPxtTF{RedaLEYb>`w!{?C}=gCKLg*;WdQ9iNh^D5BVzWlBBB-_|Y0vu9eNO7w(yBi_zUBB-{L|wOr^8bT54q`F1xVps zc&Nrh4IX@W;P4>ep%xGLGm)#u!*)FU9uN3anA-(Iaju=qgDV`J3b0pK8YinZ_%9m# zK#oiB8H#bjkg{fR@rsR$S1d2NLKz1SYheh}#RK`1FMTH&{84WHOmvn5`zu zpVKMRr2n8M{Uvp#X~7E$hJh;6SC%xhY8ly9rKY{5X1t|lj{hl@%3NYnGek9Kfs$SL z@~si0Yy(M{ZXk!UW^_zd)3OapEo0??nabQ`R&zd5vKPHfOCDnzm_R7sr>vtpvedM! z807*?xdtc~D%l?bWu|T5143CySx2^grlyT0l;hOQiD%N4jOl8|IyL8gCHn)QO}7m! zB($qclr?Qo)p1(JDmCLBHD_|y1Rw)7R}*^%%HBlxYc*$vl0DNP{K6oFv(rTB<73jX zvZbKxbR~O+p+L2aw|%RojWg8MG8U>iQ@Y-MIl?yDHt;)xXr(#9dOZ_!JvdR# z*c|0I$_~aCnTbVZKsuBkSTtSD$y2iPK``+A!XSjRTBO+4RAlv2kEvK=@cCPlYAOtJBXjFWX}TuqlOAFfV>oYK6?SUop8^{js-g*DIkpb zO7?W1$-o*USn!iMIWrYbCo?|-Eq|+IfBbSnI@mEWu8NwOzz486P07w9Ax_{kMBUYD z&Qv8k*YHPHT$Yi@ko!?(dQO5XO5CR7lfoGDhooijE__t4V*cz hyL;eWYRn`hW0IQjMbzB9@ndX1t+itSG^UW6_kVL_5heft diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py b/venv/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py deleted file mode 100644 index eb40c5f..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/py.typed b/venv/Lib/site-packages/pip/_vendor/chardet/py.typed deleted file mode 100644 index e69de29..0000000 diff --git a/venv/Lib/site-packages/pip/_vendor/chardet/resultdict.py b/venv/Lib/site-packages/pip/_vendor/chardet/resultdict.py deleted file mode 100644 index 7d36e64..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py deleted file mode 100644 index 0ffbcdd..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py deleted file mode 100644 index 890ae84..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/sjisprober.py b/venv/Lib/site-packages/pip/_vendor/chardet/sjisprober.py deleted file mode 100644 index 91df077..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/universaldetector.py b/venv/Lib/site-packages/pip/_vendor/chardet/universaldetector.py deleted file mode 100644 index 30c441d..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/utf1632prober.py b/venv/Lib/site-packages/pip/_vendor/chardet/utf1632prober.py deleted file mode 100644 index 6bdec63..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/utf8prober.py b/venv/Lib/site-packages/pip/_vendor/chardet/utf8prober.py deleted file mode 100644 index d96354d..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/chardet/version.py b/venv/Lib/site-packages/pip/_vendor/chardet/version.py deleted file mode 100644 index c5e9d85..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/colorama/__init__.py b/venv/Lib/site-packages/pip/_vendor/colorama/__init__.py deleted file mode 100644 index 383101c..0000000 --- a/venv/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/venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 79efa4f1f193df2afe5f10e2ff6d7a3d8a934498..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 479 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 diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-312.pyc deleted file mode 100644 index e29b6f9020224895fcbbb92c23723d7a3e1190ee..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3537 zcmcgvU2Gf25#GHY-jPSr)(;&~mT6j1+E9sX)OOJyG!2Y4vQwu-0V@ei2x8B=lYBD8 zBlec2WUv5b7>y0siGv1JS{RKV@?h5~V4yDr`qIY$eUbbFv1b-=5Ep3P6v+h)qXjy1 z$2(H4kfJYLVrOS}XK!bB=9^jmIgyAFD4+iE*E9c$6Y@EBf+Dn;&7T9aOblYs5-IpC zEl{s76a+&s#F98K6(mXw=>jRph72@f#Er-WT2KrHda9uUjhb|>Klps7HKG^Dt#-Gd z88MKI8ye7rKukH9p=6Qf5?`QP{tF5;M_uhm*|8?0LPjVy>KNsZ=& z{CF6MCU1e4u;oY!=2E?B&1*k#jA%~%T{TC>WAU2}@l zcGjXgmY${s&ex+#%y+zY@)tTCw}wRa>W^&6}jnfhxNhMQK-%vKpNy>@2 zljd_GLl0vSBPuzGGF;5scI4EW#%A)*O-Y!Qr}6Z7X@M&Q0Ou9qA$3qYJHS<~Ff z)+~NHtCttEHa~5$tj=a%nP63OBA0YU77}ZVLsxVb9XH|!1P&~JE zB}6V8hOrl*IyZnc$Y|g+y4QcWl^j?}AHADAwxS+;93y?ZmPg+o zZ5(g)rhMj+5_{*|(zz8S-AwPflzbc^iGgd{^|x=Bw@>~_x*LCOU8K=*dRe?2yE^qh z3I9VS@#k7<^1U6Gc3g|zQ-_rocXYts0eCTlIuCt$ zX=jJ;k_=IUmS-vWd`|YUo(7(woA?IXjoen~yAi|mZg~XejzD$x0SVEc%Hp-OLjiWK z#JU0iNQMQK^p5wU7XUg(nhOsS%0g;B^DR(?E|LzQyk2G)m>i>!4=FA zNSp8zJ`r!VFXd;XzHO>xTD>dA7Q=nF-6u?|U$GCZ)9q3+>_a;m7sG&KNV)(pmGiC) z$@0*_@tY#s3!i6MBp87wa#4o%bJa>o=a8S~8Qy`1Iv;3wMBlpJO0;fHaARe&7Ub%H z2go{Th5%Rtb5(~IAy+?}so6^)bquOg1JWP>7FBzvzEr4~Md= zQu;r!gYoeI)Xga%$Kh22_yITbOPyGdUp}VqQVNONAiorrf$LDb z^?c9wE-$KY8#|aEJH7$(r=fu6Huej2Y%`XoyEncq(R~}q6y3MJp9t|aI=D&) izZ7KJvndi`_d0SLJ0&`@k&MvZFZ&7Id!J;zll~h+lddiR diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-312.pyc deleted file mode 100644 index 896d37c7d2055fa18e6171b8f4fcc1900b71c2f3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8113 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 CsTBDD diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-312.pyc deleted file mode 100644 index 6cbc75047137ec6767f2556497b86b10035d5b67..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9075 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 J@9c5s{{Wzbm5u-a diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/ansi.py b/venv/Lib/site-packages/pip/_vendor/colorama/ansi.py deleted file mode 100644 index 11ec695..0000000 --- a/venv/Lib/site-packages/pip/_vendor/colorama/ansi.py +++ /dev/null @@ -1,102 +0,0 @@ -# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. -''' -This module generates ANSI character codes to printing colors to terminals. -See: http://en.wikipedia.org/wiki/ANSI_escape_code -''' - -CSI = '\033[' -OSC = '\033]' -BEL = '\a' - - -def code_to_chars(code): - return CSI + str(code) + 'm' - -def set_title(title): - return OSC + '2;' + title + BEL - -def clear_screen(mode=2): - return CSI + str(mode) + 'J' - -def clear_line(mode=2): - return CSI + str(mode) + 'K' - - -class AnsiCodes(object): - def __init__(self): - # the subclasses declare class attributes which are numbers. - # Upon instantiation we define instance attributes, which are the same - # as the class attributes but wrapped with the ANSI escape sequence - for name in dir(self): - if not name.startswith('_'): - value = getattr(self, name) - setattr(self, name, code_to_chars(value)) - - -class AnsiCursor(object): - def UP(self, n=1): - return CSI + str(n) + 'A' - def DOWN(self, n=1): - return CSI + str(n) + 'B' - def FORWARD(self, n=1): - return CSI + str(n) + 'C' - def BACK(self, n=1): - return CSI + str(n) + 'D' - def POS(self, x=1, y=1): - return CSI + str(y) + ';' + str(x) + 'H' - - -class AnsiFore(AnsiCodes): - BLACK = 30 - RED = 31 - GREEN = 32 - YELLOW = 33 - BLUE = 34 - MAGENTA = 35 - CYAN = 36 - WHITE = 37 - RESET = 39 - - # These are fairly well supported, but not part of the standard. - LIGHTBLACK_EX = 90 - LIGHTRED_EX = 91 - LIGHTGREEN_EX = 92 - LIGHTYELLOW_EX = 93 - LIGHTBLUE_EX = 94 - LIGHTMAGENTA_EX = 95 - LIGHTCYAN_EX = 96 - LIGHTWHITE_EX = 97 - - -class AnsiBack(AnsiCodes): - BLACK = 40 - RED = 41 - GREEN = 42 - YELLOW = 43 - BLUE = 44 - MAGENTA = 45 - CYAN = 46 - WHITE = 47 - RESET = 49 - - # These are fairly well supported, but not part of the standard. - LIGHTBLACK_EX = 100 - LIGHTRED_EX = 101 - LIGHTGREEN_EX = 102 - LIGHTYELLOW_EX = 103 - LIGHTBLUE_EX = 104 - LIGHTMAGENTA_EX = 105 - LIGHTCYAN_EX = 106 - LIGHTWHITE_EX = 107 - - -class AnsiStyle(AnsiCodes): - BRIGHT = 1 - DIM = 2 - NORMAL = 22 - RESET_ALL = 0 - -Fore = AnsiFore() -Back = AnsiBack() -Style = AnsiStyle() -Cursor = AnsiCursor() diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py b/venv/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py deleted file mode 100644 index abf209e..0000000 --- a/venv/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py +++ /dev/null @@ -1,277 +0,0 @@ -# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. -import re -import sys -import os - -from .ansi import AnsiFore, AnsiBack, AnsiStyle, Style, BEL -from .winterm import enable_vt_processing, WinTerm, WinColor, WinStyle -from .win32 import windll, winapi_test - - -winterm = None -if windll is not None: - winterm = WinTerm() - - -class StreamWrapper(object): - ''' - Wraps a stream (such as stdout), acting as a transparent proxy for all - attribute access apart from method 'write()', which is delegated to our - Converter instance. - ''' - def __init__(self, wrapped, converter): - # double-underscore everything to prevent clashes with names of - # attributes on the wrapped stream object. - self.__wrapped = wrapped - self.__convertor = converter - - def __getattr__(self, name): - return getattr(self.__wrapped, name) - - def __enter__(self, *args, **kwargs): - # special method lookup bypasses __getattr__/__getattribute__, see - # https://stackoverflow.com/questions/12632894/why-doesnt-getattr-work-with-exit - # thus, contextlib magic methods are not proxied via __getattr__ - return self.__wrapped.__enter__(*args, **kwargs) - - def __exit__(self, *args, **kwargs): - return self.__wrapped.__exit__(*args, **kwargs) - - def __setstate__(self, state): - self.__dict__ = state - - def __getstate__(self): - return self.__dict__ - - def write(self, text): - self.__convertor.write(text) - - def isatty(self): - stream = self.__wrapped - if 'PYCHARM_HOSTED' in os.environ: - if stream is not None and (stream is sys.__stdout__ or stream is sys.__stderr__): - return True - try: - stream_isatty = stream.isatty - except AttributeError: - return False - else: - return stream_isatty() - - @property - def closed(self): - stream = self.__wrapped - try: - return stream.closed - # AttributeError in the case that the stream doesn't support being closed - # ValueError for the case that the stream has already been detached when atexit runs - except (AttributeError, ValueError): - return True - - -class AnsiToWin32(object): - ''' - Implements a 'write()' method which, on Windows, will strip ANSI character - sequences from the text, and if outputting to a tty, will convert them into - win32 function calls. - ''' - ANSI_CSI_RE = re.compile('\001?\033\\[((?:\\d|;)*)([a-zA-Z])\002?') # Control Sequence Introducer - ANSI_OSC_RE = re.compile('\001?\033\\]([^\a]*)(\a)\002?') # Operating System Command - - def __init__(self, wrapped, convert=None, strip=None, autoreset=False): - # The wrapped stream (normally sys.stdout or sys.stderr) - self.wrapped = wrapped - - # should we reset colors to defaults after every .write() - self.autoreset = autoreset - - # create the proxy wrapping our output stream - self.stream = StreamWrapper(wrapped, self) - - on_windows = os.name == 'nt' - # We test if the WinAPI works, because even if we are on Windows - # we may be using a terminal that doesn't support the WinAPI - # (e.g. Cygwin Terminal). In this case it's up to the terminal - # to support the ANSI codes. - conversion_supported = on_windows and winapi_test() - try: - fd = wrapped.fileno() - except Exception: - fd = -1 - system_has_native_ansi = not on_windows or enable_vt_processing(fd) - have_tty = not self.stream.closed and self.stream.isatty() - need_conversion = conversion_supported and not system_has_native_ansi - - # should we strip ANSI sequences from our output? - if strip is None: - strip = need_conversion or not have_tty - self.strip = strip - - # should we should convert ANSI sequences into win32 calls? - if convert is None: - convert = need_conversion and have_tty - self.convert = convert - - # dict of ansi codes to win32 functions and parameters - self.win32_calls = self.get_win32_calls() - - # are we wrapping stderr? - self.on_stderr = self.wrapped is sys.stderr - - def should_wrap(self): - ''' - True if this class is actually needed. If false, then the output - stream will not be affected, nor will win32 calls be issued, so - wrapping stdout is not actually required. This will generally be - False on non-Windows platforms, unless optional functionality like - autoreset has been requested using kwargs to init() - ''' - return self.convert or self.strip or self.autoreset - - def get_win32_calls(self): - if self.convert and winterm: - return { - AnsiStyle.RESET_ALL: (winterm.reset_all, ), - AnsiStyle.BRIGHT: (winterm.style, WinStyle.BRIGHT), - AnsiStyle.DIM: (winterm.style, WinStyle.NORMAL), - AnsiStyle.NORMAL: (winterm.style, WinStyle.NORMAL), - AnsiFore.BLACK: (winterm.fore, WinColor.BLACK), - AnsiFore.RED: (winterm.fore, WinColor.RED), - AnsiFore.GREEN: (winterm.fore, WinColor.GREEN), - AnsiFore.YELLOW: (winterm.fore, WinColor.YELLOW), - AnsiFore.BLUE: (winterm.fore, WinColor.BLUE), - AnsiFore.MAGENTA: (winterm.fore, WinColor.MAGENTA), - AnsiFore.CYAN: (winterm.fore, WinColor.CYAN), - AnsiFore.WHITE: (winterm.fore, WinColor.GREY), - AnsiFore.RESET: (winterm.fore, ), - AnsiFore.LIGHTBLACK_EX: (winterm.fore, WinColor.BLACK, True), - AnsiFore.LIGHTRED_EX: (winterm.fore, WinColor.RED, True), - AnsiFore.LIGHTGREEN_EX: (winterm.fore, WinColor.GREEN, True), - AnsiFore.LIGHTYELLOW_EX: (winterm.fore, WinColor.YELLOW, True), - AnsiFore.LIGHTBLUE_EX: (winterm.fore, WinColor.BLUE, True), - AnsiFore.LIGHTMAGENTA_EX: (winterm.fore, WinColor.MAGENTA, True), - AnsiFore.LIGHTCYAN_EX: (winterm.fore, WinColor.CYAN, True), - AnsiFore.LIGHTWHITE_EX: (winterm.fore, WinColor.GREY, True), - AnsiBack.BLACK: (winterm.back, WinColor.BLACK), - AnsiBack.RED: (winterm.back, WinColor.RED), - AnsiBack.GREEN: (winterm.back, WinColor.GREEN), - AnsiBack.YELLOW: (winterm.back, WinColor.YELLOW), - AnsiBack.BLUE: (winterm.back, WinColor.BLUE), - AnsiBack.MAGENTA: (winterm.back, WinColor.MAGENTA), - AnsiBack.CYAN: (winterm.back, WinColor.CYAN), - AnsiBack.WHITE: (winterm.back, WinColor.GREY), - AnsiBack.RESET: (winterm.back, ), - AnsiBack.LIGHTBLACK_EX: (winterm.back, WinColor.BLACK, True), - AnsiBack.LIGHTRED_EX: (winterm.back, WinColor.RED, True), - AnsiBack.LIGHTGREEN_EX: (winterm.back, WinColor.GREEN, True), - AnsiBack.LIGHTYELLOW_EX: (winterm.back, WinColor.YELLOW, True), - AnsiBack.LIGHTBLUE_EX: (winterm.back, WinColor.BLUE, True), - AnsiBack.LIGHTMAGENTA_EX: (winterm.back, WinColor.MAGENTA, True), - AnsiBack.LIGHTCYAN_EX: (winterm.back, WinColor.CYAN, True), - AnsiBack.LIGHTWHITE_EX: (winterm.back, WinColor.GREY, True), - } - return dict() - - def write(self, text): - if self.strip or self.convert: - self.write_and_convert(text) - else: - self.wrapped.write(text) - self.wrapped.flush() - if self.autoreset: - self.reset_all() - - - def reset_all(self): - if self.convert: - self.call_win32('m', (0,)) - elif not self.strip and not self.stream.closed: - self.wrapped.write(Style.RESET_ALL) - - - def write_and_convert(self, text): - ''' - Write the given text to our wrapped stream, stripping any ANSI - sequences from the text, and optionally converting them into win32 - calls. - ''' - cursor = 0 - text = self.convert_osc(text) - for match in self.ANSI_CSI_RE.finditer(text): - start, end = match.span() - self.write_plain_text(text, cursor, start) - self.convert_ansi(*match.groups()) - cursor = end - self.write_plain_text(text, cursor, len(text)) - - - def write_plain_text(self, text, start, end): - if start < end: - self.wrapped.write(text[start:end]) - self.wrapped.flush() - - - def convert_ansi(self, paramstring, command): - if self.convert: - params = self.extract_params(command, paramstring) - self.call_win32(command, params) - - - def extract_params(self, command, paramstring): - if command in 'Hf': - params = tuple(int(p) if len(p) != 0 else 1 for p in paramstring.split(';')) - while len(params) < 2: - # defaults: - params = params + (1,) - else: - params = tuple(int(p) for p in paramstring.split(';') if len(p) != 0) - if len(params) == 0: - # defaults: - if command in 'JKm': - params = (0,) - elif command in 'ABCD': - params = (1,) - - return params - - - def call_win32(self, command, params): - if command == 'm': - for param in params: - if param in self.win32_calls: - func_args = self.win32_calls[param] - func = func_args[0] - args = func_args[1:] - kwargs = dict(on_stderr=self.on_stderr) - func(*args, **kwargs) - elif command in 'J': - winterm.erase_screen(params[0], on_stderr=self.on_stderr) - elif command in 'K': - winterm.erase_line(params[0], on_stderr=self.on_stderr) - elif command in 'Hf': # cursor position - absolute - winterm.set_cursor_position(params, on_stderr=self.on_stderr) - elif command in 'ABCD': # cursor position - relative - n = params[0] - # A - up, B - down, C - forward, D - back - x, y = {'A': (0, -n), 'B': (0, n), 'C': (n, 0), 'D': (-n, 0)}[command] - winterm.cursor_adjust(x, y, on_stderr=self.on_stderr) - - - def convert_osc(self, text): - for match in self.ANSI_OSC_RE.finditer(text): - start, end = match.span() - text = text[:start] + text[end:] - paramstring, command = match.groups() - if command == BEL: - if paramstring.count(";") == 1: - params = paramstring.split(";") - # 0 - change title and icon (we will only change title) - # 1 - change icon (we don't support this) - # 2 - change title - if params[0] in '02': - winterm.set_title(params[1]) - return text - - - def flush(self): - self.wrapped.flush() diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/initialise.py b/venv/Lib/site-packages/pip/_vendor/colorama/initialise.py deleted file mode 100644 index d5fd4b7..0000000 --- a/venv/Lib/site-packages/pip/_vendor/colorama/initialise.py +++ /dev/null @@ -1,121 +0,0 @@ -# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. -import atexit -import contextlib -import sys - -from .ansitowin32 import AnsiToWin32 - - -def _wipe_internal_state_for_tests(): - global orig_stdout, orig_stderr - orig_stdout = None - orig_stderr = None - - global wrapped_stdout, wrapped_stderr - wrapped_stdout = None - wrapped_stderr = None - - global atexit_done - atexit_done = False - - global fixed_windows_console - fixed_windows_console = False - - try: - # no-op if it wasn't registered - atexit.unregister(reset_all) - except AttributeError: - # python 2: no atexit.unregister. Oh well, we did our best. - pass - - -def reset_all(): - if AnsiToWin32 is not None: # Issue #74: objects might become None at exit - AnsiToWin32(orig_stdout).reset_all() - - -def init(autoreset=False, convert=None, strip=None, wrap=True): - - if not wrap and any([autoreset, convert, strip]): - raise ValueError('wrap=False conflicts with any other arg=True') - - global wrapped_stdout, wrapped_stderr - global orig_stdout, orig_stderr - - orig_stdout = sys.stdout - orig_stderr = sys.stderr - - if sys.stdout is None: - wrapped_stdout = None - else: - sys.stdout = wrapped_stdout = \ - wrap_stream(orig_stdout, convert, strip, autoreset, wrap) - if sys.stderr is None: - wrapped_stderr = None - else: - sys.stderr = wrapped_stderr = \ - wrap_stream(orig_stderr, convert, strip, autoreset, wrap) - - global atexit_done - if not atexit_done: - atexit.register(reset_all) - atexit_done = True - - -def deinit(): - if orig_stdout is not None: - sys.stdout = orig_stdout - if orig_stderr is not None: - sys.stderr = orig_stderr - - -def just_fix_windows_console(): - global fixed_windows_console - - if sys.platform != "win32": - return - if fixed_windows_console: - return - if wrapped_stdout is not None or wrapped_stderr is not None: - # Someone already ran init() and it did stuff, so we won't second-guess them - return - - # On newer versions of Windows, AnsiToWin32.__init__ will implicitly enable the - # native ANSI support in the console as a side-effect. We only need to actually - # replace sys.stdout/stderr if we're in the old-style conversion mode. - new_stdout = AnsiToWin32(sys.stdout, convert=None, strip=None, autoreset=False) - if new_stdout.convert: - sys.stdout = new_stdout - new_stderr = AnsiToWin32(sys.stderr, convert=None, strip=None, autoreset=False) - if new_stderr.convert: - sys.stderr = new_stderr - - fixed_windows_console = True - -@contextlib.contextmanager -def colorama_text(*args, **kwargs): - init(*args, **kwargs) - try: - yield - finally: - deinit() - - -def reinit(): - if wrapped_stdout is not None: - sys.stdout = wrapped_stdout - if wrapped_stderr is not None: - sys.stderr = wrapped_stderr - - -def wrap_stream(stream, convert, strip, autoreset, wrap): - if wrap: - wrapper = AnsiToWin32(stream, - convert=convert, strip=strip, autoreset=autoreset) - if wrapper.should_wrap(): - stream = wrapper.stream - return stream - - -# Use this for initial setup as well, to reduce code duplication -_wipe_internal_state_for_tests() diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/tests/__init__.py b/venv/Lib/site-packages/pip/_vendor/colorama/tests/__init__.py deleted file mode 100644 index 8c5661e..0000000 --- a/venv/Lib/site-packages/pip/_vendor/colorama/tests/__init__.py +++ /dev/null @@ -1 +0,0 @@ -# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index e4ac46dc3dfc884862117bf3c2b08918b8fabb8b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 185 zcmX@j%ge<81SfXSO7jNNk3k%C@RQRXW=X1UL1J=tVtQ(EOhIOWemqbvCBH~N zIX@@AC^0utza+J|q*y;bJ~J<~BtBlRpz;@oO>TZlX-=wL5i8IlMj$Q*F+MUgGBOr1 G16cr0{q)0E*YxsSs1?ar;ScBHDW+K2S%b-D)?{we(lc`w ztpk6&U{Lx%Vv1>`u9-OK&SzJK2d737*4eqMo$t|1(y%h-lsPw>p_Vaq)0nwAHI}$K zWhN}6dlvR9e%&yqW)ri$F{slsw0Am_%FuW^-fO`Mo4s+^z8GeEX0uE+4eQeEd{c1) zdU&}Bx;2l2SRm_eQrGxU^XD}Gz2R?KzHR@y{nw7J?{4I^!ADwyO~slvxCuy7wUxNk zd@J99%p$Qsiewcwfsj}!XO*_EqPDcTSwb5D8&H{7tXwQZ6W8fZu+e4^+ze|d%)8Ls z0zxb$ZN(OvWyI-l=GM%7b7|g16Ml0hI$I#Ww|3r@@78nmMLpdE#;Qr-kocsAA@|(# zS(;X|GzGvFk}m!0DJ6!z)&F@^VbAW%TrgJFj^$zehw4r+);M;BbZ*YL`u)#Mvz`tUH zZ*qX|w88IifPc*fztaJJzYV^*jL(w5uE@OVpFDCn%~hXJ{X!iPDk#)jLLC)qK&TK` zAps8wcu2rQ0v;0Zkbs8-JT#CFv@oxrD9%sR14Cu%sj;Ec=a@Vm9%kyucsLwk?knN3 zu?v?WFc`ZOW}fpyBjL!z5K~TH8HzCV^4ZaeFjL3F7sC^*acp$t>;!ia3%}32ya=wa zAnLeFEH?2v;Tp>g1?Z(PmUi$`p{sH=c8Mk7i+2shE&uvm$aEOM3|SUUT%CjByuaeF zUt8&enVTN~?=BF|Z*4iP?cVPD?Mv;;(Y$uJ($==rwmg{EdMa&p?fgsrso=)hpO5h%=r$k!1xEMtlc?Z_X^BFLh@3e9R@tt;DBrJ zz%{tw8hmgKPPhgyTqD2Imtl|;LwJgD41E59?sJ-KG-oxwrb9t}2vKO5E&v@idKL!JM%2(KnMk{j*pX>M|6MrS480S*{I)c|aF|Gm3 z4Whue4nE*#+6gh;lk{z{;d_)h0%Bd3BF9KnfyGt;C)og lJawOt`tN-7lz>|QR3b{lo%vs6-*1Zc*_m~jDDAwXe*pAVf$jhR diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/ansitowin32_test.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/ansitowin32_test.cpython-312.pyc deleted file mode 100644 index 5b241d118bec6ce47c2903a3a86e98cca986a6b0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18090 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 diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/initialise_test.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/initialise_test.cpython-312.pyc deleted file mode 100644 index dbd5f37823179b26b1a2e5e1e0da8845892c2b4f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11735 zcmd5iTWl0pmbbdP+SM=91_N!6ZQ2hAZH%3mWF`Ry;$R#e!LY$umL7InO;;J(?uYkQ z8SEaT^-7F3>@dPej7(;cl1NC26{LwqBQ4T?Wp+Oz?GHURvQvu`R>Kc}HfH3JwOZ{t zx2n3T+hy~ZStZx<>8krU_ug~PJ+E8;84UUel&}BoSN$K<67mOpF^gb4EdDP%OcIGm zT$;r2*Olfnu9z#s$M}pp=H`eOYx%U0@x(ltidY3lB)24_eHnku&z?Q$KqeRqW-4Qq znRT&sP*)*|=}@LBR+U*FTh9@h3~Vzewti#PP~U33n@_P#F7hssyqAgOlU-l%dVOp& ztMx-|z*ZZUYoy@dc0#D=A~OGlfrKNY+$h&fWU+-%TqW+nYwh4PxthF4M)=d@A{VWE zjH7y^ye9U^ih3ZS$eKHoNM$vjGMF0rAe)vICF;_Ip@f<|uep!ql7o+3FeJ)p!ILVL z6PZ&qF*GDoK;cehQ>qpo7*^DHe`+LtF_o2a7nOK2msN6US!;lrAvvDPsxr+c(s4yi zsB*kNN8>8Ytvu!suS@gflx!j+Yd$Iur4vaxes(m8t2B$pcv#HCfJvZmjFU*rg*1@e z1B~xxSN(S&So)4{CbcB)3)~JA$#uC{8>^7`%OoaBZh&4%0O$k!e#!F%E)oiR175=z zV?3+zNf#8j`#w$(ZQ9YV?n7B)>0|01Gr8K0Srl10IQ_+0M|2|8%ow# zZN5nx9q?^nBdk7~tUj@7*0#AgK5T2-I9d~})x^WVaFm<;W@S`qS5zrCtVU8wB%4zs ziHNF>CJk~KG$RB>da(t-BpD+E_Ey%#Vho5enc{ju&O!-Ak*V67Q*}|3rZ~;5$mxCs zhewv<-Mi1cn^F%ApN*WLxdBzjPyv(J4tc<8V=x6SO;bF`KU{ZrH4< zfewqC0F09d;614neaIUQKzSzs?pRYHSaeJz$hTEwO z`Zk_Or0)boCcg|rFB;lh^x7>>J(2a0TD%2OJ4yn<)UaXXa@iVR~?Dyc4iaW zTNENx1WS{3pIIO-Z{veN=xWbgAT%3jCDoby*qIVgJB*U!&)qcH5LMmGl6DgSPL?&1sT?| zO!vT0XMf_m6!j>Gx-gVeQX_O9(y-jbH8_#5H&>MKSJtGS)sgWA&kcB6!3`7d{yfge z^5>9k2C$WA2=a0o!g9(692^%DCv$)t^ownD(Itb08O0j?{Mv^(z)=rHuZ`&*EnwO; zpr>rJZ4vBI&av=HjvemDf%(QYc%^qi5m1f*KrU^*>7EYOFA%}o%Gd;vL9l8zP+tht z-%5Tw@X^3bAj(u!NzIZU`Y+)iHgZ`(KmKZ$x2u8wszK;_rNa3Pj6tswX0D>{CD$F^ zBI;jG&S6@OPceFC%#;71TL)L8&f#n_ zmx1J03jDiMDfPTf8r%1#bIC+n*#{501Nm2gRKZ|!oZOM__I)kPwD*qd4jbgP42|@D z0&)wA=KJeJdRRV4X>Mf*-de`bH5QTI^%5&Tf$Kyf8qrlvL9DseTG-ZmUp%fm;@gUD zE_m1AW1p1O19}#(PaaXbRF$UA4y$s0OR-~xjX2}36 z4YHb_`aFtDMHioyF>WneB-uh|XBFr?UJ_7L4CrCcE=xXN2vfycn4aI(MIl;3rO-#; z1xV5UQWQE}(oz1W1j`9GWB7xAKb%Nwd|J+Gl_0h0c!Hi&;*jT3qdfD_HE#xzyIp;! zc6I8`IT;{g z-^)s`$fS1_OxCWS6{dG)^JDRZw_r|%^(`Pahq0_QbgKd+C`fR!EE$9U8pqk8Ol zjP5e+0|2Ir18_H z9M9^wRD(NRA_x~4G<3j${oU34e^d+I^%ePMCvygY??_68G}JjzmNG3-6v#OIU%U&z zt|&^50rn^>U~Etj%8IF6AaLRaiiXYVWMQ?8r&R~W2ve?Q?wl!@p7whx0P|Z(-d8Kk2*fn+-J< zLXFd*=6hTBO$+-MTrMH9$P>@o+&n%$5qY8UiO(Z6Jqfvl&|-IE$IqNbwHtEeS04f+b~*rTF$KK9nN(MwB}7EPKMvMZRhE<(RjJmte5s2cTaJ z_^9Rd6^m4$gB|p?4WC20%(|B}C6gu2*2aS=qOzi5=A9J_ z&nWw@;SwkD-DHCM+usuM&u$gf4J(rSLw7$1=Rh<^pj!)jz~Hc~SbKDVb+X>p-rFUY zt=(bGm-xRF6~}Cj?G-m|d?qIxRx@V1yUj)b1B!ZCS$jWr47Q#QT>ow;^XF3K1!V)j zC}8Egke4yL>^X42l=;<8+Zb=-po6qntw-TEJRa55~Hh{TPNcu{-do0BJLeLEt#pohcmtsY~xFC*gU)v&VC!vrnDjd8ZQ zd1v3!!YsL=$J%pqmiCJmH6Hu6p@(HP`dF+K6)84?W17xE=7Fa0B|v3$m}cV_Fq5Wv z`cshH$d#q~!BfR=31|dBiGwQkCkAEwN+y4BEz6~-j;&Vi&qVVfPVjdCSgND8;a@gQ zc;+HoCp9cxI9jm5 z2LOT;78759XU#uErG(~MlC;PPrAE`Lou4f4`t)= zXssdF!;k_;DWm91QuJI|IH?8AhIR~>^<^<_=0BXl&lK4u0DN|ewE$jm-_@b(q zS=S?Uc52WZX~M9YN-KJR$UvoGBEC+GasIM&T?G)ha*o3{ysgz zzr%5RJ`tZ1{GC7IBJRM4`QP(3-?+t}_003cUHhl`L4k-Ho)8Wvh!orroVjsX!BtO) SU2Wv6wqVy@{;NG4!2biGyZ7&-6`tkplDp*6q9wzXtffN7KMJi_qOI6&6{7)VNwNE52ep92i~wS--8hu_ z*V&a_2~N<13pj9qv?u}xwGIkmpcP~^y|*Y}p@*WqlqCzg3j+a~L*bh&1t6eP-<#zw ze@w}4(^ETu-n@A;`(}5(_r7`JpTprGf%eDW{^FhQ1PJ*O2W}JV%I5o^+#x#AxhzRx z@5^#IU&@!`Q#?m>UKg@LPE3h8f65PIQTJy9IVmOOUpDwI=F3d{v=l2q77 zUMISAljySHTjiZyQoD>UJ$UscLa5{;2ESV0oFfa|0v8WG#_{>M&z7bQ(>kM>hArf@ zO#ZPC>|hRGw5Xxw-lSTwXiz(p%$u3%!kd}==<&xKE)nfOabfmdjppniHHukn)<|Do zuzOs+Kr>e|c`b`Z*>N^KeaTiF^?V@@qgnLiHUSiT`OT9c?hwnHy8%bEimwH2uKsz> z$dT@+T_h_Ud=d47+4g5l&9WBaob5N+mzd};w)OVJ*v#u0>+JmH*c-GkXIKSu#+)w} zsAbGtGxFDFzL&W?V`ePlXi=NJs$DV6nPR3ml7>0GKu2Z^*#gya+K2_GW{x}abhsKiS_&O4herM)jBLUjnML6?_nYfy zV2~82lax>A0A^nIffRHeq^JuZ{kjM;p!-2eEEMDgDK6W=bL`s@*p?Hdb28bXyEAjgQwUH5V168J>R zkN8XEI!C);$GAWh=Ab-Xp5n=`_-w&6vhUbD;9+9;#A37?mrDp&8p3a} zr*Tlju5lMEG0%Vi)OLO2_SIYbLrM9l>w~T(X}RZaxFQ{X6y9_D(i6hTLl2e6M;AW0 zuyl6$;@$68lp{4Bj5VBL(_5P%@bh_pvWI`rBPP|r|2i6BJl>Fl#*~%?P%sbbaL|1? z8^{;(m?15QgxKN341%(^9TdmD2c9<1fdE{(2Yx<$D*(7urQVX%yVScpSnfMgk%l~I z5&%tAQA>)t^w#o~a&)+&j37D*L??mhB(`W2ymf};A28D?L7peDEle}k<|J2Z^lsX? z{j(FL$sfC08op3-{kT2c3IApi`58VGiHgBx^X7tytf?E6vc52Ht#AxJheVw;iZIZw zXRLSMaPEP{{&wV=CJ}sd3IxFCVQ ze>=H5d5C{-NK6j5rWO(sBf39<(h0}+I1A@lYbLEuL|4b$BRTguLM-GN);iH*I}YvR zr^)TZZin1NL<2e62g8=c>Tkyg670e?z%`>Ai-&iBt7+W}==3}Yj}W~q z8(Io3kKXNi1{XFFB2(9qAh$O6gUgSVWFP-&e=;ooP6F*gSWNDfA9M#$?-P?R{$Ih0 z?AZh>p1Z@JG0<9I9cYKuDW^PS<2xYRy7VBr{s9P&RXuPM0Pd-BFT2Wirqd=)Whw#; z^g0A?Tj&+jg{9^DP(yS|OH8#!VnWqduQiz6t3g`rP-pCznvK=2H%7TTK4am%&6-ON z?z3*sd>~+Ltw9MERw%4(@1va(o;B`38T&d@#)ku)?XC5b)D&*`$+Qu3EEw6HfJ{pV zK{S)U+93iBFa8F1jz4c<9KC)F!n+g%`P8G`{hv&fckh2f`0%O9fs?fmPsl}Mt=a{uMk;qv}(RU%_xywmlwu6xq`zSaJ6>_jDUvK9beHFQ|x zVT*MFqUM9)I@-3_OkMTnx6Cnkv)jt}D1S#89~3`JzA)Y&So2AsuLUJAul0-L2SaPI z09ppc@r1ngasch4;`r%psOtz+qT7Z3vr6Wt3vD+XJ5?HUUJ%1))LVNfZX3p4vTYy6 zUu#eA_I2M3Zqvq|5!X701$$fjuYB|K?vGVxTl@O^x2O5jY2BKpp{5EAdCMsPcB6(T zR3q~tE$P8nk=hlD$2z3tf|R@JjvA{(0Cjd&!VoR(?6Wovd#=u@i1RR0l%jZdIZH$6eB2(fmk6FLxokwbT4WskUC9- z<0jb<1aW9X5yZrX!i&c@f;Nw5gw#=5f&(}T2!g7DH0kxgl|BRSwZ6NJtb3ZjKx&B;vq(yX%jn5h_<^wQt`0 z&FA~gn|VLAw+9H6AHVZuS_(!>qXnIrABQ7@pr7SyLvRj!Z?ccHWlw!g*pgB@tG17Nqc*llGo z7W@-O$EX#`8AVgOX%@1@?2N_$k*}FdFV4JkC6#kmuq)~swN6mhh(^*>C22vW6_OUq zLQJ&$Fi^`DCMTzI_0IJP(4iVI1p~`8CZs0U$vU+>T+3hQ*f)Ck!PxmsQa8uvrlVJx zF{_yd&+xgD!Avc4Lo43MysJ-VxNd4Mm9n{yVXHh-(o4e%w5bLg&KY@wWeeG1Q{yHd zo-_44kC)1pSLa#NEZ^#A>@Dsfepr>`SuK&RQ{fsYB(?6bWJM`v3!0)>0Yxbo>RcZ6 zprU*-m(4pZEC_v>jG`Sy8wzh-AkKXtDx@Y*smtku&Hs_jptIwYQG60Y-*z@+du0>q zYzwz~E8IGh>pt$h;l8uU6bk`(+_5lXC~&G4$0Ckn*mC5w1po%%uYCyOGNEwdCTLEX z#nxkGkuJ3KP#Te=k}v5RT$%;i9N%m$lW)X%x=vFu!4eE^dGKsv0(%-}w>$>ZXE?4E zjoLg|UV~!?)&p1v{5%Tc5AxR%dDPZ^XY}^y(%4q0vvRSL-1hiwZ6$fYF<_TpjMI}H zya%mM=3vu-S)B4%Srkqt;0W3v?%!!y5SnW#jWG^c>?v3nuBph&-12f$HRepa))-qC zQN!D7wIO+m+uSgq564R!tuq>6S}C8+Y07k&;dyt%&qqNxtae7$hVBk6UEZlHTc^7# zmnsu(g)E=$bpWVVCJt(NMV1qtiLU<_-K-bSbf}X#`DSh zd4rU}i4nr-yg#YtPv>*6bwb01|{fyH6$3-EIdgnbcy9eA#C z@w16fC+?p*^S~3`3H5wlTuScv!>h@M{@z_erO?lPBi{}_>^pB8+j9H92;e@pJdy)< z0=EPA!vhcGv-=VtRfG@iMqB-xzYHra#}cp6jbLI({7y>rNk7P-ZF+hD-0YJQgZ|9{ zA0k6i;uYWKun+K9&@YpxFuPA7%sC9RL6T diff --git a/venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/winterm_test.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/colorama/tests/__pycache__/winterm_test.cpython-312.pyc deleted file mode 100644 index 305050d2497cf5290408533092946dc2cd723ff0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6599 zcmeHLO>7&-6`uVexg?h~YwO>xOeHpK29adTsqNN54Ovzc6}FUGG+Yw`78G}7lje^y zyR;%g26}J{2{m9DIXG?u)IBAF1Jnfyv_N|4tw1kgrGV5BlN?&84cs7?ph-zhm$?6p~bbpSgkU#qH{*b2DC z%FHw?+5OY(G?T$qbw#S;o)FD%4OvRO#Z8k;(CV$#(_BWZeOWD;wLrpbH(v-g%0M&3%W=Ztw{6I&1ANyQ2cp4m{e7TYW;5)lUdy(jTfi_)mRct*DI-L zp!2-Wt4elU_vgT%L6;|bbOD>Vsm`MgRXqDBl;@-8zcV_J*4`|RMc<-@jG`6PQMEWx zpqeszQ_0^Py^tOoRnwZ%IRRTFuPN&2M0%oIf-$*3yDe~Z!=GqscNHQMesxVu=>j$e z^J%Tr0CJ$yh~tRWy9cCD$AJ8hJl)s)?#UTp`C#Xaup}H$?2rXry<-LZVw>@Zk`28i}$WDFxAMAga{6sjq4!aPY0|84Bs=QrHQ$>w} zOmbmTP1(4FIjA55%RdGjxMGj<*d`akh+W5`;(mlzT?=Wj~#z&`r zd3OHnl5hrQRT>YM8xL=ow=72P4$TfNiU*#E4R?oUhu^W zvLKU!FLYH#F}^U=)V?s>7zM)PKC4};EoWl{xyD+*)!HJcZVZm@>s-vj863eyxUX|F z7*EZtw_InW=$71Ook44;E3&u73rxy4v=W0EEB}JBg8rZ4iBYu6cuX|HG{tkH=tC$< zTn)b}m{`gT*L60i`yr;F0cNwNIeJsjRAkx)tL=#Eu(3-xy*HcPY-83)H?I5u$d?O{ zPxl}E*~uAxNoZMaMB@WfG^?f-G=k3r@osoF48zcRu}Hck9Ca9Ur8QP=ja6EYm0OQJ zKJe2FB{ zHBEI*I32bzMdtac%SMZh$9$&GMiD6L)Ig5TWAbJ|g&xOF1mp%!Y@|}DaMwB*v^j7&Wm9$`(DuwuFBOB{uj~)2GE z9e>=jAfEif!}$Z7b5a{zFMaL6C9@ydFLz%XfK`1=JjUq$LLQz?WQEdg;6{59FgDgG zMqb(n#6VR4rAu2Ps%aylhVvuFUZt0|MwT@P!KF?Dc~OKtd~HE!fsE~|z-%ZM(FIA$ zCv%D<=>bW~735+T+oB}l8xk>w$2gn;Z< zXgfZFIThJJbFJY&H`kU<^aQHXL2K=RLvCwijfIxs7>vV0o#7L|B*h{WlMG!b!ZRF# zkz%?{F}pBT6|x4p@Qu*C`JguS;9w5l0sAS1=YJjtbsuzk$NnJ@rl(AfKl4(C z3CtaRMzCJZaD*3UN`K;7|I7> 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/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-312.pyc index a38d7bb928eeaa7a7fed819e361d68ecb08a2f8f..845ec32f12a181be057b05491fd667a6145bac4e 100644 GIT binary patch delta 20 acmaFC`GS-CG%qg~0}wp!owt$uE(-uda0Z9~ delta 20 acmaFC`GS-CG%qg~0}!0pJ!>QPT^0aCvj&#{ diff --git a/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-312.pyc index bdc5f8a9a3d02edc948086a3eeb717bee76e0b8b..7c5d182ae6a9a33c7a7e7fe8729d47ee0f39d712 100644 GIT binary patch delta 22 ccmbR7glWbTChpU`yj%=G@VIy0MsD6s09q;sfB*mh delta 22 ccmbR7glWbTChpU`yj%=GaANnYjoiGO09tJaj{pDw diff --git a/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-312.pyc index 5ae5499b773eef36d9ca66a20f75df368884e297..d82127cecdaedda96926e193fdf589a8f437e47e 100644 GIT binary patch delta 25 fcmccD%yO@ph5IxwFBbz4Jno&>$i0=D@iHR-ZPN$z delta 25 fcmccD%yO@ph5IxwFBbz4oY+09k$WpQ<7GwwZbJwI diff --git a/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-312.pyc index 1c4621d3665cebf4b43cec06d7cb40964f71f3d0..3a8c58185b8b6612ad867e861fc64e883b2831e1 100644 GIT binary patch delta 22 ccmZ3uk8$BXM()$Ryj%=G@VIy0MsBfq099)S`Tzg` delta 22 ccmZ3uk8$BXM()$Ryj%=GaANnYjof1K09CFB2><{9 diff --git a/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-312.pyc index 333ab38b97bfb58c69d9c25ae9290cb8a5b91b63..afd208ab621b549f13168e8aab10d769926fca4c 100644 GIT binary patch delta 22 ccmex(mHFdUX71Cxyj%=G@VIy0M($^?0BA7@CjbBd delta 22 dcmex(mHFdUX71Cxyj%=GaANnYjoi;(0RU)p2{r%# diff --git a/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-312.pyc index 08ffe47f207fce423cbafbdab7e4259f229266fd..10f3e83763b3f84efcc3a18c433b7c8cab30df5e 100644 GIT binary patch delta 20 acmeAu>nP(s&CAQh00fVF=WXQvYXtyA`Udy_ delta 20 acmeAu>nP(s&CAQh00bv?&)UfS*9rhdJqHH> diff --git a/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-312.pyc index deed95854a3f1f3dfe61bea0dbdb0f98164d8f88..d205ddc6c5ab23dd101d29925947aecd1ad314d8 100644 GIT binary patch delta 20 acmexr{neWLG%qg~0}wp!owt$ul`H^EnFlNY delta 20 acmexr{neWLG%qg~0}!0pJ!>QPD_H~ChpU`yj%=G@VIy0MsEGZ09!u?n*aa+ delta 22 ccmdmWjA_>~ChpU`yj%=GaANnYjokW+0b7CxssI20 diff --git a/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-312.pyc index 96c7d71c6d3fcc71244c6b57274ba492ffe85309..a40b0ca9a53746d35b7f7dc3707d60265e435fad 100644 GIT binary patch delta 22 ccmZ3`&bXkRk^3|+FBbz4Jno&hk$b8$08PUN?EnA( delta 22 ccmZ3`&bXkRk^3|+FBbz4oY*~UBllEi08R!5`~Uy| diff --git a/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-312.pyc index eb090fca5fb98124196d42946b983cf9a6a10c35..20af8cf53e9240023b66bb08a8b456f1142fa73d 100644 GIT binary patch delta 2779 zcmZ8ieQXrR72mnr-8=j4Y-1-ro3ju5&L1qkvmLNaCk-{IS z@6G1G&Fb#AZ{B-5^X4~i-uvVwa{VHyzv1)c3-J8og-at(4Zs@*xkvs|xbyi^{THHE zHnxX-Ln;Y)65%llRejt>4~(d(K0?Vj%&keYSeJS2w1`gn7STpAlI^=1aCPc zS_BsMLG{-IcpQp@@6VF7lu4%z%vAot&d@doAuJObfP;85G$-2|V4dNOq=h{d4geP? z!wrr+!hRTz0vW5}w`8KTr7iE1B9>^V4%Wj|^g#x=l6p!rv76JWRcy7 zMEwgmk90~;jifF2DLoTQsHRFASYfmU!tRMi9X^sZqSImw5?ZjxlN9$&!wAR@l>i_! z8&Pfou$*clLARl_VN#{KnlfXs7nQ1Jnkr5^Mfi~pgU`B@8{E2+46^yHuK+_e+rCSH z%(q(tvk&3KI>2SZ50UNwxz}=Lrl;t65EVCVN0&VaoUloh&LCVx;A{O1BqiTod=|B@ zBXl5OdRU@LM}Zg=Wg|}YjA?oJyTY_N`vI7Yd;rW6`+;0BTN}s`w%qy_#C)vntmOSR zcpT=O&`S34&eowfL1D*P#jiJgaD==vc+t+w!*eKYMra1Gq?9(LQOZyA5^8%<>!zBT z!1RC~8KlO4Ab=3RPC1ty~dLrVY)?i>EWwu@OC~(J0zpLs&)!5zm`q-dm!f zX(uS>3`wGW07`+))GtwiOj)v;7@IIm`V$A`wk7l3U6?4>_1&_-PP6*$bLU>>XwgI@SfV7p7 zjxwk-8#@A!F>M_^wfGTT0l0r*C)MPHcK^cO|7yo2n1=^;M)+t`&GX`d_q_K*cLl9P z7pzusO!nL(g5ZSzop%Jb)h^CygO%m!)vLo%9lB5qplxSEU``YDYfkCyw$!Oq7YhuUcs zCUnD0>cg>&8b6_qLdJkyk!cIN+EpFE+_#+L#;AdjuA`kUvBK`4{39elW!t*jx7;i& zdF9df3&Xd{Dqc;mIZ0X5qVu1nRm&wTy;4;Bmy*CsJxjY+yw$Wa`%ZV#F?b}Tc-a4xGdO7$y0t4Y7wy77`Wkc!lw?W zmMfVa9mVE|y~=V>jot*o-X>%B z9y@;I-#EtVV@Z&MdWL?CvMZh*&tO5hj^_WMN~XLE(LdwB4ef|mdb{i%Mx8V~Z9>%lSFK%xK Q7emg2NZwU;bhnBB1Mp#`LjV8( delta 2626 zcmZ8ieQaCR75BCMo}I=?8l1*S~##~-5$qLsW!MO8Ne(l$|{wX3FXZ)lnr`(u-~!ss+nv}xyD zw+Zn6_`P$_J?GwYfA^eo-+P{2eU@#$P*bzPhTpHxJ)ir*KAY_?G`RUmH-yjpCpLc` z%~n5YI}lPs2f}vSK3mrFq%B*cwyioUMhDvG?XlW&yZwZt{B!9PlLDykFBe=BPG<36 zRG+MlpaP-<9bEH-nV)~(6JeA5Ezd7m6OT6p%ExLpvicsf*n(g=ONu!I4g7TNCb^fi zoA~>+A@uuuZIb2rwz{<3MCwranY!1RuVO-u_FT!Ju)^Um`1wSA2P>85>dQyN#y8VRp+Sty90j!q+emVk3W}N2 zVK(N18eq8=z=p(!1I!o|(+xIs&ph3(o zPG?DK(S&)!E_~2D7U{EJwefF7Qck*%r*CQG??h(g${~19w2AfdJEP6WM=siB|BsFH zXdDT7CwgASdtB=J?e4?qwh)*)q?Jk-Zdg5{872uit)PZGj93IZ&;r(T!&T6Vs-c!( zmh_YSM0Y2Qbc*-HBl2bvyZHU_NR8l3 zDk`(80R~@=Z)3;#+wr*X7_B2MXvLgvxfirjI;)rp#Q1;Xx8ad`6LI?&wz86#cV@$6 z$?gYY2HFVdU_f;glc1aAID+L+vRSy5r24}OXiCvc<5?6?OdVp5N(zZ9e+X^9nwt&$ zp}qz_+1Ji)=W~58iVDa$`8_)t%3ZfT&ajf+>~CJGM?c6ToMPhIVF$`1mZLQPC@iBG zbHg2EvWq}aXp*!<@G}Cj`)QP78!F*^o3yVHP#TGZvYZO!kt!TpvXKF;WLnkY-(pr+ zd>y9@>MtU(1Yo)x+}_2K{Mh#M7;JD~pseoDB+mnAH7%HeCTO{!6wlM zNrYH!g~M~CAPy~A$v!-1n6OF%ma{hGG%(Dxi0?hJdXP4TM`&6SsV-;+A{5?4FlrIj zStSXX-96aF?kyJv)As0haQ>8CFd_~SVCM09AlgO-BdAgtB@VWlvquGRnAT7e(ZS`-#WpaW0R`ve#ZYa1a?#ATRU3Ys9i$-=qgY}YG+O>W}!r)ba38O z4J@u+-nX}HCl!%Zm&IOI&<>_cO6HJ~S1A(>eGW3J<(M_{h8vCO`sl0N%L>=`2IXgn z%Vo~@4%~B1wuLsI)SuJe$eg+La$Cc0U*d|d?~x0OST#mT&1g9-qnMgrtQ5T{e`*85&Hw-a diff --git a/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-312.pyc index 8719308bd2ba2e4f1e04398503354d5d30fdf37e..930bd6f439e4f3850b9fc53932a206dd96ad3c00 100644 GIT binary patch delta 22 ccmeB}%G@!Pnfo*^FBbz4Jno&hk-PR308Fk2OaK4? delta 22 ccmeB}%G@!Pnfo*^FBbz4oY*~UBX{j708H@*TL1t6 diff --git a/venv/Lib/site-packages/pip/_vendor/distlib/scripts.py b/venv/Lib/site-packages/pip/_vendor/distlib/scripts.py index cfa45d2..e16292b 100644 --- a/venv/Lib/site-packages/pip/_vendor/distlib/scripts.py +++ b/venv/Lib/site-packages/pip/_vendor/distlib/scripts.py @@ -49,6 +49,24 @@ sys.exit(%(func)s()) ''' +# Pre-fetch the contents of all executable wrapper stubs. +# This is to address https://github.com/pypa/pip/issues/12666. +# When updating pip, we rename the old pip in place before installing the +# new version. If we try to fetch a wrapper *after* that rename, the finder +# machinery will be confused as the package is no longer available at the +# location where it was imported from. So we load everything into memory in +# advance. + +# Issue 31: don't hardcode an absolute package name, but +# determine it relative to the current package +distlib_package = __name__.rsplit('.', 1)[0] + +WRAPPERS = { + r.name: r.bytes + for r in finder(distlib_package).iterator("") + if r.name.endswith(".exe") +} + def enquote_executable(executable): if ' ' in executable: @@ -409,15 +427,11 @@ def _get_launcher(self, kind): bits = '32' platform_suffix = '-arm' if get_platform() == 'win-arm64' else '' name = '%s%s%s.exe' % (kind, bits, platform_suffix) - # Issue 31: don't hardcode an absolute package name, but - # determine it relative to the current package - distlib_package = __name__.rsplit('.', 1)[0] - resource = finder(distlib_package).find(name) - if not resource: + if name not in WRAPPERS: msg = ('Unable to find resource %s in package %s' % (name, distlib_package)) raise ValueError(msg) - return resource.bytes + return WRAPPERS[name] # Public API follows diff --git a/venv/Lib/site-packages/pip/_vendor/distro/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distro/__pycache__/__init__.cpython-312.pyc index e10c6a4d1b1d749f6c451ac99ac3b01c82389e3d..60177012c334dcb7f2efba08b18d6fb7cfaee74d 100644 GIT binary patch delta 20 acmdnYzL}l-G%qg~0}wp!owt#D1v3CT-v#6V delta 20 acmdnYzL}l-G%qg~0}!0pJ!>QP3T6O1A_emR diff --git a/venv/Lib/site-packages/pip/_vendor/distro/__pycache__/__main__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/distro/__pycache__/__main__.cpython-312.pyc index 6a850dba7ddbca2c0b3d31639568d80d231b953d..c2ddd18498e44f94923db3f051dfd25539bcd447 100644 GIT binary patch delta 20 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 diff --git a/venv/Lib/site-packages/pip/_vendor/distro/distro.py b/venv/Lib/site-packages/pip/_vendor/distro/distro.py index 89e1868..78ccdfa 100644 --- a/venv/Lib/site-packages/pip/_vendor/distro/distro.py +++ b/venv/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/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-312.pyc index b328e7785b1fc456543c2e2b3cce152156c68b1f..c4d39ecd6302b888979c89ce7f6df8020f46c0a5 100644 GIT binary patch delta 20 acmaFD_Joc5G%qg~0}wp!owt!Yk{JL&V+Hj9 delta 20 acmaFD_Joc5G%qg~0}!0pJ!>O(Br^a(rUnE6 diff --git a/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-312.pyc index e02dd07251f1569db7f5c90e5b97be007846b2a8..fa02f8ffdb21ce344a10e759b7974d149e887f6e 100644 GIT binary patch delta 1974 zcmZuxZ)jUp6n{5)dG94JuP?7@nB(2Tf=GJawTi4aujZVjyWx79NL2BCfS`*u3 z+?OF4$+|(+$|h^P!UBTqgW$$Mg&~T5ncoJYG*)RA`ay6A1C>hqXu5U)usHPC>{>%_YXc9A1x|Da-|r5-a91^%Y<`qrkH9jrdwsj!M(^C z!VG7K#XIe4o!yn7>o$c{Tk-F(>a!^iP%=<4ptO3M@&cupbwGBp5D9C3o2>&@wb?Dm zo@_9DW}~5*IQd!3=Sd4fcbqrsXZYa&WF@3}o*c)X8MsAiEa7ra-Ot`7`vqs!c_^K` zeTR$?a+5`z+l4xap(;D+{DN-;mrXdX_R@MJ{Qx%|RgOyF=sXpXY(n4>0tn3jmJ=Wn ziO>-Hkso&BDnmM<^{mI$O+4%kSBnoh8bVNPU{_qH1e;XYAFf_aFvW3)eJIIr!J#D9 zEd=XpslkM*Ydo1wOj6(NVWB|w=GMHjVrS&QG` z7qsoOLM0HI_1=@Uia%J2eb`rN@0jye8bYOA#bfsxL%*RnckG@&Sm}tfe)rMo=9X)@ zV(xm=LSV~{{&Ha7thXY0KXT3;U+_iCQgoKDsNvG7c{MsOMeUOf>2BJF*|sA@5TXE8 zel(Mrq?ja)A#@<@LFhzSzx6KcBDBDNzqK83hFf;DxnkFMFLTg*>9m_~2JPm~>AQR8 zUpalZuYBapDh}6{>VjJB2=j*1bQ!!UnEd~$Hth*++i;_}s}Eod1+!)XIH;JF5@FMh zQ@vRvY`cX81GBtY)S7L1V(@Exfn-sNwxwiN6#Q&S@V@3Mxbi%0$n%DPCA9=YM8*)F zMTy-U^v1F3Af=_jThh(E9J?l@Y>PcG3w3SVy$4tAXbQ{jW zCr`0T6fdXt)OLXP6xDKJ2;_;Lq!tolDenRDCwsu_fzW+5SnB-L z`HR}Q`N1kK4 zI^&a)Mmn*pr>9pJ=@AHI->Swm>WAXo+P4v(8tp|GK)_Ami-^${ZU~=Bz^ZDQ2|D)X z$oRSRST>nS(;;A!7=$Of$W=sn_WaLcu%h~xWNlFnm*sFp(U#PP%Wq%3@cxB$hh6qH z+22z=$UgH$x{u@X4r*3~Z0>9_JwfdP+GUe*NF2*dolQ=fHMJ@1A76xY0XDO(n)1Q` zgxERPO8yddF}12h&55LyHR-0?ekk=%WsGx^=0SP};_!&pS1heH@$oVjXYXiT9kEi= zVz93q>|5p9No@5niINQzbXJeDpEP}^OoUR$G6&7|EjRWqZaYwhU#x!xndJ~id>4iH O)Jy7|`YYTbR`g#?d6{bf delta 1409 zcmZuxO=uHA6yDkFZZ<#L&2CI>8r!Tjt!}jytv|KaAFATdq4=-lU}@b=Nof{nm9i zqrKO(umEl0)#F@mRZEg=b@QQJL=XixIMIxrznde!AU>0gio$WhQ7VEHbd`zL>XTGN z)Z^38G#iRtS}5tMS;>>4af{@Cn?S3Y!k4$tFcyMWt z6)Br22W*qglYK;-`$KvkI75)C4` z4naalAYi$r0Dxs#w1r7>HiWwj+k_fyT;ARj0?U)f%F}Mi3*-ya6c_UiW(0~$X$wM> z1A8l_BSQ(nvSJ54lkG6$rk^+XJUN#yj80O0uBzN1J7+?} zYw6Qg+&2aA^%t}i(#wmXA~3ePS`j;njDT+ZiBJ4)!Kv>ft zgC+uQP}&Ai5x$Gobiuv>`gcs z`=cTZR6*dU-Gj4UfD%3cIP%p7Cx21f&&*IaX$5U&Z~AxO zzf#aWxXGFl186oV(T^O$0qAul+T;#Y0tQq922=tDUx`&Az@~Ag=tF}I$IuXB5JMnb zf&N1Vs0g1W)faJ)MfASQXWdc9rNb1HXw2|1atLEMIf%dy5-F+!T!mh5SS{ZBAI|_D zvW>B{=nys(t7uZ*DU8CMmI|X&F8dU7viv2~9|^w?Tne5n580557a4b_sXOk%<0{ir z5FrP>gfia}zC?`WNNOpP`mDv-bHnDZ%Wh^L4XgVEtnftYddhV9TD~yu9}1qV7ra`W zx|W}G{i_gV8Pg&ecFgSD%XK>pYv@S?4A+p)iaIz|bgoaj2k9B`;;*mtfX$lCq=UUP wyEa*mnwOIUOUZ$nkS11bh_sWAH42Q{5R1p{M3^Y|FD@rKmlB;d0SqqiZ^UL0y8r+H diff --git a/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-312.pyc index 50ccd0a57a79f3f5f962f2161f56a9cc4bfde241..51ecd1979a92eed275015c251307ebec0e6e3d73 100644 GIT binary patch delta 20 acmaFG_KJ=BG%qg~0}wp!owt!Yo*4i_Qw9eB delta 20 acmaFG_KJ=BG%qg~0}!0pJ!>O(JTm}7mIf98 diff --git a/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-312.pyc b/venv/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-312.pyc index 8c8dabe5e9b91845be20578da73a98fccb461ffa..91aae77740c5987a693bf704ecfb733d0ece811d 100644 GIT binary patch delta 1462 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 OfB)qqeto~b-mm9%UFSO2 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